之前一直用IDEA(俗称的“神器”)来做项目开发,进入公司之后项目组开发环境都是用myeclipse于是也就切换到了myeclipse为主的开发环境。但是昨天重新部署配置了Struts2的一个简单实例,发现登录页面有中文乱码的情况,后来经过进一步的定位其实这是Struts2使用的属性文件没有被编译所导致,具体也就是项目当中的messages_zh_CN.properties 这个文件的编译。
现在回想下,IDEA对属性文件的编辑器和编译插件同myeclipse的编辑器和编译插件不同,我没有注意这其中的差别,尤其是myeclipse的这个编辑方式,所以导致编译的问题。现在把之前错误的几个主要截图给截取出来:
基本背景其实很简单,是一个struts2的入门项目,在登录页面上使用了struts2的标签具体是s标签,具体的JSP页面源码如下
<%@ taglib prefix="s" uri="/struts-tags" %>
<%--
Created by IntelliJ IDEA.
Date: 2012-8-2
Time: 2:47:14
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ page pageEncoding="UTF-8" %>
<html>
<head><title>Simple jsp page</title>
<s:head/>
</head>
<body>
<s:form action="login" validate="true">
<s:textfield name="username" key="username"/>
<s:password name="password" key="password" />
<s:submit key="submit"/>
</s:form>
</body>
</html>
这里面涉及到国际化,具体key=username和key=password会具体到本项目的messages_zh_CN.properties去寻找值来填充,其实从现在看是到本项目编译过的messages_zh_CN.properties去寻找值。
接下来说最开始错误的处理办法。首先是属性文件的编辑,我直接使用myeclipse的源码视图编辑(这个其实是错误根源,待会再说正确办法)
然后我也确保这个文件采用的是UTF-8的编码保持方式
但是这样配置之后,struts2的前台页面依然是有乱码的状况,其实不用截图JSP页面,在开发环境下即可截图发现这样弄实在不行,如下图
切换到source另外的properties视图可以看到上面的录入汉语并没有被识别,显示问号,在当时处理的时候没有注意。
真正正确的办法应该是在myeclipse里面的properties视图 来编辑和插入属性键值对,然后保存,这样myeclipse里面的这个插件会自动编译属性文件,具体截图如下
这时候切换到Source的视图就可以看到属性文件被编译为UTF-8的编码
经过这样处理,属性文件就可以正常使用,username被找到“用户名”,password被找到“密码”,最后登录页面login.jsp的截图如下: