向数据库插入中文时出现乱码
来源:互联网 发布:淘宝美工培训机构 编辑:程序博客网 时间:2024/05/15 13:45
在做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数据库插入汉字出现乱码问题
- 广度优先搜索和深度优先搜索
- 第二章 15
- 有效获取状态栏(StatusBar)高度
- 分布式文件系统:原理、问题与方法
- Linux C/C++ 区别:类型声明、struct
- 向数据库插入中文时出现乱码
- 欢迎使用CSDN-markdown编辑器
- oracle登录错误(ORA-01033:ORACLE initialization or shutdown in progress
- servlet的机制
- OSPF-LSA系列—LSA TYPE 3
- 程序猿的健康之路
- 黑马程序员_学习笔记集合框架(I)
- JSON数据转换
- equals和==的区别