zoukankan      html  css  js  c++  java
  • web项目存数据到数据库,中文乱码,解决过程

    first:

    排查原因:

    打断点,查看到底是在执行存数据库操作之前就已经乱码了,还是存数据库操作后乱码的。

    前者解决方案:

    在web.xml里面加上:

    <filter>
    <filter-name>encodingFilter</filter-name>
    <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
    <async-supported>true</async-supported>
    <init-param:>
    <param-name>encoding</param-name>
    <param-value>UTF-8</param-value>
    </init-param>
    </filter>
    <filter-mapping>
    <filter-name>encodingFilter</filter-name>
    <url-pattern>/*</url-pattern>
    </filter-mapping>
    在配置jdbc数据源的时候加上:
    jdbc:mysql://127.0.0.1:3306/logistics?useUnicode=true&amp;characterEncoding=UTF-8

    用了POST方式提交的表单时,设置编码方式:
    response.setCharacterEncoding("UTF-8");
    request.setCharacterEncoding("UTF-8");

    存数据库操作后乱码,解决方案:
    登录数据库,执行如下sql:

    show variables like 'character%';

    结果:

    | character_set_client     | utf8                                                   |

    | character_set_connection | utf8                                                   |

    | character_set_database   | latin1                                                 |

    | character_set_filesystem | binary                                                 |

    | character_set_results    | utf8                                                   |

    | character_set_server     | latin1                                                 |

    | character_set_system     | utf8                                                   |

     

    说明在安装数据库的时候,character_set_database,character_set_server编码格式设置错误。

    解决:

    找到mysql安装路径下的my.cnf(windows下为my.ini)文件在[mysqld]下添加如下两行:

    character_set_server=utf8 
    init_connect='SET NAMES utf8'

    再次查看,问题解决:

    | character_set_client     | utf8                                                   |

    | character_set_connection | utf8                                                   |

    | character_set_database   | utf8                                                   |

    | character_set_filesystem | binary                                                 |

    | character_set_results    | utf8                                                   |

    | character_set_server     | utf8                                                   |

    | character_set_system     | utf8        

     

    转载自:https://www.cnblogs.com/tom-plus/p/5701741.html

  • 相关阅读:
    ASP.NET2.0中创建自定义配置节处理程序(声明性模型) joe
    .Net3.0里的DependencyProperty(1) joe
    详解Javascript匿名函数的使用(转) joe
    Mark:未能启用约束。一行或多行中包含违反非空、唯一或外键约束的值 joe
    设置windows 7 默认登陆帐户 joe
    数据库的回滚
    关于软件开发人员如何提高自己的软件专业技术方面的具体建议
    查询表结构
    readonly 和 const总结
    深入NHibernate映射
  • 原文地址:https://www.cnblogs.com/superslow/p/8858532.html
Copyright © 2011-2022 走看看