环境:
[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转换这边有问题吗.是什么原因呢????