本人是一名物联网工程专业大二的学生,是互联网浪潮中一朵小小的浪花,写博客即是为了记录自己的学习历程,又希望能够帮助到很多和自己一样处于起步阶段的萌新。临渊羡鱼,不如退而结网。一起加油!
博客主页:https://blog.csdn.net/qq_44895397
@RequestMapping定义请求规则
-
通过@RequestMapping 注解可以定义处理器对于请求的映射规则。该注解可以注解在方法上,也可以注解在类上,但意义是不同的。value属性值常以“/”开始。
-
@RequestMapping 的 value 属性用于定义所匹配请求的 URI。但对于注解在方法上与类 上,其 value 属性所指定的URI,意义是不同的。
-
一个@Controller 所注解的类中,可以定义多个处理器方法。当然,不同的处理器方法 所匹配的 URI 是不同的。这些不同的 URI
被指定在注解于方法之上的@RequestMapping 的 value 属性中。但若这些请求具有相同的 URI 部分,则这些相同的URI,可以被抽取到注解在类之上的@RequestMapping 的value 属性中 此时的这个 URI 表示模块的名称。URI的请求 是相对于 Web 的根目录。
@Controller
@RequestMapping("/user")
public class MyController {
@RequestMapping(value = "/some.do")
public ModelAndView somedo(){
ModelAndView mv = new ModelAndView();
mv.addObject("msg","中国");
mv.setViewName("/WEB-INF/hello.jsp");
return mv;
}
@RequestMapping的method属性:
用于对被注解方法所处理请求的提交方式进行限制,即只有满足该 method 属性指定的提交方式的请求,才会执行该被注解方法。Method 属性的取值为 RequestMethod 枚举常量。
例如:
- RequestMethod.GET ----> GET请求
- RequestMethod.POST-----> POST请求
@Controller
@RequestMapping("/user")
public class MyController {
@RequestMapping(value = "/some.do" ,method = RequestMethod.POST)
public ModelAndView somedo(){
ModelAndView mv = new ModelAndView();
mv.addObject("msg","中国");
mv.setViewName("/WEB-INF/hello.jsp");
return mv;
}
客户端浏览器常用的请求方式,及其提交方式有以下几种:
- 只要指定了处理器方法匹配的请求提交方式为 POST,则相当于指定了请求发送的方式:要么使用表单请求,要么使用 AJAX 请求。其它请求方式被禁用。
- 当然,若不指定 method 属性,则无论是 GET 还是 POST 提交方式,均可匹配 即对于请求的提交方式无要求。
处理器方法的参数
处理器方法可以包含以下四类参数,这些参数会在系统调用时由系统自动赋值,即可在方法内直接使用。
- ➢ HttpServletRequest
- ➢ HttpServletResponse
- ➢ HttpSession
- ➢ 请求中所携带的请求参数
逐个参数接收
要求:保证请求参数名与该请求处理方法的参数名相同即可。
请求参数中文乱码问题
对于前面所接收的请求参数,若含有中文,则会出现中文乱码问题。Spring 对于请求参数中的中文乱码问题 ,给出了专门的字符集过滤器:
源码分析:
在web.xml中声明过滤器:
<!--过滤器-->
<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>forceRequestEncoding</param-name>
<param-value>true</param-value>
</init-param>
<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 所携带的参数名称与处理方法中指定的参数名不相同时,则需在处理方法参数前,添加一个注解@RequestParam(“请求参数名”),指定请求 URL 所携带参数的名称。
@RequestMapping(value = "/other.do")
public ModelAndView otherdo(@RequestParam("myname") String name, Integer age){
ModelAndView mv = new ModelAndView();
mv.addObject("name",name);
mv.setViewName("/WEB-INF/hello.jsp");
System.out.println(name);
return mv;
}
对象参数接收
将处理器方法的参数定义为一个对象,要保证请求参数名与这个对象的属性同名。
处理器方法的返回值
使用@Controller 注解的处理器的处理器方法,其返回值常用的有四种类型:
- ➢ 第一种:ModelAndView
- ➢ 第二种:String
- ➢ 第三种:无返回值 void
- ➢ 第四种:返回自定义类型对象
返回ModelAndView
若处理器方法处理完后,需要跳转到其它资源,且又要在跳转的资源间传递数据,此时处理器方法返回 ModelAndView 比较好。当然,若要返回 ModelAndView,则处理器方法中需要定义 ModelAndView 对象。
@RequestMapping(value = "/student.do")
public ModelAndView studentdo(Student student){
ModelAndView mv = new ModelAndView();
mv.addObject("name",student.getName());
mv.setViewName("/WEB-INF/hello.jsp");
System.out.println(student.getName());
return mv;
}
返回String
处理器方法返回的字符串可以指定逻辑视图名,通过视图解析器解析可以将其转换为物理视图地址(字符串的拼接)
返回void
对于处理器方法返回 void 的应用场景,AJAX 响应.
- 加入依赖:Jackson的依赖
- 引入js文件
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-core</artifactId>
<version>2.9.0</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.9.0</version>
</dependency>
@RequestMapping(value = "/returnvoid.do")
public void returnvoid(HttpServletResponse response,String name,Integer age) throws IOException {
Student student = new Student();
student.setName("林青霞");
student.setAge(18);
System.out.println(student);
//可以通过jkson的工具库实现对数据格式的转换
ObjectMapper om = new ObjectMapper();
String jaon = om.writeValueAsString(student);
//发送
PrintWriter writer = response.getWriter();
writer.print(jaon);
writer.flush();
writer.close();
}
返回对象 Object
处理器方法也可以返回 Object 对象。这个 Object 可以是 Integer,String,自定义对象,Map,List 等。但返回的对象不是作为逻辑视图出现的,而是作为直接在页面显示的数据出现的。
返回对象,需要使用@ResponseBody 注解,将转换后的 JSON 数据放入到响应体中。
- 加入Jackson的依赖
- 声明注解驱动
- 自定义返回对象
- 将 Object 数据转化为 JSON 数据,需要由消息转换器 HttpMessageConverter 完成。而转换器的开启,需要由<mvc:annotation-driven/>来完成。
- SpringMVC使用消息转换器实现请求数据和对象,处理器方法返回对象和响应输出之间的自动转换
- 当 Spring容器进行初始化过程中,在<mvc:annotation-driven/>处创建注解驱动时,默认 创建了八个 HttpMessageConverter 对象。也就是说,我们注册<mvc:annotation-driven/>,就是为了让容器为我们创建 HttpMessageConverter 对象。
<mvc:annotation-driven/>
处理器方法上面加入@ResponseBody注解
返回字符串对象
**若要返回非中文字符串,将前面返回数值型数据的返回值直接修改为字符串即可。**但若返回的字符串中带有中文字符 ,则接收方页面将会 出 现 乱 码 。 此 时 需 要 使 用@RequestMapping 的 produces 属性指定字符集。
- produces,产品,结果,即该属性用于设置输出结果类型。
@RequestMapping(value = "/returnRedirect.do"
,produces = "text/plain;charset=utf-8")
@ResponseBody
public String returnRedirect2(String name,Integer age){
return "";
}
解读<url-pattern>
配置详解
-
.do
在没有特殊要求的情况下,SpringMVC 的中央调度器 DispatcherServlet 的
常使用后辍匹配方式,如写为.do 或者 *.action, *.mvc 等。 -
“/”
可以写为/,因为 DispatcherServlet 会将向静态资源的获取请求,例如.css、.js、.jpg、.png
等资源的获取请求,当作是一个普通的 Controller 请求。中央调度器会调用处理器映射器为
其查找相应的处理器。当然也是找不到的,所以在这种情况下,所有的静态资源获取请求也
均会报 404 错误
静态资源访问
-
使用<mvc:default-servlet-handler/>
声 明 了 <mvc:default-servlet-handler /> 后 , springmvc 框 架 会 在 容 器 中 创 建DefaultServletHttpRequestHandler 处理器对象。
如果发现是静态资源的请求,就将该请求转由 Web 应用服务器默认的Servlet 处理。(任然依靠tomcat的静态资源处理) -
使用<mvc:resources/>
Spring 定义了专门用于处理静态资源访问请求的处理器
ResourceHttpRequestHandler。并且添加了<mvc:resources/>标签,专门用于解决静态资源无法访问问题。需要在 springmvc 配置文件中添加如下形式的配置:
解决动态资源和静态资源冲突的问题, 在 springmvc 配置文件加入:注解驱动
本站所有文章均为原创,欢迎转载,请注明文章出处:爱敲代码的小游子