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条)

报告相同问题?

悬赏问题

  • ¥15 Arcgis相交分析无法绘制一个或多个图形
  • ¥15 seatunnel-web使用SQL组件时候后台报错,无法找到表格
  • ¥15 fpga自动售货机数码管(相关搜索:数字时钟)
  • ¥15 用前端向数据库插入数据,通过debug发现数据能走到后端,但是放行之后就会提示错误
  • ¥30 3天&7天&&15天&销量如何统计同一行
  • ¥30 帮我写一段可以读取LD2450数据并计算距离的Arduino代码
  • ¥15 飞机曲面部件如机翼,壁板等具体的孔位模型
  • ¥15 vs2019中数据导出问题
  • ¥20 云服务Linux系统TCP-MSS值修改?
  • ¥20 关于#单片机#的问题:项目:使用模拟iic与ov2640通讯环境:F407问题:读取的ID号总是0xff,自己调了调发现在读从机数据时,SDA线上并未有信号变化(语言-c语言)