ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

springmvc学习笔记

2021-05-03 23:30:50  阅读:136  来源: 互联网

标签:请求 笔记 springmvc 视图 学习 处理器 DispatcherServlet 方法


学习完王鹤老师的springmvc的笔记,王鹤老师视频地址https://www.bilibili.com/video/BV1sk4y167pD

springmvc是专门做web开发的,可以看做是servlet的一个升级,底层使用的是servlet

springmvc:springmvc能够创建对象,放入到springmvc的容器中,springmvc就是管理controller对象的容器。

springmvc简要:在方法的定义上使用@Controller 创建控制器对象,把创建的对象作为控制器使用。这个控制器对象能够接收用户的请求,显示处理结果,就当作是一个servlet使用

使用 @Controller 注解创建的是一个普通的对象 ,不是servlet,springmvc赋予了控制器对象一些额外的功能。
web开发底层是servlet,springmvc中有一个对象是servlet:DispatcherServlet(中央调度器)
DispatcherServlet:负责接收用户的所有请求,用户把请求给了DispatcherServlet,之后DispatcherServlet把请求转发给我们的Controller对象,最后Controller对象处理请求。

springmvc的简单使用:

1	发起some.do请求
2	tomcat (web.xml	从url-pattern知道 *.do 的请求给DispatcherServlet)
3	DispatcherServlet(根据spring.xml配置知道some.do,doSome()方法)
4	DispatcherServlet把some.do转发给MyController.doSome()方法
5	框架执行doSome()把得到的ModelAndView进行处理,转发到show.jsp	

具体可以查看第一个项目。

springmvc的调用流程:

在这里插入图片描述

需要注意的是:

1.web.xml中注册springmvc框架的核心对象 DispatcherServlet

1)DispatcherServlet叫做:中央调度器,是一个servlet,他的父类继承 HttpServlet
2)DispatcherServlet:负责接收用户提交的请求,调用其他控制器对象,并把请求的处理结果显示给用户
	<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
         version="4.0">

        <!--声明:注册springmvc的核心对象DispatcherServlet

        需要在tomcat服务器启动后,创建DispatcherServlet对象实例

        为什么要创建DispatcherServlet对象的实例呢?
        因为在DispatcherServlet创建过程中,会同时创建springmvc容器对象,
        读取springmvc的配置文件,把这个配置文件中的对象都配置好,
        当用户发起请求时就可以直接使用对象了。

        servlet的初始化会执行init()方法,DispatcherServlet在init()中{
            //创建容器,读取配置文件
            webApplicationContext ctx = new ClassPathXmlApplicationContext("springmvc.xml");
            //把容器对象放入到ServletContext中
            getServletContext().setAttribute(key,ctx);
         }
    -->
    <servlet>
        <servlet-name>springmvc</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>

        <!--自定义springmvc读取文件的位置-->
        <init-param>
            <!--springmvc配置文件的位置属性-->
            <param-name>contextConfigLocation</param-name>
            <!--指定自定义文件的位置-->
            <param-value>classpath:springmvc.xml</param-value>
        </init-param>

        <!--表示在tomcat启动后,创建servlet对象
            数字表示启动后创建对象的顺序,数值越小,tomcat创建对象越早,要求大于等于0的整数
        -->
        <load-on-startup>1</load-on-startup>

    </servlet>

        <servlet-mapping>
            <servlet-name>springmvc</servlet-name>
            <!--
                使用框架的时候,url-pattern可以使用两种值
                1.使用扩展名方式,语法 *.xxxx , xxxx时自定义扩展名。常用的方式 *.do, *.action, *.mvc等等
                    http://localhost:8080/myweb/some.do
                    http://localhost:8080?myweb/other.do
                2.使用斜杠"/"
            -->
            <url-pattern>*.do</url-pattern>
        </servlet-mapping>
</web-app>

2.需要在springmvc的配置文件中声明组件扫描器和视图解析器

组件扫码器:<context:component-scan base-package="com.bjpowernode.controller"/>指定@Controller注解所在的包名
视图解析器:

<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
		<!--前缀:视图文件位置-->
        <property name="prefix" value="/WEB-INF/view/"></property>
        <!--后缀:视图文件的扩展名-->
        <property name="suffix" value=".jsp"></property>
