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

35 篇文章 1 订阅
34 篇文章 0 订阅

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

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");

来获得新字符串再加入数据库就解决了乱码问题

8.SpringMVC处理中文乱码问题

修改web.xml:

加入:

<filter>  
        <filter-name>characterEncodingFilter</filter-name>  
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>  
        <init-param>  
            <param-name>encoding</param-name>  
            <param-value>UTF-8</param-value>  
        </init-param>  
        <init-param>  
            <param-name>forceEncoding</param-name>  
            <param-value>true</param-value>  
        </init-param>  
    </filter>  
    <filter-mapping>  
        <filter-name>characterEncodingFilter</filter-name>  
        <url-pattern>/*</url-pattern>  
    </filter-mapping>  

有关java web响应慢的问题:

我的原因是数据库连接池过多,SqlSession没有及时释放

就是openSession启动的SqlSession太多了没有释放,导致数据库连接池慢了

解决办法:

所有增删查改语句用同一个静态的SqlSession

ps:

网上查到的响应慢的原因有:

(1)数据库的选择不同,操作速度有所不同,比如mysql就比oracle慢多了

(2)日志记录过多容易造成响应慢

(3)对数据库进行操作的代码效率低,容器像list的扩容费时问题

(4)页面富集了大量数据,应该是要用ajax之类的异步更新解决吧

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值