向数据库插入中文时出现乱码
来源:互联网 发布:人工智能修道士与野人 编辑:程序博客网 时间:2024/05/16 05:33
版权声明:本文为博主原创文章,未经博主允许不得转载。
在做web开发时(本人用JSP做开发,数据库用的MySQL,其他开发方式可能稍有不同,但原理是一样的),向数据库中插入中文时出现乱码现象。这个现象跟很多环节有关系,但最根本的是要选择一种支持中文的编码,且各个地方的编码都要保持一致。这些地方主要包括数据库的编码,JSP页面代码请求的编码,数据库连接时的编码。具体如下:
1、创建数据库的时候要选好一种支持中文的编码,可以选GBK、GB2312、UTF-8,选好后其他地方的编码都尽量与这里的一样,这里就以UTF-8为例说明。
2、在进行JSP页面代码区,将页面中凡是涉及到编码的地方都设置成与上述数据库同一编码。为了避免不同浏览器支持不同编码的问题,可以在每个页面的开始处(可以放在<head>标签前面)都加一条设置请求代码的编码,具体如下:
<%
request.setCharacterEncoding("utf-8");
%>
这样就能保证对发送的请求按照设置好的编码传过来,这解决了页面直接传递中文时出现乱码的问题,以下则解决插入数据库时乱码的问题。
3、当页面的编码和数据库的编码都相同的时候,就能保证中文数据传过来是正确的,但要保证插入时也正确,还要设置连接数据库时的编码。具体语句如下(连接的是MySQL数据库):
public class DB {
public static Connection getConnection(){
String user = "root"; //连接数据库时的用户名
String password = "root"; //连接数据库时的密码
String url = "jdbc:mysql://localhost:3306/db_name?useUnicode=true&characterEncoding=utf-8"; //加上这部分有关编码设置的代码
String driver = "com.mysql.jdbc.Driver";
Connection con = null;
try {
Class.forName(driver);
con = DriverManager.getConnection(url, user, password);
} catch (Exception e) {
e.printStackTrace();
}
return con;
}
}
以上为连接数据库的DB类,以上红色字体部分为设置相应的连接编码。
总结:进行web开发的时候,如果要避免中文乱码的问题,则尽量将各个环节的编码统一或者是可兼容,这样才能保证不出现乱码。
- 向数据库插入中文时出现乱码
- 向数据库插入中文时出现乱码
- 向MySQL数据库插入中文时乱码
- 向数据库插入中文乱码
- java向MySQL数据库插入记录时出现中文乱码问题
- 241,使用mybatis向mysql插入中文时,出现乱码
- java向mysql数据库插入中文时乱码
- hibernate向mysql数据库插入中文乱码
- jsp向数据库中插入中文乱码
- python向数据库插入中文乱码问题
- java中利用JDBC向MySql数据库中插入中文出现乱码解决办法
- hibernate插入数据库出现中文乱码问题
- 使用Hibernate向Mysql中插入中文数据出现乱码
- 解决Hibernate向MySQL插入中文出现乱码的问题
- 解决:Hibernate 向Mysql插入中文数据乱码,出现???
- 向数据库插入数据时出现乱码 --设置连接数据库的编码
- php向数据库插入数据出现乱码问题
- python向mysql数据库插入汉字出现乱码问题
- jQuery 遍历
- 1018
- centos 7 pip install tensorflow
- linux virtualbox虚拟机 设备》usb》找不到usb设备
- 【解决方案】extjs 怎么取消 gridPanel 表头上的图标(下拉排序)
- 向数据库插入中文时出现乱码
- 博客开通之1024纪念篇
- 1019
- 自定义控件(详解_待完善)
- 【mysql】mysql基础操作
- 邮件服务器运作原理
- 欧拉函数的求法(线性筛法?)
- Career Advice From an Oldish Not-Quite Geezer
- 使用Linux的lsblk命令列出块设备信息