jsp表单提交到数据库的数据(中文字符)读取后就变成了乱码。

时间:2022-06-01 22:16:49
我是用的getRequest().getParameter("tupian")
得到tupian的数据。然后插入到ms sql数据库中。可是当我用rs.getString("UserName")读取显示时,中文字符全变成了乱码,英文的没事。
应该怎么解决呢?

9 个解决方案

#1


首先在你的bean里加上toChinese方法
===================================================
public static String toChinese(String strvalue)
{
try{
if(strvalue==null)
{
return null;
}
else
{
strvalue = new String(strvalue.getBytes("ISO8859_1"), "GBK");
return strvalue;
}
}
catch(Exception e)
{
return null;
}
}

==================================================
然后在setUsername方法中:
public void setUsername(String c)
{
this.username=类名.toChinese(c);
}

#2


在jsp加上
request.setCharacterEncoding("GB2312");
试试

#3


to:pczhouji(挪威的森林)

我这没用bean啊。

#4


不用bean就直接把那个函数写到JSP页面里

#5


JSP表单里的中文字符串提交后是乱码的,你必须写一个BEAN,把这此中文进行编码转换,或者你在servlet里设置也可以,这么做还方便些,不用每次都进行编码转换

#6


<%! String trans(String chi)
{
               String result = null;
               byte temp [];
               try
               {
                       temp=chi.getBytes("iso-8859-1");
                      result = new String(temp);
                }
                catch(UnsupportedEncodingException e)
                {
                        System.out.println (e.toString());
                }
return result;
}
%>

#7


jsp乱码问题的一些解决方法

一、JSP页面显示乱码 
下面的显示页面(display.jsp)就出现乱码: 
<html> 
<head> 
<title>JSP的中文处理</title> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
</head> 

<body> 
<% 
out.print("JSP的中文处理"); 
%> 
</body> 
</html> 
对不同的WEB服务器和不同的JDK版本,处理结果就不一样。原因:服务器使用的编码方式不同和浏览器对不同的字符显示结果不同而导致的。解决办法:在JSP页面中指定编码方式(gb2312),即在页面的第一行加上:<%@ page contentType="text/html; charset=gb2312"%>,就可以消除乱码了。完整页面如下: 
<%@ page contentType="text/html; charset=gb2312"%> 
<html> 
<head> 
<title>JSP的中文处理</title> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
</head> 

<body> 
<% 
out.print("JSP的中文处理"); 
%> 
</body> 
</html> 

二、表单提交中文时出现乱码 
下面是一个提交页面(submit.jsp),代码如下: 
<html> 
<head> 
<title>JSP的中文处理</title> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
</head> 

<body> 
<form name="form1" method="post" action="process.jsp"> 
<div align="center"> 
<input type="text" name="name"> 
<input type="submit" name="Submit" value="Submit"> 
</div> 
</form> 
</body> 
</html> 
下面是处理页面(process.jsp)代码: 
<%@ page contentType="text/html; charset=gb2312"%> 
<html> 
<head> 
<title>JSP的中文处理</title> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
</head> 

<body> 
<%=request.getParameter("name")%> 
</body> 
</html> 
如果submit.jsp提交英文字符能正确显示,如果提交中文时就会出现乱码。原因:浏览器默认使用UTF-8编码方式来发送请求,而UTF-8和GB2312编码方式表示字符时不一样,这样就出现了不能识别字符。解决办法:通过request.setCharacterEncoding("gb2312")对请求进行统一编码,就实现了中文的正常显示。修改后的process.jsp代码如下: 
<%@ page contentType="text/html; charset=gb2312"%> 
<% 
request.seCharacterEncoding("gb2312"); 
%> 
<html> 
<head> 
<title>JSP的中文处理</title> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
</head> 

<body> 
<%=request.getParameter("name")%> 
</body> 
</html> 

三、数据库连接出现乱码 
只要涉及中文的地方全部是乱码,解决办法:在数据库的数据库URL中加上useUnicode=true&characterEncoding=GBK就OK了。 

