今天打算动手写一个要读取中文字符到数据库的网站,本以为会很顺利,结果就中文的读取问题居然折磨了我一天,查了很多博客,尝试了很多次,刚刚才总算是解决了中文的编码问题,网站和数据库才可以正确读取显示中文字符,注意编码一致指的是所有流程内的编码一致。。少了一个都可能导致编码不正确
ps:我使用的是linux内核的deepin系统,也就是linux下的解决办法,windows也大同小异。
1.数据库的编码问题:
mysql默认的设置是不支持插入中文字符的
可以在mysql客户端中
输入:status查看当前的编码状态
支持中文的状态应该是这样的:
输入:
show variables like '%char%'; 可以查看字符集状态:
解决办法:
ctrl+alt+T打开终端
cd /etc/mysql/来到mysql的配置目录
sudo vim my.cnf来修改这个配置文件
然后按i表示插入
在尾部添加这些字段:
[mysqld]
default-storage-engine=INNODB
character-set-server=utf8
collation-server=utf8_general_ci
[mysql]
default-character-set=utf8
[client]
default-character-set=utf8
然后在终端输入:
service mysql restart重启后再进就行了
2.jsp页面的编码问题:
解决方法:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
3.html内的编码问题:
解决办法:
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
</head>
4.servlet中的编码问题:
要处理request和response
解决办法:
在doGet和doPost方法最前面加上
req.setCharacterEncoding("UTF-8");
resp.setContentType("text/html; charset=UTF-8");5.mybatis或者jdbc的url中数据连接池设置的编码问题:
解决办法:
<property name="url" value="jdbc:mysql://localhost:3306/users?useUnicode=true&characterEncoding=UTF-8"/>
也就是在url的尾部加上useUnicode=true&characterEncoding=UTF-8"
6.idea中编码方式设置:
解决办法:
file->setting->Editor->File Encodings有三个编码选项全选UTF-8
7.浏览器上传数据默认编码与数据库编码不一致
浏览器默认编码为ISO-8859-1,这时需要对传过来的表单的数值进行编码处理
解决方法:
new String(OldString.getBytes("ISO-8859-1"),"UTF-8");
来获得新字符串再加入数据库就解决了乱码问题
有关java web响应慢的问题:
我的原因是数据库连接池过多,SqlSession没有及时释放
就是openSession启动的SqlSession太多了没有释放,导致数据库连接池慢了
解决办法:
所有增删查改语句用同一个静态的SqlSession
ps:
网上查到的响应慢的原因有:
(1)数据库的选择不同,操作速度有所不同,比如mysql就比oracle慢多了
(2)日志记录过多容易造成响应慢
(3)对数据库进行操作的代码效率低,容器像list的扩容费时问题
(4)页面富集了大量数据,应该是要用ajax之类的异步更新解决吧