转自 “http://www.netjsp.com/main/helpcontent.jsp?id=ff8080812b32e071012bb12f0b440d06”
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里配置数据源,请将上面的&使用&来替换,例如:
<?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&characterEncoding=utf8"
maxActive="4"/>
</Context>
只要保证上面5个方面没有问题,那么就不会出现乱码了,Good Luck!
分享到:
相关推荐
jsp+servlet+mysql乱码解决方案是指在使用jsp+servlet+mysql开发web应用程序时,如何解决中文乱码问题的解决方案。该方案通过设置每个页面的编码格式为utf-8,控制器servlet中的请求编码格式为utf-8,数据库连接url...
利用jsp+servlet实现的一个网上书城web应用,数据库使用的是MySQL,具体的处理涉及到:中文乱码的处理,购物车,订单管理,用户账户管理,商品搜索,高级搜索,登录/注册,各种系统验证。里面包含了系统的一些设计...
在使用JSP结合MySQL进行Web应用开发时,中文乱码问题一直是困扰开发者的一大难题。本文将详细介绍如何在MySQL数据库层面解决中文乱码问题,并提供一系列实用的方法和技巧。 #### MySQL配置文件(my.cnf)设置 在...
解决jsp+MysQL输入和输出中文乱码的方法! 解决jsp+MysQL输入和输出中文乱码的方法!
(第四代)学生信息管理系统,没有中文乱码问题,部署简单,功能全。使用最新技术开发:eclipse2022,支持java:17or8,支持mysql:8.0or5.7or.56,tomcat:10 普通用户 具有按学号学好查询学生资料功能,普通用户必须先...
处理 Java+jsp+mysql 开发 web 项目中文乱码问题 在 Java+jsp+mysql 开发 web 项目中,中文乱码问题是一个常见的问题,影响着项目的正常运行。下面我们将从四个方面来解决中文乱码问题: 一、Jsp 输出中文的乱码...
在开发Web应用时,我们经常会遇到中文乱码问题,特别是在JSP与MySQL的结合使用中。这个"mysql.rar_JSP+Mysql_中文乱码"压缩包提供的资源旨在帮助开发者解决此类问题。以下是对这个问题的详细解释和解决方案。 首先...
后端:jsp + servlet + java + mysql 开发工具:ideaIC-2022.3.2.exe 或者eclipse都行 + jdk1.8 + Apache Tomcat/8.5.78 select version() 获取数据库版本'5.6.00' 图片无法加载是因为拦截器,修改拦截器,或者删除...
后端: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' 图片无法加载是因为...
在本篇文章中,我们将深入探讨如何解决Struts + Hibernate + MyEclipse + Tomcat + MySQL环境中出现的乱码问题。该问题通常出现在处理中文字符时,由于编码设置不当导致中文显示为乱码或无法正常读取。为了确保系统...
本文将从 JSP、MyBatis 和 MySQL 三个方面来解决中文乱码问题。 JSP 中文乱码解决方案 在 JSP 中,中文乱码的原因主要是浏览器和服务器的编码格式不一致。解决方法是: 1. 在 JSP 页面头部添加 `; charset=UTF-8...
其中,中文乱码问题是一个常见的挑战。开发者需要通过合理的编码设置来解决这一问题,以保证数据的准确性和一致性。其他问题可能涉及到数据同步、性能优化等方面,这些都是需要开发者认真对待并解决的问题。 目前,...
图书管理系统项目使用eclipse开发工具和MySql数据库进行开发,maven方式创建项目,编码格式为utf-8(如出现乱码可改成utf-8), 项目分成三层架构,数据访问层、业务逻辑层和表现层,并没有使用框架等复杂的技术,...
第五章对在开发过程中遇到的问题进行了总结,如中文乱码问题和其他常见问题,这些问题的解决对于系统稳定运行至关重要。 最后,第六章总结了已经实现的功能,如实时库存查询、库存预警、出入库记录跟踪等,并指出了...
总结,处理JSP+MySQL+中文的关键在于确保从用户输入、JSP页面、数据库到后台处理的整个链路中,字符集的一致性和兼容性。只有这样,中文数据才能正确地存储、传输和显示,避免出现乱码问题。在实际开发中,还应注意...
总结来说,解决JSP+MySQL中文乱码问题的关键在于确保页面编码、数据库编码以及浏览器解析编码三者保持一致。开发者需要在JSP页面、数据库以及服务器连接设置中,明确指定并统一使用`UTF-8`或`gb2312`编码。在实现上...
4. "乱码解决办法.txt":为了解决可能出现的编码问题,这个文件提供了具体的解决策略。 5. "Java经典项目带视频教程.url":指向一个外部链接,可能是更广泛的Java开发教程或者相关视频课程。 6. "ssm酒店系统文档":...