目录
1.什么是国际化
简称i18n,是一种让软件在开发阶段就支持多种语言的技术
2.java.util.Locale解释
语言代码_国家代码
注:国家代码可省略
zh_CN
3.ResourceBundle加载资源文件(中英双语)
i18n_zh_CN.properties
i18n_en_US.properties
//test是属性文件的名字,不写语言代码、国家代码,后缀名properties
String path = "i18n";
ResourceBundle bundle = ResourceBundle.getBundle(path, Locale.CHINA);
String yhzhLabel = bundle.getString("yhzh.label");
<!--注1:需修改pom.xml将国际化资源文件输出到target文件夹-->
<resource>
<directory>src/main/resources</directory>
<includes>
<!--<include>jdbc.properties</include>-->
<include>*.properties</include>
<include>*.xml</include>
</includes>
</resource>
4.复合消息
message=hello {0}, my name is {1}
java.text.MessageFormat.format(message, "zs", "ls");
String message = bundle.getString("message");
5.SpringMvc实现动态国际化(中英双语)
5.1 提供中英双语资源文件
例如:
i18n_en_US.properties
i18n_zh_CN.properties
5.2 通过ResourceBundleMessageSource加载资源文件(basenames属性)
<!--1) 配置国际化资源文件 -->
<bean id="messageSource" class="org.springframework.context.support.ResourceBundleMessageSource">
<property name="basenames">
<list>
<value>i18n</value>
</list>
</property>
</bean>
注1:必须叫messageSource、必须叫messageSource、必须叫messageSource
注2:可在开发阶段使用ReloadableResourceBundleMessageSource它能自动重新加载资源文件
5.3 指定springmvc的语言区域解析器,由它来确定使用哪个语言
5.3.1 配置语言区域解析器
<!--2) 指定语言区域解析器,由它来确定使用哪个语言 -->
<bean id="localeResolver" class="org.springframework.web.servlet.i18n.SessionLocaleResolver"></bean>
注1:必须叫localeResolver、必须叫localeResolver、必须叫localeResolver
5.3.2 语言解析器的类型
AcceptHeaderLocaleResolver/SessionLocleResolver/CookieLocaleResolver
各解析器的相关说明
AcceptHeaderLocaleResolver(基于操作系统)
Spring采用的默认区域解析器是AcceptHeaderLocaleResolver。它通过检验HTTP请求的accept-language头部来解析区域。
这个头部是由用户的web浏览器根据底层操作系统的区域设置进行设定。请注意,这个区域解析器无法改变用户的区域,
因为它无法修改用户操作系统的区域设置
SessionLocaleResolver(基于会话)
它通过检验用户会话中预置的属性来解析区域。如果该会话属性不存在,它会根据accept-language HTTP头部确定默认区域
CookieLocaleResolver(基于Cookie)
这个区域解析器所采用的Cookie可以通过cookieName和cookieMaxAge属性进行定制。
defaultLocale:默认的语言区域
cookieName:设置cookieName名称
cookieMaxAge:设置cookieName有效时间,单位秒
cookiePath:设置cookie可见的地址,默认是“/”即对网站所有地址都是可见的,如果设为其它地址,则只有该地址或其后的地址才可见
5.4 配置国际化操作拦截器,如果采用基于(Session/Cookie)则必需配置
<!--3) 配置国际化操作拦截器-->
<mvc:interceptors>
<bean class="org.springframework.web.servlet.i18n.LocaleChangeInterceptor" />
</mvc:interceptors>
5.5 通过标签输出内容,而非直接输出内容
5.5 springmvc的message标签输出
<%@ taglib prefix="t" uri="http://www.springframework.org/tags" %>
<t:message code="title"/>
注1:为什么在index.jsp使用
<t:message code="user_name"/>
会报错
原因是在web.xml中配置的DispatcherServlet的url-pattern为“/”,不会匹配访问.jsp的url,
所以直接访问首页并不会经过DispatcherServlet,导致无法读取到资源文件
解决方案:首页转发到/WEB-INF/jsp/login.jsp即可
注2:切换语言的关键代码(系统必须使用SessionLocaleResolver解析器)
session.setAttribute(SessionLocaleResolver.LOCALE_SESSION_ATTRIBUTE_NAME,Locale.CHINA)
5.6 后台代码获取国际化信息
5.6.2 后台通过springmvc的消息机制显示消息
5.6.2 通过RequestContext获得国际化的消息
RequestContext requestContext = new RequestContext(request);
String errorMsg = requestContext.getMessage("login.error.label");
System.out.println("errorMsg:" + errorMsg);
6.SpringMvc的文件上传
struts文件上传
1、二进制存在数据库
2、存储到具体的硬盘目录
3、存储到服务器中
真实路径与虚拟路径
通过虚拟路径获取真实路径
request.getservletContext.getrealPath(虚拟路径);
fileutil.copyInputStreamtofile(file.getInput);
fileutil.copyofile(file,new file(真是路径))
6.1 添加文件上传相关依赖
<dependency>
<groupId>commons-fileupload</groupId>
<artifactId>commons-fileupload</artifactId>
<version>1.3.3</version>
</dependency>
6.2 配置文件上传解析器(CommonsMultipartResolver)
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<!-- 必须和用户JSP 的pageEncoding属性一致,以便正确解析表单的内容 -->
<property name="defaultEncoding" value="UTF-8"></property>
<!-- 文件最大大小(字节) 1024*1024*50=50M-->
<property name="maxUploadSize" value="52428800"></property>
<!--resolveLazily属性启用是为了推迟文件解析,以便捕获文件大小异常-->
<property name="resolveLazily" value="true"/>
</bean>
6.3 表单提交方式为method=“post” enctype=“multipart/form-data”
6.4 文件项用spring提供的MultipartFile进行接收
6.5 IO流读写文件
6.6 保存文件上传记录
注:springmvc文件上传关键代码
File targetFile = ....;
MultipartFile mf = ....;
String fileName = mf.getOriginalFilename();
mf.transferTo(targetFile);