iteye_588 2009-04-17 10:39
浏览 275
已采纳

中文乱码问题

环境:

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

  • 写回答

4条回答 默认 最新

  • wei_jing 2009-04-18 10:01
    关注

    [quote]1. 在form里面填写中文,可以查如数据库, 在页面上search出来的也是正常的.
    但用sqlplus查询出来的, 却是乱码. [/quote]
    [quote]2. 如果用sqlplus插入数据, 再用sqlplus查询, 中文显示正常, 但页面上查询出来的就是乱码了. [/quote]

    我不知道AL32UTF8和utf-8有什么区别,但是敢肯定是这2者之间编码转换的问题。
    我建议楼主看下这篇文章,再测试一下。
    [url]http://www.itpub.net/838447,1.html[/url]

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!
  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?