Bootstrap

第七章:Springmvc中applicationContext.xml配置文件应用上下文详解

主要配置程序的总体用上下文,让容器对全局掌握来龙去脉
1.扫描所有项目的包名
2.配置项目所有的静态资源映射
3.配置请求方法的映射驱动
4.配置适配器适配@RequestMapping注解标注的Handler(HandlerMethod类型)
5.配置消息转换器决定浏览器以什么样的形式解析响应的消息
6.配置视图解析器即如何从服务器端转向具体页面解析
7.配置上传文件的大小限制

头文件

<?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:mvc="http://www.springframework.org/schema/mvc" 
   
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:tx="http://www.springframework.org/schema/tx" 
    xmlns:aop="http://www.springframework.org/schema/aop"
    xsi:schemaLocation="http://www.springframework.org/schema/beans
               http://www.springframework.org/schema/beans/spring-beans-4.3.xsd
               
               http://www.springframework.org/schema/mvc
       		   http://www.springframework.org/schema/mvc/spring-mvc.xsd
               http://www.springframework.org/schema/context
               http://www.springframework.org/schema/context/spring-context-4.3.xsd
               http://www.springframework.org/schema/tx
               http://www.springframework.org/schema/tx/spring-tx-4.3.xsd
               http://www.springframework.org/schema/aop
               http://www.springframework.org/schema/aop/spring-aop-4.3.xsd
               ">

1.扫描所有项目的包名–注入容器

作用:扫描包及其子包下的所有带注解的类,注入Spring的bean。
如果有@Component(组件)、@Service(服务)、@Controller(控制器)、@Repository(数据仓库)构造型(stereotype)注解所标注的类,则将对象作为Bean注册注入到Spring IOC容器中。
举例:
在注解后加上例如@Component(value=”a”)时,注册的这个类的bean的id就是a.

#base-package指明一个包,多个包用逗号隔离开
#扫描这个包下所有项目
<context:component-scan base-package="com.test"></context:component-scan>
#扫描多个指定多个包下的所有项目,逗号隔离开
<context:component-scan base-package="com.test1.xxx,com.test2.xxx"/>
多个包逗号隔开。

2.配置项目所有的静态资源的映射(放行资源)

作用:自定义请求项目内静态资源的访问路径URL规则。
目的:为了访问或者加载项目内静态资源。
SpringMVC的配置文件中使用mvc:resource标签来设置要放行的静态资源
mvc:resources 加入后框架会创建ResourceHttpRequestHandler这个处理器对象。 让这个对象处理静态资源的访问,不依赖tomcat服务器。
注意: css,js,images文件夹放于WebContent目录下。

	<mvc:resources mapping="/jspath/**" location="/js/" />
	<mvc:resources mapping="/imgpath/**" location="/img/" />
	<mvc:resources mapping="/csspath/**" location="/css/" />
#静态资源解释:以配置的js为例
mapping和@RequestMapping区别
mapping: 访问静态资源的uri地址,使用通配符 **  意思是代表某个映射规则下所有请求形式
location:静态资源在你的项目中的目录位置。
1.mapping中定义的是访问静态资源的url,最前面的/表示的是WebContent根目录,后面的js是WebContent目录下的js文件夹或者子目录,最后的**表达多层路径(可能是一层或者多层路径)
2.location中定义的是根目录下的js文件位置
举例:比如 /js/login/login.js  如何访问login.js???
假设整个项目的包名为Shopping
根据mapping定义的访问规则映射访问项目中静态资源。
localhost:8080/Shopping/jspath/login.js 这个url就能访问到location=/js/”这是项目中静态资源所在的位置

当然,为了方便,也可以把images、js、html等文件夹都放到一个文件夹下(创建static文件夹)

