环境:
[code="java"]
数据库字符集:
select * from nls_database_parameters where parameter in('NLS_LANGUAGE','NLS_TERRITORY','NLS_CHARACTERSET')
PARAMETER VALUE
NLS_LANGUAGE AMERICAN
NLS_TERRITORY AMERICA
NLS_CHARACTERSET AL32UTF8
客户端设置:
注册表里改了:
NLS_LANG: AMERICAN_AMERICA.AL32UTF8
使用以上设置在sqlplus里面是可以正常插入,正常查询,没有乱码.
[/code]
java环境
jsp和web.xml:
[code="java"]
<%@ page pageEncoding="UTF-8" contentType="text/html; charset=UTF-8" %>
Set Character Encoding
filters.SetCharacterEncodingFilter
encoding
utf8
server启动的时候加了: -Dfile.encoding="UTF-8" -Dsun.jnu.encoding="utf-8"
不加的话默认是:
sun.jnu.encoding=GBK
file.encoding=Cp1252
[/code]
[code="java"]
Reginal and Language里面的设置是:
Location: China.
Advanced: Chinese (RPC)
[/code]
现在的问题:
1. 在form里面填写中文,可以查如数据库, 在页面上search出来的也是正常的.
但用sqlplus查询出来的, 却是乱码.
2. 如果用sqlplus插入数据, 再用sqlplus查询, 中文显示正常, 但页面上查询出来的就是乱码了.
难道是数据库到java转换这边有问题吗.是什么原因呢????
[quote]1. 在form里面填写中文,可以查如数据库, 在页面上search出来的也是正常的.
但用sqlplus查询出来的, 却是乱码. [/quote]
[quote]2. 如果用sqlplus插入数据, 再用sqlplus查询, 中文显示正常, 但页面上查询出来的就是乱码了. [/quote]
我不知道AL32UTF8和utf-8有什么区别,但是敢肯定是这2者之间编码转换的问题。
我建议楼主看下这篇文章,再测试一下。
[url]http://www.itpub.net/838447,1.html[/url]
jsp也要转码成UTF-8!
1.建议debug看看,断点调试看看拿到的值是不是乱码?
2.或者在插入的时候打印到控制台上,看是否是乱码.
3.可以使用转码:
写入:String newStr = new String(oldStr.getByte("GB2312"),"ISO8859_1");
读出:String newStr = new String(oldStr.getByte("ISO8859_1"),"GB2312");
测试方法是:都插入中文,比如"中国",看用sqlplus插入的和用应用程序插入的,在数据库中编码是不是一样。[color=red]我认为是不一样的[/color]