1.
2. 使用的数据库的字符集: iso-8859-1 ,在处理java代码时,对所有的含中文 配置文件其编码都是iso-8859-1 ,
java 代码编译时 -encoding "ISO8859-1" 。这样在使用struts2 时 就出现了乱码,主要是 <s:
property 标签,经过对struts2源码的分析该标签输出时默认对输出内容做了htmlEncode 操作。
解决该问题:
1 将默认的执行 htmlEncode 操作,改为对输出内容不进行htmlEncode操作:
struts2-core-2.0.6 中 :
package org.apache.struts2.components ;
将
Property.java 中的
private boolean escape = true;
改为:
private boolean escape = false;
其次,将prepare 方法改为:
-
private String prepare(String value) {
-
if (escape) {
-
return TextUtils.htmlEncode(value,false);
-
} else {
-
return value;
-
}
-
}
private String prepare(String value) {
if (escape) {
return TextUtils.htmlEncode(value,false);
} else {
return value;
}
}
struts2-core-2.1.6 中:
package org.apache.struts2.components
将
Property.java 中的
private boolean escape = true;
改为:
private boolean escape = false;
其次,将prepare 方法改为:
-
private String prepare(String value) {
-
String result = value;
-
if (escape) {
-
result = TextUtils.htmlEncode(result,false);
-
}
-
if (escapeJavaScript) {
-
result = TextUtils.escapeJavaScript(result);
-
}
-
return result;
-
}
private String prepare(String value) {
String result = value;
if (escape) {
result = TextUtils.htmlEncode(result,false);
}
if (escapeJavaScript) {
result = TextUtils.escapeJavaScript(result);
}
return result;
}
再其次:
package org.apache.struts2.views.jsp;
将 PropertyTag.java 中的
private boolean escape = true;
改为:
private boolean escape = false;
这样就OK了~!
进一步说明: 对于需要使用 htmlEncode 的时候,那么就使用 <s:
property 标签的 escape="true" (防止用户在输入内容时页面出现js注入错误)
但是以上的修改方法还是有一个问题:我们来看看xwork-2.1.2 中的
package com.opensymphony.xwork2.util;
TextUtils.java
-
public final static String htmlEncode(String s) {
-
return htmlEncode(s, true);
-
}
-
-
-
-
-
-
-
-
-
public final static String htmlEncode(String s, boolean encodeSpecialChars) {
-
s = noNull(s);
-
-
StringBuilder str = new StringBuilder();
-
-
for (int j = 0; j < s.length(); j++) {
-
char c = s.charAt(j);
-
-
-
if (c < '\200') {
-
switch (c) {
-
case '"':
-
str.append(""");
-
-
break;
-
-
case '&':
-
str.append("&");
-
-
break;
-
-
case '<':
-
str.append("<");
-
-
break;
-
-
case '>':
-
str.append(">");
-
-
break;
-
-
default:
-
str.append(c);
-
}
-
}
-
-
else if (encodeSpecialChars && (c < '\377')) {
-
String hexChars = "0123456789ABCDEF";
-
int a = c % 16;
-
int b = (c - a) / 16;
-
String hex = "" + hexChars.charAt(b) + hexChars.charAt(a);
-
str.append("&#x" + hex + ";");
-
}
-
-
-
else {
-
str.append(c);
-
}
-
}
-
-
return str.toString();
-
}
public final static String htmlEncode(String s) {
return htmlEncode(s, true);
}
/**
* Escape html entity characters and high characters (eg "curvy" Word quotes).
* Note this method can also be used to encode XML.
* @param s the String to escape.
* @param encodeSpecialChars if true high characters will be encode other wise not.
* @return the escaped string
*/
public final static String htmlEncode(String s, boolean encodeSpecialChars) {
s = noNull(s);
StringBuilder str = new StringBuilder();
for (int j = 0; j < s.length(); j++) {
char c = s.charAt(j);
// encode standard ASCII characters into HTML entities where needed
if (c < '\200') {
switch (c) {
case '"':
str.append(""");
break;
case '&':
str.append("&");
break;
case '<':
str.append("<");
break;
case '>':
str.append(">");
break;
default:
str.append(c);
}
}
// encode 'ugly' characters (ie Word "curvy" quotes etc)
else if (encodeSpecialChars && (c < '\377')) {
String hexChars = "0123456789ABCDEF";
int a = c % 16;
int b = (c - a) / 16;
String hex = "" + hexChars.charAt(b) + hexChars.charAt(a);
str.append("&#x" + hex + ";");
}
//add other characters back in - to handle charactersets
//other than ascii
else {
str.append(c);
}
}
return str.toString();
}
也就是说,我们即使 使用 <s:
property 标签的 escape="true" 任然会有一定问题。这里我们首先复习一下:
ASCII 的表示内容如下:
0 – 31 控制符号
32 空格
33-47 常用符号
48-57 数字
58-64 符号
65-90 大写字母
91-96 符号
97-127 小写字母
ISO8859 如下:
编号 0 – 127 与 ASCII 保持兼容
编号128 – 159 共32个编码保留给扩充定义的 32 个扩充控制码
160 为空格
161 -255 的 95 个数字用于新增加的字符代码
编码的布局与 ASCII 的设计思想如出一辙,由于在一张码表中只能增加 95 种字符的代码,所以 ISO8859 实际上不是一张码表,而是一系列标准,包括 14 个字符码表。
例如,西欧的常用字符就包含在 ISO8859-1字符表中。在 ISO8859-7种则包含了 ASCII 和现代希腊语字符。
现在我想大家一定已经都很明白了,为什么修改后的代码:
-
else if (encodeSpecialChars && (c < '\377')) {
-
String hexChars = "0123456789ABCDEF";
-
int a = c % 16;
-
int b = (c - a) / 16;
-
String hex = "" + hexChars.charAt(b) + hexChars.charAt(a);
-
str.append("&#x" + hex + ";");
-
}
else if (encodeSpecialChars && (c < '\377')) {
String hexChars = "0123456789ABCDEF";
int a = c % 16;
int b = (c - a) / 16;
String hex = "" + hexChars.charAt(b) + hexChars.charAt(a);
str.append("&#x" + hex + ";");
}
才能将中文显示正确。
但是同时也是有隐患的,所以也就让我有了别的想法:
干脆先进行转码好了
struts2-core-2.0.6 中 :
package org.apache.struts2.components ;
将
Property.java 中的
-
private String prepare(String value) {
-
if (escape) {
-
return TextUtils.htmlEncode(new String(value.getBytes("iso-8859-1"),"gbk"));
-
} else {
-
return value;
-
}
-
}
private String prepare(String value) {
if (escape) {
return TextUtils.htmlEncode(new String(value.getBytes("iso-8859-1"),"gbk"));
} else {
return value;
}
}
注:进行该修改 可不对
package org.apache.struts2.components
Property.java 中的
private boolean escape = true;
进行修改,让其默认进行 htmlEncode
struts2-core-2.1.6 中:
package org.apache.struts2.components
将
Property.java 中的
-
private String prepare(String value) {
-
String result = value;
-
if (escape) {
-
result = TextUtils.htmlEncode(new String(result.getBytes("iso-8859-1"),"gbk"));
-
}
-
if (escapeJavaScript) {
-
result = TextUtils.escapeJavaScript(result);
-
}
-
return result;
-
}
private String prepare(String value) {
String result = value;
if (escape) {
result = TextUtils.htmlEncode(new String(result.getBytes("iso-8859-1"),"gbk"));
}
if (escapeJavaScript) {
result = TextUtils.escapeJavaScript(result);
}
return result;
}
注:进行该修改 可不对:
package org.apache.struts2.components
Property.java 中的
private boolean escape = true;
和
package org.apache.struts2.views.jsp;
PropertyTag.java 中的
private boolean escape = true;
进行修改,让其默认进行 htmlEncode 操作,便可以显示正确的中文。
其他相关包说明:
xwork-2.0.1.jar
struts2-core-2.0.6.jar
struts2-spring-plugin-2.0.6.jar
struts2-tiles-plugin-2.0.6.jar
xwork-2.1.2.jar
struts2-core-2.1.6.jar
struts2-spring-plugin-2.1.6.jar
struts2-tiles-plugin-2.1.6.jar
相关推荐
在Struts2的各个版本和不同过滤器设置下,GET方式提交的中文乱码问题仍然存在。一种可行的解决方案是在Tomcat服务器的配置文件`server.xml`中,修改`<Connector>`标签,添加`URIEncoding="UTF-8"`属性。这将强制...
通过这些配置,大部分Struts中文乱码问题都能得到解决。但有时,问题可能源自于其他因素,比如静态资源(如CSS、JavaScript文件)的编码设置,或者是第三方库的编码处理不当。因此,排查问题时需全方位考虑,确保每...
### Struts2中文乱码问题解决方案 在使用Struts2框架进行Web开发的过程中,中文乱码问题是一个常见的问题。这不仅影响用户体验,还可能导致数据处理错误。本文将详细介绍几种解决Struts2中文乱码问题的方法。 ####...
struts处理中文乱码问题总结struts处理中文乱码问题总结struts处理中文乱码问题总结struts处理中文乱码问题总结
在开发Web应用程序时,中文乱码问题是一个常见的挑战,特别是在使用Struts框架的时候。这个问题的出现通常是由于客户端和服务器端的字符集不一致导致的。本文将深入探讨如何解决Struts框架下的中文乱码问题。 首先...
### Struts2中文乱码问题解决方案 在使用Struts2框架进行Web开发的过程中,中文乱码问题是一个常见的挑战。这不仅影响用户体验,还可能导致数据不一致等问题。为了解决这一问题,我们需要理解其背后的原理,并采取...
### Struts2中文乱码问题解析与解决方案 #### 一、引言 在Web开发过程中,尤其是使用Struts2框架时,中文字符的正确显示是一个常见的挑战。本篇文章将详细介绍Struts2中出现中文乱码的原因及解决方案,帮助开发者更...
本DEMO是为了解决Struts2在处理中文输入时可能出现的乱码问题,确保系统能够正确地接收和显示中文字符。 首先,我们要理解乱码产生的原因。在Web应用中,数据的传输通常涉及多种编码方式,如HTTP请求的默认编码通常...
Struts是一个非常流行的Java Web应用程序框架,用于构建和管理MVC(模型-视图-控制...如果你的项目中仍然存在乱码问题,建议参考提供的“Struts中文乱码解决方案.doc”文档,它可能包含了更详细的排查步骤和解决方案。
在Struts框架中,汉字乱码问题是一个常见的问题,特别是在处理中文输入时。解决这个问题涉及到多个层面,包括页面编码设置、服务器配置以及Struts的Servlet配置。以下是对这些问题的详细解释: 1. 页面编码设置: ...
总结来说,解决Eclipse Struts中文乱码问题主要涉及页面编码设置、请求参数处理以及资源文件的正确编码。通过调整相应的配置和使用合适的工具,可以有效避免和解决这些问题,确保中文字符的正常显示和处理。
本文将深入探讨一个关于Struts2在Internet Explorer(IE)浏览器中出现中文乱码的奇怪问题及其解决方案。 首先,中文乱码问题通常涉及到几个关键因素:数据库编码、开发文件编码和网页的Content-Type编码。在确保这...
在IT领域,特别是Web开发中,Struts框架作为Java Web应用的一个重要组成部分,其在处理中文字符时常常遇到乱码问题。这个问题不仅影响了用户体验,也增加了开发者的调试难度。本文将深入探讨Struts框架中中文乱码的...
通过以上步骤,一般可以解决Struts 2.5.2框架下的中文乱码问题。但请注意,每个项目可能有不同的配置和需求,因此在实际应用中,还需要根据具体情况进行调试和调整。 在`myStruts`这个压缩包中,可能包含了示例代码...
在开发基于Struts2框架的应用时,经常遇到的一个问题就是中文乱码。这不仅影响用户体验,还可能导致数据处理错误。本文将详细介绍如何彻底解决Struts2中的乱码问题,并提供实际可行的解决方案。 #### 二、乱码产生...
Struts2 Action 处理中文乱码问题是一个常见的挑战,尤其是在进行Web开发时,由于编码格式不统一,可能导致输入或显示的中文字符出现乱码。以下是对两种解决方法的详细解释: 方法一:通过配置Struts2的i18n编码 ...
在Web开发中,使用Struts2框架进行文件下载操作时,经常遇到的一个问题是文件名中的中文字符显示为乱码。这主要是因为浏览器和服务器之间的编码不一致所导致的。为了确保用户能够正确地看到文件名中的中文字符,需要...