[转载]form提交页设置编码类型,使其数据无乱码

这确实是个很好的办法。

 accept-charset 一个很少用到的表单属性,利用它实现在不同编码的页面里实现表单的提交也是一种很方便的解决方法。转自老王的baidu空间,记录在此。

问题背景:

两个应用编码不同,一个是GBK编码,另一个是UTF-8编码。现在要在GBK编码的应用里使用表单向UTF-8编码的应用里提交数据,很显然,如果不做特殊处理的话,会出现乱码。 

解决方案:

当然了,可以自己使用ICONV或者MB扩展来转换编码,但这不是我们要的。 
在W3里介绍了一个不太常见的属性:accept-charset,用它可以完成我们的需求。 
在GBK编码的页面里编写如下代码: 
<form method="post" action="..." accept-charset="utf-8"> ... </form> 

如此的代码在Firefox等正常的浏览器下没有任何问题,但是遇到IE这个变态浏览器就不灵光了,我们还得用点不入流的手段Hack一下: 
<form method="post" action="..." accept-charset="utf-8" οnsubmit="document.charset='utf-8';"> ... </form> 

剩下的工作浏览器会搞定。

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
当从提交数据到 Java 程序出现乱码时,通常是由于编码不一致引起的。在处理乱码问题时,需要检查以下几个方面: 1. 编码 在 HTML 面中,可以使用 `<meta>` 标签指定编码。例如: ```html <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> ``` 这样可以确保浏览器提交数据以 UTF-8 编码传输到服务器端。 2. 服务器编码 在 Java 程序中,可以使用 `request.setCharacterEncoding("UTF-8")` 方法指定服务器端使用 UTF-8 编码接收数据。例如: ```java request.setCharacterEncoding("UTF-8"); ``` 这样可以确保服务器正确解析提交数据。 3. 数据编码 如果提交数据需要存储到数据库中,需要确保数据库表的编码方式和 Java 程序中连接数据库的编码方式一致。可以在连接字符串中指定字符集,例如: ```java String url = "jdbc:mysql://localhost:3306/mydb?useUnicode=true&characterEncoding=UTF-8"; Connection conn = DriverManager.getConnection(url, "username", "password"); ``` 这样可以确保数据库正确存储数据,并且在查询数据时不会出现乱码。 需要注意的是,以上三个方面的编码方式必须一致,否则会出现乱码问题。如果还是出现乱码,可以使用工具类将数据转换成正确的编码方式。例如: ```java String str = new String(request.getParameter("name").getBytes("ISO-8859-1"), "UTF-8"); ``` 其中 `"ISO-8859-1"` 是提交数据编码方式,`"UTF-8"` 是需要转换成的编码方式。这样可以确保数据在 Java 程序中正确解析。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值