</bean>

SpringMVC 注解式开发

@RequestMapping

/*
* @RequestMapping
* 	value:所有请求的公共部分,叫做模块名称
*   位置:在类的上面
*/
@Controller
@RequestMapping("/user")
//或者@RequestMapping("/test")
public class MyController {
    @RequestMapping(value = "/some.do")
    public ModelAndView doSome(){
    }
}

换句话说,你要访问哪个模块,就在方法定义前,加上要访问的路径,例如:/user或者/test
在这里插入图片描述

@RequestMapping的属性method

method指定请求的提交方式,常用的为 RequestMethod.GET 与RequestMethod.POST,分别表示提交方式的匹配规则为 GET 与 POST 提交
客户端浏览器常用的请求方式,及其提交方式有以下几种
在这里插入图片描述

处理器方法的参数

处理器方法可以包含以下四类参数,这些参数会在系统调用时由系统自动赋值,即程序员可以在方法中直接使用。

1	HttpServletRequest		 请求
2	HttpServletResponse		 应答
3	HttpSession				会话
4	请求中所携带的请求参数	

具体使用可以查看第三个项目,结果如图:

解决请求参数中文乱码问题

<filter>
        <filter-name>characterEncodingFilter</filter-name>
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
        <!--指定字符集-->
        <init-param>
            <param-name>encoding</param-name>
            <param-value>utf-8</param-value>
        </init-param>
        <!--强制Request使用字符集encoding-->
        <init-param>
            <param-name>forceRequestEncoding</param-name>
            <param-value>true</param-value>
        </init-param>
        <!--强制Response使用字符集encoding-->
        <init-param>
            <param-name>forceResponseEncoding</param-name>
            <param-value>true</param-value>
        </init-param>
    </filter>
    <filter-mapping>
        <filter-name>characterEncodingFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>

逐个接收参数

接收用户提交的参数:只要保证请求参数名与该请求处理方法的参数名相同即可
在这里插入图片描述
在这里插入图片描述
查看第三个项目

校正请求参数名@RequestParam

请求URL携带的参数名称与方法中的名称不一致时,需要使用注解校正
在这里插入图片描述
在这里插入图片描述
查看第四个项目

对象参数接收

将处理器方法的参数定义为一个对象,对象的属性名要求和请求中参数名一致
查看第五个项目

处理器方法的返回值

使用@Controller 注解的处理器的处理器方法,其返回值常用的有四种类型:
➢ 第一种:ModelAndView
➢ 第二种:String
➢ 第三种:无返回值 void
➢ 第四种:返回自定义类型对象

第一种:ModelAndView

若处理器方法处理完后,需要跳转到其他资源,且又要在跳转的资源间传递数据,此时处理器方法返回 ModelAndView 比较好。当然,若要返回 ModelAndView,则处理器方法中需要定义 ModelAndView对象。

第二种:String

@Controller
public class MyController {
    /*
    * 处理器方法返回String,表示逻辑视图名称,需要配置视图解析
    * */
    @RequestMapping(value = "/returnString-view.do")
    public String doReturnView(HttpServletRequest request,String name, Integer age) {
        System.out.println("dosome方法的,name=" + name + ", age=" + age);

        //手动添加数据到request作用域
        request.setAttribute("myname",name);
        request.setAttribute("myage",age);
        /*
        * show:逻辑视图名称
        * 框架对视图执行forward转发操作
        * */
        return "show";
    }

    //处理器方法返回 String,表示完整视图路径,此时不能配置视图解析器
    @RequestMapping(value = "/returnString-view2.do")
    public String doReturnView2(HttpServletRequest request,String name, Integer age) {
        System.out.println("---doReturnView2方法---,name=" + name + ", age=" + age);

        //手动添加数据到request作用域
        request.setAttribute("myname",name);
        request.setAttribute("myage",age);
        /*
         * 完整视图路径,项目中不能配置视图解析器
         * 框架对视图执行forward转发操作
         * */
        return "WEB-INF/view/show.jsp";
    }
}

查看第六个项目

第三种:无返回值 void

void:不能表示数据,也不能表示视图。在处理ajax的时候,可以使用void返回值。通过HttpServletResponse输出数据。响应ajax请求。ajax请求服务器端返回的就是数据,和视图无关。

