• 表单数据提交后的中文乱码解决方案


    在web项目运行时,通常会遇到中文乱码问题。那么对于表单提交后数据是乱码的问题有以下几点需注意:

    1、过滤器 的配置在web.xml中

    <!-- post乱码过虑器 -->
        <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>
        </filter>
        <filter-mapping>
            <filter-name>CharacterEncodingFilter</filter-name>
            <url-pattern>/*</url-pattern>
        </filter-mapping>

    2、数据库连接配置:

    connection.url=jdbc:mysql://localhost:3306/test?characterEncoding=UTF-8

    3、jsp或html页面的编码 charset="UTF-8"

    4、数据库、表以及表中的相应字段统一设置成

    5、tomcat 中server.xml中在connector加上 URIEncoding="UTF-8"即可。

    原因:

    ​在页面上提交数据到服务器有两种方式“GET”和“POST”,当使用“GET”时,传输的数据是直接拼接在URL后面的。当数据中含有对HTML来说不安全的字符例如中文时,就会被编码,一般采用的是UTF-8编码。这时URL已经被转义成相对安全的字符串。此时再经过ios-8859-1的编码方式转换成二进制的形式跟随请求头一起发送到服务器端。 ​到达服务器端时,服务器也对数据进行两次解码,服务器先把数据经过ios-8859-1解码,然后根据服务器默认的编码进行第二次解码。在tomcat中,默认的编码是ios-8859-1,所以第二次解码用的是ios-8859-1而不是UTF-8,到此,服务器端收到的数据就是乱码了。  ​解决的方法是修改tomcat的默认编码为UTF-8。

     

     

    对照以上五点乱码就能解决了!

  • 相关阅读:
    css盒模型不同浏览器下解释不同 解决办法
    【META http-equiv="Content-Type" Content="text/html; Charset=*】意义详解
    淘宝2015年秋招在线笔试题
    mouseleave mouseout时候悬浮框不应该消失的时候消失了 css 解决办法
    ACM知识点分类
    2019牛客多校第九场 B.Quadratic equation
    扫描线算法
    可持久化数据结构(模板)
    luogu SP3267 DQUERY
    luogu2633 Count on a tree(树上LCA+主席树求区间第k小)
  • 原文地址:https://www.cnblogs.com/jing58/p/6061323.html
Copyright © 2020-2023  润新知