当前位置: 移动技术网 > IT编程>开发语言>Java > 解决javaWEB中前后台中文乱码问题的3种方法

解决javaWEB中前后台中文乱码问题的3种方法

2019年07月22日  | 移动技术网IT编程  | 我要评论

兖州天气预报,弗洛泽,玛尔西亚·爱子

中文乱码问题真的是一个很棘手的问题,特别是从前台传到后台之后,都不知道问题出在哪里了。现在分享解决javaweb中前后台中文乱码问题的3种方法。
方法一:
tomcat的自带编码是iso-8859-1的格式,是不兼容中文的编码的。所以我们从后台接收的时候要注意。
采用相同的格式去接收(iso-8859-1),然后用能解析的编码(utf-8)去转换。这样我们就能得到能兼容中文的格式了。这样处理之后发往前台。注意:发往前台的时候也需要设置一下
resp.setcontenttype("text/html;charset=utf-8");//设置页面的字符编码,解决界面显示中文乱码的问题

protected void service(httpservletrequest req, httpservletresponse resp) 
   throws servletexception, ioexception { 
  //因为tomcat自带编码是iso-8859-1格式 

//解决乱码方法之一 
<span style="white-space:pre">  </span>string name=req.getparameter("username"); 
<span style="white-space:pre">  </span>string pwd=req.getparameter("pwd"); 
<span style="white-space:pre">  </span>byte[] b=name.getbytes("iso-8859-1");//用tomcat的格式(iso-8859-1)方式去读。 
<span style="white-space:pre">  </span>string str=new string(b,"utf-8");//采用utf-8去接string 
<span style="white-space:pre">  </span>resp.setcontenttype("text/html;charset=utf-8");//设置页面的字符编码<span style="white-space:pre"> </span> 
<span style="white-space:pre">  </span>printwriter pw =resp.getwriter(); 
<span style="white-space:pre">  </span>string str1="<html><body><font size='5px' color='red'>username:"+name+"pwd:"+pwd+"</font></body></html>"; 
<span style="white-space:pre">  </span>pw.print(str1); 
  printwriter pw =resp.getwriter(); 
  string str1="<html><body><font size='5px' color='red'>username:"+name+"pwd:"+pwd+"</font></body></html>"; 
  pw.print(str1); 

方法二:
由于方法一比较繁琐,采用用了简单的设置。只需要简单的一句就可以搞定
req.setcharacterencoding("utf-8");//必须写在第一位,因为采用这种方式去读取数据,否则数据会出错。 
这样就不用像之前的那样繁琐的设置了

protected void service(httpservletrequest req, httpservletresponse resp) 
   throws servletexception, ioexception { 
  //因为tomcat自带编码是iso-8859-1格式 
  
 //解决乱码二《法一比较繁琐》 
  req.setcharacterencoding("utf-8");//必须写在第一位,因为采用这种方式去读取数据,否 
 
则数据会出错。 
//设置这样方式去读。这样中文就能够读取出来了,但是需要注意。表单的发送方式必须是<span style="color:#ff0000;"> method='post'</span> 
  resp.setcontenttype("text/html;charset=utf-8");//设置传过去的页面显示的编码 
  string name=req.getparameter("username"); 
  string pwd=req.getparameter("pwd"); 
  printwriter pw =resp.getwriter(); 
  string str1="<html><body><font size='5px' color='red'>username:"+name+"pwd:"+pwd+"</font></body></html>"; 
  pw.print(str1); 

方法三:

这是在法二的基础上修改的。虽然我们能修改编码格式去读,但是考虑到用户肯定不会修改,所以我们需要采用比较通用的办法,让用户修改配置文件。也就是web.xml文件
需要修改web.xml里面的内容,就是说,字符编码从xml接收过来。需要在xml文件中配置参数。
代码如下:

<servlet> 
 <servlet-name>encodeing</servlet-name> 
 <servlet-class>cn.hncu.com.encode.encodeing</servlet-class> 
 <init-param> 
 <param-name>charset</param-name> 
 <param-value>utf-8</param-value>//这里面的内容可供用户自己填写(必须是编码格式) 
 </init-param> 
 </servlet> 

我们知道前台和后台进行交换必须经过web.xml配置
我们需要获取web.xml的设置的参数

public void init(servletconfig config) throws servletexception { 
  charset=config.getinitparameter("charset");//获得初始化参数。当然charset需要设置为全局变量。后面的service函数需要设置req.setcharacterencoding(charset); 
 } 
req.setcharacterencoding(charset); 
  resp.setcontenttype("text/html;charset=utf-8"); 
  string name=req.getparameter("username"); 
  string pwd=req.getparameter("pwd"); 
   
  printwriter pw =resp.getwriter(); 
  string str1="<html><body><font size='5px' color='red'>username:"+name+"pwd:"+pwd+"</font></body></html>"; 
  pw.print(str1); 

解决的效果图:

解决之前:

解决之后:

前台代码:

<body> 
 <form action="login" method="post">//login在web.xml中配置,就能实现到后台去读取数据 
 用户名:<input type="text" name="username"/><br/> 
 密码:<input type="password" name="pwd"/><br/> 
 <input type="submit" value="登录"/> 
 </form> 
 </body> 

以上就是为大家分享的解决javaweb中前后台中文乱码问题的3种方法,特别是从前台传到后台之后产生的中文乱码问题,希望对大家的学习有所帮助。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网