当使用JSP页面将中文数据添加到MySql数据库中的时候发现变为乱码,或者从mysql中读取中文的时候出现乱码,这些问题根源都是由于字符编码不一致造成的。要知道病源是什么我们才能对症下药,所以我将问题产生的过程简单描述一下(如有不对望高人赐教)
我们以一个从form表单读取数据并写入mysql数据库的例子来讲解;
HTML页面参数—(以浏览器的编码方式发送)—》JSP页面—(以JSP定义的编码方式被编译)—》被JSP引擎编译为*.class文件——》在JSP容器中运行——》传递给Mysql数据库—(以数据库的编码方式读取数据并存储)—》读取Mysql—(以数据库的编码方式读取)—》JSP页面接受后在浏览器中显示(以浏览器编码方式解码显示);
注意:这里的“浏览器编码”“JSP页面编码”“JSP页面输出编码”“JSP页面输入编码”“数据库的编码”可能存在潜在的不一直,当它们中的任意一个不相同的时候就会出现乱码;就好像传话游戏一样,张三要把话传给李四,李四把他听到的传给王五,要让王五知道张三说的什么就需要他们三个人使用的相同语言,如果李四是个火星人,他当然听不懂张三说什么,然后他还不厚道的对王五说火星话(乱码),结果王五就只能听到乱码了。(比喻比较汗~~^_^!)
好了,现在我们就依次把各个编码方式改为相同就可以了;
//-------------------------浏览器编码-----------------
<html>
<head><meta http-equiv="Content-Type" content="text/html; charset=GB2312"></head>
</html>
//---------------------------JSP页面-------------------
<%@ page pageEncoding="GB2312"%> //JSP页面编码:
<%@ page contentType="text/html;charset=gb2312"%> //JSP页面输出编码:
<% request.setCharacterEncoding("gb2312"); %> //JSP页面输入编码:
//------------------------MySql编码-------------------
Connection connect = java.sql.DriverManager.getConnection(
"jdbc:mysql://localhost/mydb?user=登陆帐号&password=你的密码&useUnicode=true&characterEncoding=gb2312");
//-------------------------------------------------------
注意:gb2312的写法(红色部分) 在浏览器和数据库中的写法要区分!
以上配置测试成功!(tomcat5.5+MySql5.0)
//另外看了网上的很多文章,比如通过函数转码啊~~改配置文件啊~~都不如这样来的简便且成功率高!
推荐!
运行环境 tomcat5.5+MySql5.0
编写一个简单的HTML表单:
<html>
<head>
</head>
<body>
<form action="http://127.0.0.1/test/login.jsp" method="post">
学号:<input type="text" name="id"><br>
姓名:<input type="text" name="name"><br>
<label>
<input type="radio" name="sex" value="boy" checked>
男</label>
<label>
<input type="radio" name="sex" value="girl">
女</label><br>
电话:<input type="text" name="tel"><br>
<input type="submit" value="提交">
<input type="reset" value="重填">
</form>
</body>
</html> 接这编写一个JSP文件用于读取表单数据
Connection conn = null;
Class.forName("com.mysql.jdbc.Driver").newInstance();
conn = java.sql.DriverManager.getConnection("jdbc:mysql://localhost/mydb","root","corsair");
if(conn==null){
System.out.println("get Conn Error");
}
Statement stmt=conn.createStatement();
ResultSet rs=null;
%>
<%
String id,name,sex,tel;
id=request.getParameter("id");
name=request.getParameter("name");
sex=request.getParameter("sex");
tel=request.getParameter("tel");
try{
stmt.executeUpdate("INSERT INTO inf_student(id,name,sex,tel) VALUES ('"+id+"','"+name+"','"+sex+"','"+tel+"')");
}catch(SQLException e){}
stmt.close();
conn.close();
%> 将以上文件保存在tomcat5.5的webapps目录下;然后启动tomcat5.5和mysql数据库,最后打开表单,插入数据提交,并可以mysqlQueryBrower查看到插入数据的情况了。
<%@ %>指令块。定义JSP文件的全局属性,该指令不能作用动态包含文件;
<%@ page
language="java"
extends="指定父类"
import="导入JAVA类"
session="false||true是否使用session对象"
buffer="定义缓冲区大小默认8kb"
autoFlush="false||true自动清除缓冲区"
isThreadSafe="false||true是否处理多请求"
info="定义相关信息.txt"
errorPage="url指定错误页"
contentType="编码方式"
isErroPage="false||true是否为处理异常页"
%>
<%@ include
file
="URL指定要包含的另外一个JSP文件,*.jspf,*.htmlf"%>
<%@ taglib
uri
="" prefix=""%>
常用的JSP动作元素
1
<jsp:useBean
id="指定该bean对象名"
scope="page||request||session||application bean的作用域"
class="bean的class文件名,注意不能与beanName属性一起使用"
beanName="*.class或*.ser或bean包的名字,紧当bean不存在于指定 的作用域时才使用 "
type="与class或beanName一起使用,指定要实例化的bean的类或接口"
>
<jsp:setProperty name="" property="" value="">实例话bean的初始特性值。
</jsp:/useBean>
2
<jsp:setProperty
name="对应<jsp:useBean>中的id"
property="*||bean属性名 通过request参数设定bean属性值"
value="为bean属性值指定值,需要指定bean属性名"
/>
3
<jsp:getProperty
name="对应<jsp:useBean>中的id"
property="对应想要获得的属性值名"
/>
4
<jsp:include>
page="要包含文件的相对地址"
flush="true||false 是否清空缓冲区"
<jsp:param name="" value="" 可以传递一个参数/>
</jsp:include>
5
<jsp:forward page="URL或者一个表达式,用于将请求的页面转向其他页面">
<jsp:param name="" value="">可以传递参数;
</jsp:forward>
6
<jsp:param
name="" value="">
<%! %>
变量和方法声明块,要使用“;”结尾
<% %>
脚本块 可以声明局部变量 但是不能定义方法!
<%= %>
表达式 注意内部不能使用“;”
硬件情况:
两台电脑均使用windowsxp-sp2;
两台电脑均有板载网卡。一台使用升技NF7-S2主板,一台用的技嘉威盛芯片组的小板(好像叫 8V800M2)
单独购买一个tp-link的8139网卡。购价24元(嘿嘿。JS想宰我,结果与其打心理战!最终JS阴谋落败!哈哈)
一根双机对联的双绞线。注意排线(橙蓝绿棕)(绿蓝橙棕);
1: 其中一台正确接入internet;(由于使用升技NF7-S2主板的电脑一旦双网卡就会重起,所以不敢使用)并安装双网卡,使用独立网卡接入internet,另外板载网卡与另一台电脑相连;
2:在主机上(就是有双网卡的那台)创建一个internet连接.
3: 将与internet相连的哪个本地连接A的tcp/ip设置为自动获得;将刚创建的哪个internet连接共享出来(属性--》高级--》全打钩--》家庭网络连接选与另外一太电脑相连的那个本地连接B)再把B连接的ip地址设置为192.168.0.1 掩码255.255.255.0 。
4:最后把客户机的ip设置为192.168.0.2 掩码255.255.255.0 网关:192.168.0.1 DNS:192.168.0.1
好了!把主机上网,这样就实现了双机共享上网了!
很久以前就对
linux
很好奇,于是在网上查了很多的发行版,最后互相比较之后最终选择了
kubentu
这是基于
Dibean
的
LINUX
发行版本,由于它的软件包很丰富,而且采用的
KDE
桌面环境也和
WINDOWS
比较像(而且漂亮很多),在网上的评价也很不错,于是下载刻盘。我安装的版本是
kubentu6.06
,我的
winXP-sp2
我
80G
的分区如下:
主分区:
C
:
4G fat32
安装
windowXP
系统
扩展分区:
D
:
15G ntfs
安装软件
E
:
35G ntfs
存放视频
F
:
6G fat32
我的工作目录
G
:
5G fat32
存放备份
Linux
主分区:
8G ext3
挂载根文件系统
Swap:512MB
交换分区
顺便说明一点:我用的分区软件是
PartitionMagic
汉化版;还有一个
hand disk manager6.0
也非常好用。可以将你硬盘中的空闲空间合并起来形成一个新的分区;具体使用方法可以参考软件的帮助文件;要注意的是将
LINUX
的分区划为一个主分区,如果划为扩展逻辑分区不知道行的通不。保险起见还是划为主分区了;
在使用
PartitionMagic
汉化版时,这个软件有个向导帮助你安装双系统比如
widow+linux
但在最后一步中它会提示你要将你新划出的
LINUX
分区设置为激活状态,但同时也说如果没有马上安装
LINUX
的话会导致
WINDOWS
不可引导。当时我也很在意这句话也上网查了很多资料但是都没有说明这个问题(是否需要激活);由于不想冒风险于是还是决定不将它设置为激活,事实证明这样是对的;呵呵。
第一步
:正常安装
WINDOWXP
不用多说,如果你本来就有
windows
系统就往下继续
第二步
:设置
BIOS
从光驱启动,然后放入
kubentu
的光盘(注意刻盘的时候要将不要科成数据光盘否者是不能引导的,从网上下载镜像文件然后从镜像复制光盘)
第三步
:正常引导以后选择第一个选项;这里要注意,如果你要安装简体中文版的系统需要现在选者
language
为简体中文,如果安装英文版的就直接选择第一项就可以了;如果现在不选择语言等引导进入系统后再选择简体中文就会是乱码了,这里要注意;
第四步
:进入系统,选择安装,进入之后依次设置时区(上海)语言(简体中文)键盘(标准美式键盘)等属性。
第五步
:也是最关键的一步,选择手动编辑分区表,这时候回列出现在的分区信息,选择你已经
l
划分好的
inux
分区并记录好这个分区的名字(一般是
hda?—“?”
代表数字)点下一步,选择刚才的
had?
哪个分区,然后在最左边的下拉列表中选择
”/”j
即根文件系统,注意在最右边有一列单选按钮提示是否要重新格式划对应的分区,如果你不想你硬盘其他分区的数据不想被破坏的话几千万不要选择!好了点下一步:这时候有个戏剧性的场面会出现,安装程序会提示你一段警告英文,大体意思是说:“如果继续的话你的硬盘所有的分区的数据将被摧毁!请确认做好备份……”当时我就被这段话给吓住了
~~
提心吊胆了好久也不敢点下一步,经过了几个月的思想斗争后终于决定点下一步了……其结果可想而知!原来确实是虚惊一场!!安装程序给我开了一个天大的玩笑。同志们如果确认前面的事情都做好了就放心的点下一步吧!
好了
~~
以后的安装完全不用担心了。它回自动识别你的硬件和
windowsxp
系统,好了完成,这时候将光盘拿出重起,你就会看到双启动菜单!