解决JSP在MySQL数据库中进行插入出现乱码的问题

在我一个项目中,当我使用下列语句

 

 

String typeid = request.getParameter(

"typeid");

String content = 

request.getParameter("content");

 

String sqlQuery =

"insert into smscontent(typeid, content) values('";

sqlQuery += typeid;

sqlQuery +=

"', /"";

sqlQuery += content;

sqlQuery +=

"/")";

 

进行数据插入时,发现在数据库中的汉字都变成了乱码(发送请求的Url为:http://localhost:8080/MySMS/SubmitSMS.jsp?typeid=2&content=%E6%B5%B7%E5%A4%A7%E5%B8%88),一看原来是自己没有对URL进行解码,所以,使用下面代码进行解码:

 

String content =

new String(request.getParameter("content").getBytes("ISO-8859-1"),"utf-8");

 

可是尽管这样,写入到数据库的数据还是乱码!问题出在数据库连接时没有指定编码!

 

因此将数据库连接代码:

 

 

sqlConn = java.sql.DriverManager.getConnection(

"jdbc:mysql://" + host+ "/"+ database, user,pass);

 

替换为:

 

sqlConn = java.sql.DriverManager.getConnection(

"jdbc:mysql://" + host+ "/"+ database + "?useUnicode=true&characterEncoding=utf-8",user,pass);

 

数据插入成功!

 

另外需要指出的是,我在数据库中指定的编码是utf-8,所以这里连接时也是使用characterEncoding=utf-8。这里需要针对不同的编码选用对应的类型!

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值