<mvc:annotation-driven />
<mvc:resources mapping = "/static/**" location = "/static/" />
<!-- static/**表示该目录下所有文件-->

3.配置静态资源方法的映射驱动

spring配置文件中启动mvc注解驱动
mvc:annotation-driven
静态资源乱码StringHttpMessageConverter引出的客户端服务器端之间的乱码配置两种方式
使用mvc:annotation-driven不用配置上边的RequestMappingHandlerMapping和RequestMappingHandlerAdapter

#第一种方式
<mvc:annotation-driven>
#处理静态资源请求和返回乱码问题
        <mvc:message-converters register-defaults="true">
            <bean class="org.springframework.http.converter.StringHttpMessageConverter">
              <constructor-arg value="UTF-8" />
            </bean>
        </mvc:message-converters>
    </mvc:annotation-driven>
#第二种方式
<mvc:annotation-driven >
        <!-- 消息转换器,添加对文字编码的全局处理,解决中文返回问号的毛病 --> 
        <mvc:message-converters register-defaults="true">
            <bean class="org.springframework.http.converter.StringHttpMessageConverter">
                <property name="supportedMediaTypes" value="text/html;charset=UTF-8"/>
            </bean>
        </mvc:message-converters>
    </mvc:annotation-driven>
#第三种方式
<bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">
        <property name="messageConverters">
            <list>
                <!-- String 转换器 -->
               <ref bean="stringHttpMessageConverter"/>
                <!-- JSON 转换器 -->
                <ref bean="jsonHttpMessageConverter"/>
                <!-- XML 转换器 -->
            </list>
        </property>
</bean>
    
    <!-- <bean id="stringHttpMessageConverter" class="org.springframework.http.converter.StringHttpMessageConverter"/> -->
 
<bean id="jsonHttpMessageConverter"
          class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter">
        <property name = "supportedMediaTypes">
             <list>
                 <value>text/html;charset=UTF-8</value>  
                 <value>text/plain;charset=UTF-8</value>  
            </list>   
       </property>   
</bean>
<bean id="stringHttpMessageConverter"
          class="org.springframework.http.converter.StringHttpMessageConverter">
        <property name = "supportedMediaTypes">
             <list>
            	 <value>text/html;charset=UTF-8</value> 
                 <value>text/plain;charset=UTF-8</value>   
            </list>   
       </property> 
</bean>    
如果GET方式请求页面依然出现乱码的情况,可以在view中请求的jsp页面的第一行,添加如下jsp代码:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>

<mvc:annotation-driven />标签是为了解决resources标签 和@RequestMapping注解的冲突。

<!--采用注解驱动-->
在我们设置
<url-pattern>/</url-pattern>后,
动态资源和静态资源的访问就会造成冲突,我们此时就需要配置另外静态资源
一、<mvc:default-servlet-handler />标签
在springmvc配置文件中加入
<mvc:annotation-driven />
<mvc:default-servlet-handler />
原理是:
加入<mvc:default-servlet-handler />标签后,
框架会创建控制器对象DefaultServletHttpRequestHandler(类似我们自己创建的Controller对象)。
DefaultServletHttpRequestHandler这个对象可以把接收的请求转发给tomcat的default这个servlet。
----------------------------------------------------
<mvc:annotation-driven />标签是为了解决default-servlet-handler标签
和@RequestMapping注解的冲突。
------------------------------------------------
二、<mvc:resources />标签
mvc:resources 加入后框架会创建ResourceHttpRequestHandler这个处理器对象。
让这个对象处理静态资源的访问,不依赖tomcat服务器。

<mvc:annotation-driven />注解意义
提供Controller请求转发,json自动转换等功能

0.HttpServletResponse 对象写回数据,HttpServletRequest对象带回数据,ModelandView对象带回数据
或者@ResponseBody将字符串数据返回对象或集合@ResponseBody和<mvc:annotation-driven/>
1.提供Controller请求转发,json自动转换等功能。
2.解决了@Controller注解的使用前提配置<context:annotation-config/>是对包进行扫描,
实现注释驱动Bean定义,将bean自动注入容器中使用。即解决了@Controller标识的类的bean的注入和使用
3.自动注册RequestMappingHandlerMapping与RequestMappingHandlerAdapter两个Bean
4.提供数据绑定支持
5.@NumberFormatannotation支持,@DateTimeFormat支持,@Valid支持读写XML的支持(JAXB)和读写JSON的支持(默认Jackson)等功能。
6.处理响应ajax请求时,就使用到了对json的支持
7.写JUnit单元测试时,要从spring IOC容器中取DefaultAnnotationHandlerMapping
与AnnotationMethodHandlerAdapter 两个bean来完成测试,这是通过<mvc:annotation-driven />
注册的这两个bean

4.配置消息转换器

json消息转换器
spring默认使用的json消息转换器是MappingJackson2HttpMessageConverter,spring3是使用MappingJacksonHttpMessageConverter。
类MappingJackson2HttpMessageConverter是实现json序列化和反序列化的核心。

<!-- 启动Spring MVC的注解功能,完成请求和注解POJO的映射 -->
	<bean	class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">
		<property name="messageConverters">
			<list>
				<!--json转换器 -->
				<ref bean="testMessageConverter" />
			</list>
		</property>
	</bean>
	<bean  class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter">
		<property name="messageConverters">
			<list>
				<ref bean="testMessageConverter" />
			</list>
		</property>
	</bean> 
<bean  id="testMessageConverter" class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter">
		<property name="supportedMediaTypes">
			<list>
				<bean class="org.springframework.http.MediaType">
					<constructor-arg index="0" value="text" />
					<constructor-arg index="1" value="plain" />
					<constructor-arg index="2" value="UTF-8" />
				</bean>
				<bean class="org.springframework.http.MediaType">
					<constructor-arg index="0" value="*" />
					<constructor-arg index="1" value="*" />
					<constructor-arg index="2" value="UTF-8" />
				</bean>
				<bean class="org.springframework.http.MediaType">
					<constructor-arg index="0" value="text" />
					<constructor-arg index="1" value="*" />
					<constructor-arg index="2" value="UTF-8" />
				</bean>
				<bean class="org.springframework.http.MediaType">
					<constructor-arg index="0" value="application" />
					<constructor-arg index="1" value="json" />
					<constructor-arg index="2" value="UTF-8" />
				</bean>
			</list>
		</property>
</bean>  
------------------------代码测试1---------------------------
var parameter= {
		"name":"zhangsan",
		"age": 18
	};
	$.ajax({
		url:"testurl",
		type:"post",
		data:JSON.stringify(parameter), //参数转换成json对象
		contentType:"application/json;charset=UTF-8",//告诉收件人服务器接收的数据类型
		dataType: 'json',//从接口返回的数据形式
		success: function (res) {
			
		},
		error: function (res) {
			
		}
});
@RequestMapping(value="testurl", method=RequestMethod.POST, produces="application/json;charset=UTF-8", consumes="application/json;charset=UTF-8")
@ResponseBody //将java对象转成json
public String DoFunction(User user) { 
	//...
}

------------------------代码测试2---------------------------
@Controller
@RequestMapping("/test")
public class testController {
	@Autowired
	private TestService testService;
	
	// 查询数据
	@RequestMapping("getAll")testService
	@ResponseBody
	public Map<String, Object> doSelectDfc() {
		return testService.findAll();
	}
	
	@RequestMapping("/getJson")
	@ResponseBody
	public String doGet() {
	    return testService.findAllList().toString;		
	}
	
	// 插入数据
	@RequestMapping("/InsertData")
	public boolean doInsertDfc(Data dataObject) { 
		if (testService.InsertData(dataObject)) {
			return true;
		} else {
			return false;
		}
	}
}

解释Content-type:application/json; charset = utf-8
$.ajax
contentType 和 dataType , contentType 主要设置你发送给服务器的格式,
dataType设置你收到服务器数据的格式。

5.配置视图解析器

配置xml前后缀如何拼接
请求接口的方法返回字符串与视图解析器的前后缀拼接后跳转。
在这里插入图片描述转发:forward:/WEB-INF/views/index.jsp
重定向:redirect:/index.jsp

#第一种方式
<!--定义内部资源视图解析器-->
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>
        <property name="prefix" value="/WEB-INF/views(文件夹名字)/"/>
		<!--资源的后缀名-->        
        <property name="suffix" value=".jsp"/>
    </bean>
#	第二种方式 这是html
	<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
		<!-- 配置html路径的前缀,在哪个文件下 -->
		<property name="prefix" value="/WEB-INF/Html/"/>
		<!-- 哪个文件夹下以配置html路径的后缀文件 -->
		<property name="suffix" value=".html"/>		
	</bean>

如果返回的视图用到jstl标签库,就是${ } 取 modelandview 对象的参数 如果视图解析器解析jsp解析,默认使用jstl标签,classpath下的得有jstl的包
举例:

@Controller
@RequestMapping("/TestReturnView")
public class TestReturnView{
	@RequestMapping("/userLogin")
	public ModelAndView login(HttpSession session, String username, String password,HttpServletRequest request)
				throws Exception {
			ModelAndView view = new ModelAndView();
			User userinfo = userService.findUserByCondition(username,password);
			String projectPath = request.getContextPath();//从请求中获取项目的端口和项目路径
			if(login !=null){
				session.setAttribute("userinfo", userinfo);//session放用户信息
				view.addObject("projectPath", projectPath);
				view.setViewName("index");//主页面
			}			
			}else{
				//登录失败
				view.addObject("errmsg", "用户名或密码错误");
				view.setViewName("error");//错误页面
			}
			return view;
		}
}		
在index.jsp页面如何取session和view中值呢?

首先视图中携带这返回信息,信息以map形式存储在内存中

在index.jsp前端页面如何获取携带回的值?用jstl标签
1.在项目classpath下有jstl包
2.前端页面加jstl 标签
<%@ page language="java" import="java.util.*" contentType="text/html; charset=UTF-8"  pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
#获取携带回的值
var projectPath = '${projectPath}';
var userinfo = <%=session.getAttribute("userinfo") %>;

6.配置文件上传的大小限制

CommonsMultipartResolver的作用

<!--文件上传解析器-->
    <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
        <!-- 设置请求编码格式,必须与JSP中的pageEncoding属性一致,默认为ISO-8859-1 -->
        <property name="defaultEncoding" value="UTF-8" />
        <!-- 设置允许上传文件的最大值单位为字节 ,比如10M= 10485760 字节=10*1024*1024  -->
        <property name="maxUploadSize" value="10485760"/>
    </bean>
    ------------------------------------
    注意:在配置CommonsMultipartResolver时必须指定该Bean的id为multipartResolver。 
	因为初始化MultipartResolver时,程序会在Spring容器中查找名称为multipartResolver的
	MultipartResolver实现类,
	如果没有查找到对应名称MultipartResolver实现类,将不提供文件解析处理
配置文件上传基础实操

项目中导入Apache Commons FileUpload组件的依赖,即commons-fileupload依赖和commons-io依赖。由于commons-fileupload依赖会自动依赖commons-io
前端页面
form表单的method属性设置为post。
form表单的enctype属性设置为multipart/form-data。
提供的文件上传输入框。

//创建一个 前端页面
<form action="uploadpath" method="post" enctype="multipart/form-data" >
这个  name=testfile   这个key 要和对接的接口形参数一致
    <input type="file" name="testfile666" multiple="multiple" />
    <input type="submit" value="文件上传" />
</form>
@Controller
@RequestMapping("/uploadtest")
uploadpath
public ModelAndView FileUpload {
    @RequestMapping("/testfileUpload")
    public String testfileUpload(MultipartFile testfile666, HttpServletRequest request) throws IOException {
    //这个 testfile参数 要与input 输入框的name 属性的值也就是name的key 相同
        String filepath = request.getServletContext().getRealPath("/") + "testfile666/";
		ModelAndView view = new ModelAndView();
        if (!testfile.isEmpty()) {
            // 保存上传的文件,filepath为保存的目标目录
            String filePath = filepath + testfile666.getOriginalFilename();
            testfile.transferTo(new File(filePath));
            //返回成功上传页面
			view.addObject("msg","成功");
			view.setViewName("success");			
		}else{
			view.setViewName("failure");
		}		
       	return view; 
    }
}

7.引发思考:xml 文件中配置的信息注册类不是唯一的

根据实际情况或者项目的复杂程度进行配置

点解连接
第一章:Spring流程执行步骤
第二章:Spring核心思想和IOC和AOP依赖注入
第三章:Spring常用注解解释
第四章:Spring七大核心模块Bean、Core、Context
第五章:Spring细分一如何让mapper文件夹下的SQL语句对数据库生效,jdbc和mybatis-config.xml
第六章:Springmvc事务管理和配置文件xml详解和七大事务和注解@Transactional
第七章:Springmvc中applicationContext.xml配置文件应用上下文详解

;