四、数据库的显示乱码 
在mysql4.1.0中,varchar类型,text类型就会出现中文乱码,对于varchar类型把它设为binary属性就可以解决中文问题,对于text类型就要用一个编码转换类来处理,实现如下: 
public class Convert { 
/** 把ISO-8859-1码转换成GB2312 
*/ 
public static String ISOtoGB(String iso){ 
String gb; 
try{ 
if(iso.equals("") || iso == null){ 
return ""; 

else{ 
iso = iso.trim(); 
gb = new String(iso.getBytes("ISO-8859-1"),"GB2312"); 
return gb; 


catch(Exception e){ 
System.err.print("编码转换错误:"+e.getMessage()); 
return ""; 



把它编译成class,就可以调用Convert类的静态方法ISOtoGB()来转换编码。

#8


strvalue = new String(strvalue.getBytes("ISO8859_1"), "GBK");

#9


別想得太復雜,用樓上的就行了。

#1


首先在你的bean里加上toChinese方法
===================================================
public static String toChinese(String strvalue)
{
try{
if(strvalue==null)
{
return null;
}
else
{
strvalue = new String(strvalue.getBytes("ISO8859_1"), "GBK");
return strvalue;
}
}
catch(Exception e)
{
return null;
}
}

==================================================
然后在setUsername方法中:
public void setUsername(String c)
{
this.username=类名.toChinese(c);
}

#2


在jsp加上
request.setCharacterEncoding("GB2312");
试试

#3


to:pczhouji(挪威的森林)

我这没用bean啊。

#4


不用bean就直接把那个函数写到JSP页面里

#5


JSP表单里的中文字符串提交后是乱码的,你必须写一个BEAN,把这此中文进行编码转换,或者你在servlet里设置也可以,这么做还方便些,不用每次都进行编码转换

#6


<%! String trans(String chi)
{
               String result = null;
               byte temp [];
               try
               {
                       temp=chi.getBytes("iso-8859-1");
                      result = new String(temp);
                }
                catch(UnsupportedEncodingException e)
                {
                        System.out.println (e.toString());
                }
return result;
}
%>

#7


jsp乱码问题的一些解决方法

一、JSP页面显示乱码 
下面的显示页面(display.jsp)就出现乱码: 
<html> 
<head> 
<title>JSP的中文处理</title> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
</head> 

<body> 
<% 
out.print("JSP的中文处理"); 
%> 
</body> 
</html> 
对不同的WEB服务器和不同的JDK版本,处理结果就不一样。原因:服务器使用的编码方式不同和浏览器对不同的字符显示结果不同而导致的。解决办法:在JSP页面中指定编码方式(gb2312),即在页面的第一行加上:<%@ page contentType="text/html; charset=gb2312"%>,就可以消除乱码了。完整页面如下: 
<%@ page contentType="text/html; charset=gb2312"%> 
<html> 
<head> 
<title>JSP的中文处理</title> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
</head> 

<body> 
<% 
out.print("JSP的中文处理"); 
%> 
</body> 
</html> 

二、表单提交中文时出现乱码 
下面是一个提交页面(submit.jsp),代码如下: 
<html> 
<head> 
<title>JSP的中文处理</title> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
</head> 

<body> 
<form name="form1" method="post" action="process.jsp"> 
<div align="center"> 
<input type="text" name="name"> 
<input type="submit" name="Submit" value="Submit"> 
</div> 
</form> 
</body> 
</html> 
下面是处理页面(process.jsp)代码: 
<%@ page contentType="text/html; charset=gb2312"%> 
<html> 
<head> 
<title>JSP的中文处理</title> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
</head> 

<body> 
<%=request.getParameter("name")%> 
</body> 
</html> 
如果submit.jsp提交英文字符能正确显示,如果提交中文时就会出现乱码。原因:浏览器默认使用UTF-8编码方式来发送请求,而UTF-8和GB2312编码方式表示字符时不一样,这样就出现了不能识别字符。解决办法:通过request.setCharacterEncoding("gb2312")对请求进行统一编码,就实现了中文的正常显示。修改后的process.jsp代码如下: 
<%@ page contentType="text/html; charset=gb2312"%> 
<% 
request.seCharacterEncoding("gb2312"); 
%> 
<html> 
<head> 
<title>JSP的中文处理</title> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
</head> 

<body> 
<%=request.getParameter("name")%> 
</body> 
</html> 

三、数据库连接出现乱码 
只要涉及中文的地方全部是乱码,解决办法:在数据库的数据库URL中加上useUnicode=true&characterEncoding=GBK就OK了。 

四、数据库的显示乱码 
在mysql4.1.0中,varchar类型,text类型就会出现中文乱码,对于varchar类型把它设为binary属性就可以解决中文问题,对于text类型就要用一个编码转换类来处理,实现如下: 
public class Convert { 
/** 把ISO-8859-1码转换成GB2312 
*/ 
public static String ISOtoGB(String iso){ 
String gb; 
try{ 
if(iso.equals("") || iso == null){ 
return ""; 

else{ 
iso = iso.trim(); 
gb = new String(iso.getBytes("ISO-8859-1"),"GB2312"); 
return gb; 


catch(Exception e){ 
System.err.print("编码转换错误:"+e.getMessage()); 
return ""; 



把它编译成class,就可以调用Convert类的静态方法ISOtoGB()来转换编码。

#8


strvalue = new String(strvalue.getBytes("ISO8859_1"), "GBK");

#9


別想得太復雜,用樓上的就行了。