Java Web开发过程中的中文编码问题和响应慢解决方法

今天打算动手写一个要读取中文字符到数据库的网站,本以为会很顺利,结果就中文的读取问题居然折磨了我一天,查了很多博客,尝试了很多次,刚刚才总算是解决了中文的编码问题,网站和数据库才可以正确读取显示中文字符,注意编码一致指的是所有流程内的编码一致。。少了一个都可能导致编码不正确

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&amp;characterEncoding=UTF-8"/>

也就是在url的尾部加上useUnicode=true&amp;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之类的异步更新解决吧

猜你喜欢

转载自blog.csdn.net/qq_37497322/article/details/80034487