一、SpringMVC
SpringMVC是基于Spring框架之上的后端框架
请求流程:客户端发起请求,请求被配置统一进入DispatcherServlet,由此servlet在HandlerMapping协助下格局请求路径将请求分发给配置了对应路径的Controller和method,执行方法后返回视图名称,经由视图解析器解析成页面返回。
DispatcherServlet来源如下:
进入DispatcherServlet需在web.xml中增加如下配置:
<servlet>
<servlet-name>chen</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!-- 当没有指定mvc配置文件时,默认去WEB-INF下寻找名为chen-servlet.xml文件,在FrameworkServlet中
使用org.springframework.web.context.ConfigurableWebApplicationContext 来生成文件中定义的bean -->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:muchen-servlet.xml</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>chen</servlet-name>
<url-pattern>*.do</url-pattern>
<!-- 容器启动后紧跟着启动 -->
<load-on-startup>1</load-on-startup>
</servlet-mapping>
该DispatcherServlet初始化时需加载SpringMVC的配置文件,当在该DispatcherServlet的初始化参数没有指定配置文件时会去WEB-INF目录下寻找[servlet-name]-servlet.xml文件。
SpringMVC的配置文件需配置以下几项:
<context:component-scan base-package="com.muchen"></context:component-scan>
<!-- 注册以下bean:
RequestMappingHandlerMapping:定位controller
RequestMappingHandlerAdapter:定位controller里的方法
ExceptionHandlerExceptionResolver:异常处理 -->
<mvc:annotation-driven/>
<!-- 注册视图解析器 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/jsp/"></property>
<property name="suffix" value=".jsp"></property>
</bean>
<!-- 注入org.springframework.web.servlet.resource.DefaultServletHttpRequestHandler,
由它检查进入DispatcherServlet的url是否为静态资源请求,
如果是,则交给服务器默认的Servlet处理,如果不是才交给DispatcherServlet处理-->
<mvc:default-servlet-handler/>
Controller:
@Controller
@RequestMapping("/mu/mu.do")
public class PrimaryController {
@Autowired
XzqhService xzqhService;
@RequestMapping(params="method=getQh",method=RequestMethod.GET)
public String getQh(@RequestBody String msg, ModelMap map, HttpServletRequest request, HttpServletResponse response) {
// get方法中同样可以用@RequestBody
System.out.println("msg1="+msg);
map.addAttribute("xzqh", xzqhService.queryXzqh(msg));
return "xzqh";
}
@RequestMapping(params="method=getAjax")
public void getAjax(HttpServletRequest request, HttpServletResponse response) throws IOException {
System.out.println(URLDecoder.decode(request.getReader().readLine(),"utf-8"));
// System.out.println(jsonArray);
}
}
注意:在Controller中传参只能使用一次request的输入流,否则会报输入流已被使用的异常错误。
二、SpringMVC注解
@Controller、@Service、@Reposity 与 @Component注解功效其实一样,在使用时@Controller换成@Component效果一样,为了方便标识才会有这些不一样名称标识的注解。
@RequestMapping
在类上表示进入此 @Controller 的路径,在方法上表示进入此方法的路径。
常用参数:
value:指定路径,@RequestMapping(value="test") 简写方式 @RequestMapping("/test");
method:指定请求的方法类型,method=RequestMethod.GET,method=RequestMethod.POST等;
params:指定请求要包含或不能包含的参数,params={"pra1=p1","pra2=p2","!pra3"},要有参数pra1和参数pra2,不能 有参数pra3的请求才能访问此方法。
被@RequestMapping注解的方法能传入的参数有以下这些:
1. HttpServletRequest、HttpServletResponse、HttpSession
2. InputStream、Reader,读取HttpServletRequest数据,
3. OutputStream、Writer,向HttpServletResponse写入数据
4. Map、Model、ModelMap,绑定模型数据
5. @RequestParam 绑定指定请求参数 ,简写形式@RequestParam String gender ,完整写法如下:
@RequestParam(value="请求参数名",required="是否必须:true/false",defaultValue="默认值") String gender
6. MultipartFile 用以接收上传文件
7. @RequestBody 一般用于前台参数类型为json时使用
8. @CookieValue 将request header中的cookie值绑定到方法参数上 @CookieValue("cookie名称") String cookie
9. @PathVariable 获取在url中的参数
// http://110.237.199.148:7070/muweb/interface/restful/testUrl/zhangsan/18
@RequestMapping("/testUrl/{name}/{age}")
public String testGetPath(@PathVariable("name") String name,@PathVariable("age") int age)
@Autowired 属性注入,按byType注入
@Resource 属性注入,按byName/byType注入,默认按byName注入,不是Spring注解,但spring支持此注解
@RequestBody 按照request中header的content-Type类型使用默认配置的HttpMessageConverter将request的请求 参数解析绑定到返回对象上,然后将返回的对象绑定到Controller的方法参数上,常用于请求参数是复 杂json的情形,multipart/form-data类型不能处理。
@ResponseBody 将Controller返回的对象按照request中header的Accept指定的类型使用默认配置的 HttpMessageConverter转换后写入response的缓冲区,常用于将返回对象转换为json对象的情况