`

(转载)JSP+MySQL 乱码问题的总结

阅读更多
文章转载自:http://www.netjsp.com/main/helpcontent.jsp?id=ff8080812b32e071012bb12f0b440d06

JSP+MySQL 乱码问题的总结
  JSP+MySQL的乱码问题是我站虚拟主机用户所谘询的频率最高的问题,本文以UTF8编码为例把影响编码的各个方面经行说明,以供用户参考。主要注意以下几个方面:
  • 1.服务器向客户端发送的页面编码要设置为UTF8:
  • <%@ page contentType="text/html; charset=UTF-8" %>
    

  • 2.页面的保存格式为UTF8:
  • 一般编辑器默认保存的编码都是ascii,最好选择另存指定编码。
  • 3.保证请求参数为UTF8。
  • 如果使用GET方式传递参数,请为Tomcat的HTTP Connector设置URIEncoding参数为UTF-8。
    如果使用POST方式传递参数,请使用request.setCharacterEncoding("UTF-8")。
  • 4.MySQL数据库编码的编码可以在库、表、字段3个级别进行设置,优先级为 库 < 表 < 字段。如果库的编码为UTF8,你在创建表格及字段时没有明确指定其字符集,那么表及字段的编码就继承库的编码也为UTF8。因此如果你在表格和字段级别具体指定了字符集,那么数据库的字符集已经没有意义,不会影响你的编码。最终的编码在字段上,只要字段的编码格式正确,数据库和表的编码已经无关紧要。我站虚拟主机的数据库默认字符集就是utf8,如果你在创建表格及其字段时没有明确指定其编码,字段的编码就会是utf8了。
  • 本站为用户创建的数据库默认编码为utf8,如果您需要其它编码,例如gbk,可以使用以下命令修改自己库的默认编码:
     ALTER DATABASE 数据库名称 DEFAULT CHARACTER SET '字符集名称'
    

    示例:
    ALTER DATABASE test  DEFAULT CHARACTER SET 'gbk'
    


    show variables like "%colla%"查看的是数据库系统的默认编码,查看自己库的默认编码应该使用mysql远程登录到数据库:
    use db;
    status;
    示例:
    mysql> status
    --------------
    mysql  Ver 14.12 Distrib 5.0.77, for redhat-linux-gnu (x86_64) using readline 5.1

    Connection id: 10044
    Current database: za00001
    Current user: za00001@localhost
    SSL: Not in use
    Current pager: stdout
    Using outfile: ''
    Using delimiter: ;
    Server version: 5.0.77 Source distribution
    Protocol version: 10
    Connection: Localhost via UNIX socket
    Server characterset: latin1
    Db     characterset: utf8
    Client characterset: latin1
    Conn.  characterset: latin1
    UNIX socket: /var/lib/mysql/mysql.sock
    Uptime: 39 days 20 hours 26 sec
    上面信息中的Db characterset 就是自己数据库的编码!
    Client characterset是客户端链接时使用的编码,使用mysql命令时要附带--default-character-set参数,否则如果你使用中文,mysql命令会显示乱码。
    mysql命令有--default-character-set 参数改变客户端链接编码,那么JDBC链接如何处理呢,请看下面的地5节。
  • 5.JDBC的url的设置。
  • 需要设置useUnicode=true和characterEncoding=utf8这两个参数,例如:
    String jdbcUrl="jdbc:mysql://localhost:3306/fcm1?useUnicode=true&characterEncoding=utf8";
    如果你在xml文件中,例如context.xml里配置数据源,请将上面的&使用&amp;来替换,例如:
    <?xml version="1.0" encoding="UTF-8"?>
    <Context>
      <Resource
        name="jdbc/FCM"
        type="javax.sql.DataSource"
        driverClassName="com.mysql.jdbc.Driver"
        password="passwd"
        maxIdle="2"
        maxWait="5000"
        username="root"
        url="jdbc:mysql://localhost:3306/fcm1?useUnicode=true&amp;characterEncoding=utf8"
        maxActive="4"/>
    </Context>
    


    只要保证上面5个方面没有问题,那么就不会出现乱码了,Good Luck!
    分享到:
    评论

    相关推荐

      jsp+servlet+mysql乱码解决的这天

      jsp+servlet+mysql乱码解决方案是指在使用jsp+servlet+mysql开发web应用程序时,如何解决中文乱码问题的解决方案。该方案通过设置每个页面的编码格式为utf-8,控制器servlet中的请求编码格式为utf-8,数据库连接url...

      EBook网上书城jsp+servlet+mysql

      利用jsp+servlet实现的一个网上书城web应用,数据库使用的是MySQL,具体的处理涉及到:中文乱码的处理,购物车,订单管理,用户账户管理,商品搜索,高级搜索,登录/注册,各种系统验证。里面包含了系统的一些设计...

      jsp+mysql中文乱码解决方案集合

      在使用JSP结合MySQL进行Web应用开发时,中文乱码问题一直是困扰开发者的一大难题。本文将详细介绍如何在MySQL数据库层面解决中文乱码问题,并提供一系列实用的方法和技巧。 #### MySQL配置文件(my.cnf)设置 在...

      jsp+mysql学生信息管理系统

      (第四代)学生信息管理系统,没有中文乱码问题,部署简单,功能全。使用最新技术开发:eclipse2022,支持java:17or8,支持mysql:8.0or5.7or.56,tomcat:10 普通用户 具有按学号学好查询学生资料功能,普通用户必须先...

      解决jsp+MysQL输入和输出中文乱码的方法!

      解决jsp+MysQL输入和输出中文乱码的方法! 解决jsp+MysQL输入和输出中文乱码的方法!

      java+jsp+mysql开发 web项目处理中文乱码问题

      处理 Java+jsp+mysql 开发 web 项目中文乱码问题 在 Java+jsp+mysql 开发 web 项目中,中文乱码问题是一个常见的问题,影响着项目的正常运行。下面我们将从四个方面来解决中文乱码问题: 一、Jsp 输出中文的乱码...

      mysql.rar_JSP+Mysql_中文乱码

      在开发Web应用时,我们经常会遇到中文乱码问题,特别是在JSP与MySQL的结合使用中。这个"mysql.rar_JSP+Mysql_中文乱码"压缩包提供的资源旨在帮助开发者解决此类问题。以下是对这个问题的详细解释和解决方案。 首先...

      JSP+MYSQL 库存管理系统

      《JSP+MYSQL 库存管理系统》是一份关于构建基于JSP和MySQL的库存管理系统的教程,涵盖了系统设计、开发工具、技术应用以及问题解决等多个方面。本系统旨在提升仓库管理效率,降低运营成本,通过计算机自动化管理实现...

      在线考试系统平台设计,框架:html + js + css + jsp + servlet + java + mysql

      后端:jsp + servlet + java + mysql 开发工具:ideaIC-2022.3.2.exe 或者eclipse都行 + jdk1.8 + Apache Tomcat/8.5.78 select version() 获取数据库版本'5.6.00' 图片无法加载是因为拦截器,修改拦截器,或者删除...

      网络考试系统平台设计,框架:html + js + css + jsp + servlet + java + mysql

      后端:jsp + servlet + java + mysql 开发工具:ideaIC-2022.3.2.exe 或者eclipse都行 + jdk1.8 + Apache Tomcat/8.5.78 http://localhost:8080/exam/ select version() 获取数据库版本'5.6.00' 图片无法加载是因为...

      jsq+mybatis+mysql中文乱码解决方案

      本文将从 JSP、MyBatis 和 MySQL 三个方面来解决中文乱码问题。 JSP 中文乱码解决方案 在 JSP 中,中文乱码的原因主要是浏览器和服务器的编码格式不一致。解决方法是: 1. 在 JSP 页面头部添加 `; charset=UTF-8...

      Struts+Hibernate+MyEclipse+Tomcat+MySQL的乱码之解决篇

      在本篇文章中,我们将深入探讨如何解决Struts + Hibernate + MyEclipse + Tomcat + MySQL环境中出现的乱码问题。该问题通常出现在处理中文字符时,由于编码设置不当导致中文显示为乱码或无法正常读取。为了确保系统...

      基于JSP+Servlet+JDBC+mysql的图书管理系统源码(课程设计).zip

      图书管理系统项目使用eclipse开发工具和MySql数据库进行开发,maven方式创建项目,编码格式为utf-8(如出现乱码可改成utf-8), 项目分成三层架构,数据访问层、业务逻辑层和表现层,并没有使用框架等复杂的技术,...

      JSP+MYSQL库存管理毕业设计论文.pdf

      第五章对在开发过程中遇到的问题进行了总结,如中文乱码问题和其他常见问题,这些问题的解决对于系统稳定运行至关重要。 最后,第六章总结了已经实现的功能,如实时库存查询、库存预警、出入库记录跟踪等,并指出了...

      JSP+MYSQL+中文处理

      总结,处理JSP+MySQL+中文的关键在于确保从用户输入、JSP页面、数据库到后台处理的整个链路中,字符集的一致性和兼容性。只有这样,中文数据才能正确地存储、传输和显示,避免出现乱码问题。在实际开发中,还应注意...

      JSP+ MySQL中文乱码问题post提交乱码解决方案

      总结来说,解决JSP+MySQL中文乱码问题的关键在于确保页面编码、数据库编码以及浏览器解析编码三者保持一致。开发者需要在JSP页面、数据库以及服务器连接设置中,明确指定并统一使用`UTF-8`或`gb2312`编码。在实现上...

      jsp+ssm+mysql酒店管理.7z

      4. "乱码解决办法.txt":为了解决可能出现的编码问题,这个文件提供了具体的解决策略。 5. "Java经典项目带视频教程.url":指向一个外部链接,可能是更广泛的Java开发教程或者相关视频课程。 6. "ssm酒店系统文档":...

    Global site tag (gtag.js) - Google Analytics