中文乱码、jsp操作数据库中文乱码!帮你解决!!!

本文详细介绍了在Java环境中处理中文乱码的方法,包括在网页输出、从参数读取、数据库操作以及JSP页面中的中文问题解决技巧。

                                    中文乱码、jsp操作数据库中文乱码!

 

      在基于Java的编程中,经常会碰到汉字的处里及显示的问题,比如一大堆乱码或问号。

  这是因为JAVA中默认的编码方式是UNICODE,而中国人通常使用的文件和DB都是基于GB2312或者BIG5等编码,故会出现此问题。以前我也经常为这个问题而苦恼,后来经查了些资料,终于解决了,我知道一定有很多朋友也会碰到这个问题,所以特就总结了一下,来拿出来让大家一起分享了。

 

1、在网页中输出中文。

  JAVA在网络传输中使用的编码是"ISO-8859-1",故在输出时需要进行转化,如:

  String str="中文";

  str=new String(str.getBytes("GB2312"),"8859_1");

  但假如在编译程序时,使用的编码是“GB2312”,且在中文平台上运行此程序,不会出现此问题,一定要注重。

2、从参数中读取中文

  这正好与在网页中输出相反如:

  str=new String(str.getBytes("8859_1"),"GB2312");

3、操作DB中的中文问题

  一个较简单的方法是:在“控制面扳”中,把“区域”设置为“英语(美国)”。假如还会出现乱码,还可进行如下设置:

  取中文时:str=new String(str.getBytes("GB2312"));

  向DB中输入中文:str=new String(str.getBytes("ISO-8859-1"));

4、在jsp中的中文解决:

  在“控制面扳”中,把“区域”设置为“英语(美国)”.

  在JSP页面中加入:

  假如还不行正常显示,则还要进行下面的转换:

  如:name=new String(name.getBytes("ISO-8859-1"),"GBK");

  就不会出现中文问题了。

 

5.消除纯HTML页和JSP页在Tomcat环境下运行的乱码

这个是由于流览器无法选择编码方式造成的,   手动从IE中选择“GB2312”即可解决;也可以网页中加入META标记或Page指令;
META标记如下:
<meta   http-equiv= "Content-Type "   content= "text/html;   ch***t=GB2312 ">
Page指令如下:
<%@   page   language= "java "   contentType= "text/html;   ch***t=GB2312 "   pageEncoding= "GB2312 "%>

 

JSP获取页面参数时一般采用系统默认的编码方式,如果页面参数的编码类型和系统默认的编码类型不一致,很可能就会出现乱码。解决这类乱码问题的基本方法是在页面获取参数之前,强制指定request获取参数的编码方式:request.setCharacterEncoding("GBK")或request.setCharacterEncoding("gb2312")。

如果在JSP将变量输出到页面时出现了乱码,可以通过设置response.setContentType("text/html;charset=GBK")或response.setContentType("text/html;charset=gb2312")解决。

 

 

6.一般jdbc驱动连接时要注意:
String   url   = "jdbc:mysql://localhost/BookStore?useUnicode=true&characterEncoding=gb2312 ";
conn=DriverManager.getConnection(url, "root ", " ");

一般情况下用   String   url   = "jdbc:mysql://localhost/BookStore "应该就能正常显示中文。
总结:修改MySQL   Server数据库默认字符集为“GB2312”,从MySQL读出中文可正常显示;

package Dao; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import java.util.ArrayList; import com.mysql.jdbc.Connection; import javaBean.Student; import test.DBUtil; public class AddStudentDao { public int addStudent(String sid,String sname,String sage){ int rs=0; Connection con = (Connection) DBUtil.getCon(); String sql="insert into student values(?,?,?)"; try{ PreparedStatement ps = con.prepareStatement(sql); ps.setString(1, sid); ps.setString(2, sname); int sage1 = Integer.parseInt(sage); ps.setInt(3, sage1); rs = ps.executeUpdate(); }catch (SQLException e){ e.printStackTrace(); } return rs; } } package servlet; import java.io.IOException; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import Dao.AddStudentDao; public class AddStudentServlet extends HttpServlet{ @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { //解决中文乱码问题 req.setCharacterEncoding("utf-8"); resp.setContentType("text/html;charset=utf-8"); //获取前台页面数据 String sid = req.getParameter("sid"); String sname = req.getParameter("sname"); String sage = req.getParameter("sage"); //调用dao的插入学生的方法 AddStudentDao asd = new AddStudentDao(); int rs = asd.addStudent(sid, sname, sage); if(rs!=0){ System.out.println("插入成功"); req.getRequestDispatcher("slist").forward(req, resp); }else{ System.out.println("插入失败"); } } }其中rs与asd分别是什么,在这里我该怎样理解是正确的
最新发布
11-14
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值