1、Spring容器和SpringMVC容器是父子容器
1.1 SpringMVC容器可以调用Spring容器中的所有内容
1.2 图示
2、SpringMVC环境搭建
1、导入jar包
2、在web.xml中配置前端控制器
2.1 <init-param> 如果不配置会自动去 / WEB-INF/<servlet-name>-servlet.xml 中寻找
<?xml version="1.0" encoding="utf-8"?>
<web-app xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
version="3.0">
<servlet>
<servlet-name>spring</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
自定义更改配置文件位置
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc.xml</param-value>
</init-param>
<!-- tomcat启动时加载此类 -->
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>spring</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
3、在scr下新建 springmvc.xml
3.1 引入 xmlns:mvc 命名空间
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd"> <!-- 扫描包 -->
<context:component-scan base-package="com.bjsxt.controller"></context:component-scan>
<!-- 注解驱动 -->
<!-- org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping-->
<!-- org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter -->
<mvc:annotation-driven></mvc:annotation-driven> 配置这个标签,也就会默认配置上面两个类
<!-- 静态资源 --> 由于控制器 / 可以拦截所有的(除.jsp)的请求,所以对静态资源放行(不要把对静态资源的请求当做是 其他请求)
<mvc:resources location="/js/" mapping="/js/**"></mvc:resources>
<mvc:resources location="/css/" mapping="/css/**"></mvc:resources>
这是在项目中的位置 这是在请求地址栏的资源
<mvc:resources location="/images/" mapping="/images/**"></mvc:resources>
</beans>
4、编写控制器类
@Controller
public class DemoController {
@RequestMapping("demo")
public String demo(){
System.out.println("执行demo");
return "/main.jsp";
}
}
5、字符编码过滤器
1.1 在web.xml中配置
<filter>
<filter-name>charsetEncoding</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>
</filter>
<filter-mapping>
<filter-name>charsetEncoding</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
6、传参
6.1 把内容写到方法(HandlerMethod)参数中,SpringMVC只要有这个内容,就自动注入内容
6.2 基本数据类型参数
6.2.1 默认保证参数名称和请求中传递的参数名相同就Ok
@Controller
public class DemoController {
@RequestMapping("demo")
public String demo(String name,int age){
System.out.println("执行demo"+name+age);
return "/main.jsp";
}
}
6.2.2 如果请求参数名和方法参数名不相同可以使用 @RequestParam()
@RequestMapping("demo")
public String demo(@RequestParam(value="name1")String name,@RequestParam(value="age1")int age){
System.out.println("执行demo"+name+age);
return "/main.jsp";
}
6.2.3 如果方法参数是基本数据类型(不是封装类)可以通过@RequestParam设置默认值
6.2.3.1 防止没参数时 500
@RequestMapping("pageinfo")
public String page(@RequestParam(defaultValue="2")int pageSize,@RequestParam(defaultValue="1")int pageNumber){
System.out.println("执行pageinfo"+pageSize+pageNumber);
return "main.jsp";
}
6.2.4 如果强制要求必须有某个参数
@RequestMapping("hand")
public String hand(@RequestParam(required=true)String name){
System.out.println("name是SQL查询条件,必须要传递name参数"+name);
return "main.jsp";
}
6.2.5 HandlerMethod中参数是对象类型
6.2.5.1 请求参数名和对象中属性名对应(get/set方法)
@RequestMapping("demo3")
public String hand(People people){
System.out.println(people);
return "main.jsp";
}
6.2.6 请求参数中包含多个同名参数的获取方式
如复选框(传递的就是多个同名参数)
@RequestMapping("demo5")
public String demo5(String name,int age,@RequestParam("hover")List<String> list){
System.out.println(name+" "+age+" "+list);
return "/main.jsp";
}
<body>
<form action="demo5" method="post">
<input type="text" name="name"/>
<input type="text" name="age"/>
<input type="checkbox" name="hover" value="学习"/>
<input type="checkbox" name="hover" value="敲代码"/>
<input type="checkbox" name="hover" value="健身"/>
<input type="checkbox" name="hover" value="睡觉"/>
<input type="submit" value="提交"/>
</form>
</body>
6.2.7请求参数中 对象.属性格式
6.2.7.1 jsp页面
<body>
<form action="demo5" method="post">
<input type="text" name="peo.name"/>
<input type="text" name="peo.age"/>
<input type="submit" value="提交"/>
</form>
</body>
6.2.7.2 新建一个类
对象名称要与 参数中 . 前面的名称相对应
public class Demo {
private People peo; public People getPeo() {
return peo;
}
public void setPeo(People peo) {
this.peo = peo;
}
@Override
public String toString() {
return "Demo [peo=" + peo + "]";
}
}
6.2.7.3 控制器
@RequestMapping("demo6")
public String demo6(Demo peo){
System.out.println(peo);
return "main.jsp";
}
6.2.8 请求参数中传递集合对象类型参数
6.2.8.1 jsp页面
<body>
<form action="demo6" method="post">
<input type="text" name="peo[0].name"/>
<input type="text" name="peo[0].age"/>
<input type="text" name="peo[1].name"/>
<input type="text" name="peo[1].age"/>
<input type="submit" value="提交"/>
</form>
</body>
6.2.8.2 新建一个类
public class Demo {
private List<People> peo; public List<People> getPeo() {
return peo;
}
public void setPeo(List<People> peo) {
this.peo = peo;
}
@Override
public String toString() {
return "Demo [peo=" + peo + "]";
}
}
6.2.8.3 控制器中
@RequestMapping("demo6")
public String demo6(Demo peo){
System.out.println(peo);
return "main.jsp";
}
6.2.9 restful 传值方式
6.2.9.1 简化jsp中参数编写格式
6.2.9.2 在jsp中设定特定的格式
<a href="demo7/阿旭/45">跳转</a>
6.2.9.3 在控制器中
6.2.9.3.1 在@RequestMapping中一定要和请求格式对应
6.2.9.3.2 {名称} 中名称自定义名称
6.2.9.3.3 @PathVariable 获取@RequestMapping中内容。默认按照方法参数名称去寻找
@RequestMapping("demo7/{name1}/{age}")
public String demo7(@PathVariable("name1")String name,@PathVariable int age){
System.out.println(name+age);
return "/main.jsp";
}
7、跳转方式
7.1 默认跳转方式请求转发
7.2 设置返回值字符串的内容:
7.2.1 添加redirect 资源路径:重定向
7.2.2 添加forward 资源路径或 省略 默认方式 转发
@RequestMapping("demo8")
public String demo8(){
System.out.println("重定向");
return "redirect:main.jsp";
}
8、视图解析器
8.1 SpringMVC 会提供默认视图视图解析器
8.2 程序员定义的视图解析器
<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/"></property>
<property name="suffix" value=".jsp"></property>
</bean>
8.3 如果希望不执行自定义视图解析器,在方法返回值前面加上 forward:或 redirect
@RequestMapping("demo8")
public String demo8(){
System.out.println("重定向");
return "redirect:main.jsp";
}
@RequestMapping("demo9")
public String demo9(){
System.out.println("自定义视图解析器");
return "main";
}
9、@ResponseBody
1 在方法上只有@RequesetMapping时,无论返回值是什么都认为是跳转页面
2 在方法上添加@ResponseBody(恒不跳转)
2.1 如果返回值满足key-value形式(对象或map)
2.1.1 把响应头设置为application/json;charset=utf-8
2.1.2 把转换后的内容输出流的形式响应给客户端
2.2 如果返回值不满足key-value,例如 返回值为string
2.2.1 把响应头设置为text/html
2.2.2 把方法返回值以流的形式直接输出
2.2.3 如果返回值包含中文,出现中文乱码
produces表示响应头中Content-Type取值
需要加上 produces的属性,防止出现中文乱码
@RequestMapping(value="demo11",produces="text/html;charset=utf-8")
@ResponseBody
public String demo11(){
People peo=new People();
peo.setName("阿旭旭");
peo.setAge(45);
return "中文";
}