SpringMVC
国际化
- 国际化需求
-
在页面上能够根据浏览器语言设置的情况对文本(不是内容), 时间, 数值进行本地化处理 解决:使用 JSTL 的 fmt 标签
-
在src下新建i18n.propertis和i18n_en_US.properties和i18n_zh_CN.properties两个文件
i18n.propertis
otEmpty.employee.lastName=^^LastName\u4E0D\u80FD\u4E3A\u7A7A. Email.employee.email=Email\u5730\u5740\u4E0D\u5408\u6CD5 Past.employee.birth=Birth\u4E0D\u80FD\u662F\u4E00\u4E2A\u5C06\u6765\u7684\u65F6\u95F4 typeMismatch.employee.birth=Birth\u4E0D\u662F\u4E00\u4E2A\u65E5\u671F\u3001 i18n.user=\u7528\u6237\u540D i18n.Password=\u5BC6\u7801
i18n_en_US.properties
NotEmpty.employee.lastName=^^LastName\u4E0D\u80FD\u4E3A\u7A7A. Email.employee.email=Email\u5730\u5740\u4E0D\u5408\u6CD5 Past.employee.birth=Birth\u4E0D\u80FD\u662F\u4E00\u4E2A\u5C06\u6765\u7684\u65F6\u95F4 typeMismatch.employee.birth=Birth\u4E0D\u662F\u4E00\u4E2A\u65E5\u671F\u3001 i18n.user=\u7528\u6237\u540D i18n.Password=\u5BC6\u7801
i18n_zh_CN.properties
NotEmpty.employee.lastName=^^LastName\u4E0D\u80FD\u4E3A\u7A7A. Email.employee.email=Email\u5730\u5740\u4E0D\u5408\u6CD5 Past.employee.birth=Birth\u4E0D\u80FD\u662F\u4E00\u4E2A\u5C06\u6765\u7684\u65F6\u95F4 typeMismatch.employee.birth=Birth\u4E0D\u662F\u4E00\u4E2A\u65E5\u671F\u3001 i18n.user=User i18n.Password=Password
-
在springmvc.xml中配置
<!-- 配置国际化资源文件 --> <bean id="messageSource" class="org.springframework.context.support.ResourceBundleMessageSource"> <property name="basename" value="i18n"></property> </bean> <mvc:view-controller path="/i18n" view-name="i18n"/> <mvc:view-controller path="/i18n2" view-name="i18n2"/>
3.在views下新建i18n.jsp 和i18n2.jsp进行测试
i18n.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %> <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Insert title here</title> </head> <body> <fmt:message key="i18n.user"></fmt:message> <br><br> <a href="i18n2">I18N2 Page</a> </body> </html>
i18n2.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %> <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Insert title here</title> </head> <body> <fmt:message key="i18n.password"></fmt:message> <br><br> <a href="i18n">I18N Page</a> </body> </html>
4.这样 在修改首选语言再点超链接时,页面出现的语言就会转换
-
-
可以在 bean 中获取国际化资源文件 Locale 对应的消息。
解决:在 bean 中注入
ResourceBundleMessageSource
的示例, 使用其对应的getMessage
方法即可-
在SpringMVCTest.java中新建一个方法
@Controller public class SpringMVCTest { @Autowired private ResourceBundleMessageSource messageSource; @RequestMapping("/i18n") public String testI18n(Locale locale){ String val = messageSource.getMessage("i18n.user", null, locale); System.out.println(val); return "i18n"; } }
- 这样在点击i18n.jsp和i18n2.jsp链接时,就会在控制台打印 相对应语言的信息
-
可以通过超链接切换 Locale, 而不再依赖于浏览器的语言设置情况 解决:.配置
LocalResolver
和LocaleChangeInterceptor
-
首先在springmvc.xml文件中配置
<!-- 配置 SessionLocalResolver --> <bean id="localeResolver" class="org.springframework.web.servlet.i18n.SessionLocaleResolver"></bean> <mvc:interceptors> <!-- 配置 LocaleChanceInterceptor --> <bean class="org.springframework.web.servlet.i18n.LocaleChangeInterceptor"></bean> </mvc:interceptors>
- 在i18n.jsp中加入两个超链接 用于切换语言
<br><br> <a href="i18n?locale=zh_CH">中文</a> <br><br> <a href="i18n?locale=en_US">英文</a>
-
文件的上传
-
步骤
-
首先在springmvc.xml中配置文件
<!-- 配置 MultipartResolver --> <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <property name="defaultEncoding" value="UTF-8"></property> <property name="maxUploadSize" value="1024000"></property> </bean>
-
其次在SpringMVCTest.java写一个测试方法
@RequestMapping("/testFileUpload") public String testFileUpload(@RequestParam("desc") String desc, @RequestParam("file") MultipartFile file) throws IOException{ System.out.println("desc: " + desc); System.out.println("OriginalFilename: " + file.getOriginalFilename()); System.out.println("InputStream: " + file.getInputStream()); return "success"; }
-
最后在views下新建一个success.jsp页面以及在index.jsp中写一个表单
<form action="testFileUpload" method="POST" enctype="multipart/form-data"> File: <input type="file" name="file"/> Desc: <input type="text" name="desc"/> <input type="submit" value="Submit"/> </form>
-
显示效果
-
拦截器
-
第一个自定义拦截器
-
创建一个
com.atguigu.springmvc.interceptors
包,包下创建FirstInterceptor.java类package com.atguigu.springmvc.interceptors; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.springframework.web.servlet.HandlerInterceptor; import org.springframework.web.servlet.ModelAndView; public class FirstInterceptor implements HandlerInterceptor{ /** * 渲染视图之后被调用. 释放资源 */ @Override public void afterCompletion(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, Exception arg3) throws Exception { System.out.println("[FirstInterceptor]afterCompletion"); } /** * 调用目标方法之后, 但渲染视图之前. * 可以对请求域中的属性或视图做出修改. */ @Override public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, ModelAndView arg3) throws Exception { System.out.println("[FirstInterceptor]postHandle"); } /** * 该方法在目标方法之前被调用. * 若返回值为 true, 则继续调用后续的拦截器和目标方法. * 若返回值为 false, 则不会再调用后续的拦截器和目标方法. * * 可以考虑做权限. 日志, 事务等. */ @Override public boolean preHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2) throws Exception { System.out.println("[FirstInterceptor]preHandle"); return true; } }
-
在springmvc.xml文件中配置
-
<mvc:interceptors> <!-- 配置自定义的拦截器 --> <bean class="com.atguigu.springmvc.interceptors.FirstInterceptor"></bean> </mvc:interceptors>
-
-
-
拦截器的配置
-
在com.atguigu.springmvc.interceptors下创建SecondInterceptor.java类
-
<mvc:interceptors> <!-- 配置自定义的拦截器 --> <bean class="com.atguigu.springmvc.interceptors.FirstInterceptor"></bean> <!-- 配置拦截器(不)作用的路径 --> <mvc:interceptor> <!-- <mvc:exclude-mapping path="/emps"/> 不作用路径配置--> <mvc:mapping path="/emps"/> <bean class="com.atguigu.springmvc.interceptors.SecondInterceptor"></bean> </mvc:interceptor> </mvc:interceptors>
-
点击index.jsp页面上任意按钮和链接时,控制台打印
-
-
多个拦截方法的执行顺序
-
如果
FirstInterceptor的preHandle
方法return false,则只会执行FirstInterceptor的preHandle
方法,控制台只会打印[FirstInterceptor]preHandle
-
如果
SecondInterceptor的preHandle
方法return false,则会执行
FirstInterceptor的preHandle
方法,SecondInterceptor的preHandle
方法,FirstInterceptor的afterCompletion
方法为什么会执行
FirstInterceptor的afterCompletion
方法,是因为FirstInterceptor的preHandle
方法return true所以一定要释放资源而
SecondInterceptor的preHandle
方法return false所以不用释放资源