Spring MVC springMVC-servlet.xml

DispatcherServlet的配置:

  DispatcherServlet是SpringMVC的前端控制器,所有的请求都经过前端控制器,也是项目中出现的唯一一个servlet,在 web.xml中进行配置:

    <servlet>
        <servlet-name>springMVC</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>

        <!-- springmvc配置文件默认的名字:<servlet-name>-servlet.xml -->
        <init-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>classpath:springMVC-servlet.xml</param-value>
        </init-param>
        <load-on-startup>1</load-on-startup>
    </servlet>
<servlet-mapping> <servlet-name>springMVC</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping>

1 @Controller:

  用于标记在一个类上,标记的类就是一个SpringMVC Controller对象

  dispatcherServlet会扫描使用该注解的类的方法,并检测该方法是否使用了@RequestMapping注解

  @Controller只是定义了一个控制器类,使用了@RequestMapping注解的方法才是真正处理请求的处理器

    <!-- 扫描controller -->
    <context:component-scan base-package="com.roxy.springmvc.controller"></context:component-scan>

2 @ RequestMapping()

  用于处理请求地址映射,可用于类或者方法上

  用于类上:说明类中所有响应请求的方法都是以该地址作为父路径

  返回值会通过视图解析器解析为实际的物理视图(通过perfix+returnValue+suffix的方式得到),然后做转发操作

     <!-- 视图解析器,定义了前缀和后缀 -->
     <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
         <property name="prefix" value="/WEB-INF/jsp/"></property>
         <property name="suffix" value=".jsp"></property>
     </bean>
pro:

  value:指定请求的实际地址
    value是默认的通知,可以省略;如果有其他的参数,则不可省略
  method:指定请求的method类型[GET、POST、PUT、DELETE等]
    POST形式:@RequestMapping(value="/world", method=RequestMethod.POST)
     GET形式:@RequestMapping(value="/world", method=RequestMethod.GET)
      如果不指定method,则接受任何形式的请求
       405:请求方式错误
  consumes:指定处理请求的提交内容类型[application/json、text/html等]
  produces:指定返回的内容类型,仅当request请求头中的Accept类型中包含该指定类型才返回
  params:指定request中必须包含某些参数值
  headers:指定request中必须包含某些指定的header值
@Controller
@RequestMapping("/hello")
public class HelloWorld {

    //请求映射:
    //    将url参数映射到方法,DispatcherServlet 根据这个配置中的uri地址决定调用哪个方法
    //  方法的返回值类型如果是字符串(String)
    @RequestMapping(value="/world", method=RequestMethod.GET)
    public String helloWorld(){
        
        //返回的是视图的名字
        System.out.println("hello world");
        
        //说明返回的是一个视图名字,DispatcherServlet 会根据视图解析器中的配置找到视图的完整的路径,从而解析并显示视图
        return "helloworld";
    }
}
ant风格:
 
  可以接收通配符
  @RequestMapping(""):
    通配符:
      ?:匹配文件名的一个字符
      *:匹配文件名的所有字符
      **:匹配多层路径
    @RequestMapping("/testantpath/*/draco")
    
    public String testAntpath() {
        
        System.out.println("antpath");
        
        return "success";
    } 

 3 @CookieValue()

  用于处理cookies,显示必须有值

    @RequestMapping("/testcookie")
    public String testCookie(@CookieValue("JSESSIONID") String sessionID){
        
        System.out.println(sessionID);
        
        return "success";
    }

 4 @RequestHeader():

  获取请求头中某一部分的值

    @RequestMapping("/testheader")
    public String testHeader(@RequestHeader(value="Accept-Language") String header) {
System.out.println(header);
return "success"; }

5 请求参数和请求头表达式:

params和 headers支持简单的表达式:
  param1: 表示请求必须包含名为 param1 的请求参数
  
!param1: 表示请求不能包含名为 param1 的请求参数   param1 != value1: 表示请求包含名为 param1 的请求参数,但其值 不能为 value1   {“param1=value1”, “param2”}: 请求必须包含名为 param1 和param2 的两个请求参数,且 param1 参数的值必须为 value1
    @RequestMapping(value="/testparam", params= {"username", "age!=10"}, headers= {"Accept-Language=zh-CN,zh;q=0.8"})
    public String testParam(String username, Integer age) {
        
        System.out.println(username + " " + age);
        
        return "success";
    }

 6 处理器请求参数: 

  6.1 自动的表单参数匹配(post/get):

    表单中控件name的值,和controller层方法的参数名一致,则匹配,可自动接收

    <form action="login" method="post">
        <label for="username">用户名<input type="text" id="username" name="username"/></label>
        <label for="password">密码<input type="password" id="password" name="password"/></label>
        <button>登录</button>
    </form>
    @RequestMapping(value="/login", method=RequestMethod.POST)
    public String login(String username, String password){
        
        System.out.println(username);
        System.out.println(password);
        
        return "redirect:world";
    }

  6.2 注解形式的参数匹配:

    表单中控件的name的值和controller方法中参数名不一致时,使用@RequestParam()注解

<label>用户名<input type="text" id="username" name="realname" /></label>
    @RequestMapping(value="/login", method=RequestMethod.POST)
    public String login(@RequestParam(value="realname") String username, String password) {

    }

  6.3 url中get形式的参数匹配:

    url中参数name的值,和controller层方法的参数名一致,则匹配,可自动接收

  6.4 可以用 defaultValue 属性设置上参数的默认值:  

    @RequestMapping("/list")
    public String list(
            @RequestParam(value="currentpage", defaultValue="1") Integer currentpage, 
            @RequestParam(value="pagesize", defaultValue="10") Integer pagesize) 

  6.5 必须使用包装类类型的参数:

    因为当参数不存在时,springmvc会将参数的值转换成null,若使用基本类型会出现转换异常

  6.6 可以使用required设置参数是否可选:   

    @RequestMapping("/list")
    public String list(
            @RequestParam(value="currentpage", required=false)Integer currentpage, 
            @RequestParam(value="pagesize", required=false)Integer pagesize) 

 7 路径参数

  使用 @PathVariable 将url地址中的路径部分做参数传递

    @RequestMapping("/get/{id}")
    public String get(@PathVariable(value="id") Integer id) {
System.out.println(
"id:" + id);
return "user/edit"; }

 8 请求转发和重定向:

请求转发: 
  
  return "视图名称";
重定向:
  
  return "redirect:controller的mapping地址"

 9 解决post乱码:

  在web.xml文件中配置字符编码过滤器,由spring提供
   <!-- 解决SpringMVC的post乱码 -->
    <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>
        <init-param>
            <param-name>forceEncoding</param-name>
            <param-value>true</param-value>
        </init-param>
    </filter>
    <filter-mapping>
        <filter-name>characterEncodingFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
原文地址:https://www.cnblogs.com/roxy/p/7604007.html