第四种:返回对象Object

object:例如String,Integer,Map,List,Student 等等都是对象,对象有属性,属性就是数据。所以返回 object 表示数据,和视图无关。可以使用对象表示的数据,响应ajax请求。

//处理器方法返回一个Student,通过框架转为json,响应ajax请求
//@ResponseBody 作用:把处理器方法返回对象转为json后,通过HttpServletResponse输出给浏览器
@ResponseBody
@RequestMapping(value = "returnStudentJson.do")
public Student doStudentJsonObject(String name,Integer age){
    Student student = new Student();
    student.setName("lisi");
    student.setAge(20);
    return student; //会被框架转为json
}

解读中央调度器 < url-pattern/ >

(1) .do
在没有特殊要求的情况下,SpringMVC 的中央调度器 DispatcherServlet 的
常使用后辍匹配方式,如写为
.do 或者 *.action, *.mvc 等
(2) /
可以写为/,因为 DispatcherServlet 会将向静态资源的获取请求,例如.css、.js、.jpg、.png
等资源的获取请求,当作是一个普通的 Controller 请求。中央调度器会调用处理器映射器为
其查找相应的处理器。当然也是找不到的,所以在这种情况下,所有的静态资源获取请求也
均会报 404 错误
(3).tomcat本身能处理静态资源的访问,像html,图片,js文件等都是静态资源,tomcat的web.xml文件有一个 servlet 名称为 default。
这个名叫 default 的 servlet 作用:
1 处理静态资源
2 处理未映射到其它servlet的请求
使用 ” / “ 后,无法访问静态资源,可以访问动态资源
解决方案:使用<mvc:default-servlet-handler/>或者<mvc:resources/>或者使用注解驱动<mvc:annotation-driven/>

<mvc:default-servlet-handler/>:只需要在 springmvc.xml 中添加<mvc:default-servlet-handler/>标签即可
在这里插入图片描述
<mvc:resources/>:在springmvc 配置文件中添加如下形式的配置

<mvc:resources mapping="/static/**" location="/static/" />

location 表示静态资源所在目录。当然,目录不要使用/WEB-INF/及其子目录。
mapping 表 示 对 该 资 源 的 请 求 ( 以 /images/ 开 始 的 请 求 , 如 /image/beauty.jpg ,
/images/car.png 等)。注意,后面是两个星号**

<mvc:annotation-driven/>
在这里插入图片描述

SSM整合开发

详情SSM整合开发笔记

SpringMVC 核心技术

请求重定向和转发

转发

处理器方法返回 ModelAndView 时,需在 setViewName()指定的视图前添加 forward:,且
此时的视图不再与视图解析器一同工作,这样可以在配置了解析器时指定不同位置的视图。
视图页面必须写出相对于项目根的路径。forward 操作不需要视图解析器。
处理器方法返回 String,在视图路径前面加入 forward: 视图完整路径
在这里插入图片描述

重定向

在处理器方法返回的视图字符串的前面添加 redirect:,则可实现重定向跳转
在这里插入图片描述

拦截器

public class MyInterceptor implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest request,
                             HttpServletResponse response,
                             Object handler) throws Exception {
        System.out.println("拦截器的MyInterceptor的preHandle()");
        return true;
    }
    @Override
    public void postHandle(HttpServletRequest request,
                           HttpServletResponse response,
                           Object handler, ModelAndView mv) throws Exception {
        System.out.println("拦截器的MyInterceptor的postHandle");

    }
    @Override
    public void afterCompletion(HttpServletRequest request,
                                HttpServletResponse response,
                                Object handler, Exception ex) throws Exception {
        System.out.println("拦截器的MyInterceptor的afterCompletion");
    }
}

preHandle:该方法在处理器方法执行之前执行。其返回值为 boolean,若为 true,会执行后面的afterCompletion
postHandle:该方法在处理器方法执行之后执行。
afterCompletion: 当 preHandle()方法返回 true 时才会执行,最后执行的方法,清除资源
多个拦截器的执行顺序:
在这里插入图片描述

标签:请求,笔记,springmvc,视图,学习,处理器,DispatcherServlet,方法
来源: https://blog.csdn.net/qq_45604925/article/details/115935617

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有