web前后台乱码总结
来源:互联网 发布:淘宝卖特产没证可以吗 编辑:程序博客网 时间:2024/06/05 17:54
第一:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8" contentType="text/html; charset=UTF-8"%>这句话是加在每个页面的最上面,在<!DOCTYPE html>之前加的并且
request.setCharacterEncoding("gb2312");
第二: 配置Tomcat的 server.xml。
<Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" URIEncoding="UTF-8" /> <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" URIEncoding="UTF-8"/>第三:配置 web.xml
<filter> <filter-name>setEncoding</filter-name> <filter-class>com.dinner.filter.CharsetFilters</filter-class> <init-param> <param-name>coding</param-name> <param-value>UTF-8</param-value> </init-param> </filter> <filter-mapping> <filter-name>setEncoding</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
第四:
工程编码
开发中发现Windows版Eclipse默认Java和Web工程的默认编码方式不那么遂人愿,修改方法如下:
1. Web工程文件编码修改方式
Window -> Preference -> Content types
推荐将Web相关文件的编码都设置为UTF-8
2. Java源文件编码修改方式
Window -> Preference -> Workspace -> Text file encoding
Windows平台默认为GBK,Linux平台默认为UTF-8
第五:
如果使用ajax前后台数据交互,可以改变传输方式,将type设置为post
$.ajax({url:"productAdd.htmls", type:"post", data:{ "productName" : productName, "productCre" : productCre }, success:function(data){ if(data != null){ var product = eval("("+data+")"); temp="<tr class='text-c'><td><input type='checkbox' value='"+product.productId+ "'></td><td>"+product.productName+"</td><td><a href='checkdisease.htmls'>【查看疾病信息】</a><a href='updateproduct.htmls'>【更新】</a></td></tr>"; $('.table-bordered tbody tr:first' , parent.document).before(temp); $('.table-bordered tbody tr:last' , parent.document).remove(); } // var index = parent.layer.getFrameIndex(window.name); 可以用这个获取当前要关闭的layer ,也可以使用parent.indexProductAdd 获取在父层定义的那个layer。open()的弹窗 parent.layer.close(parent.indexProductAdd); //获取到layer的弹出窗 关闭它 }});
这样即可以解决!!!
第六:
在type不能设置为post的情况下,可以在后台接收到数据之后,自行进行解码
【 URLDecoder.decode(condition, "utf-8");】参数1:字符串 参数2:编码方式
@RequestMapping(value= "/statistics" ,produces = "text/html;charset=UTF-8") @ResponseBody public String statistics(HttpServletRequest request,String condition,String questOptions) throws UnsupportedEncodingException{ questOptions = questOptions.replaceAll("category=", ""); String [] questArr = questOptions.split("&"); condition = URLDecoder.decode(condition, "utf-8"); System.out.println(condition); System.out.println(questOptions); return null; }
在这里 获取到转码后的字符串的 效果 比【new String(str.getBytes("ISO-8859-1"),"utf-8")】要好得多!
阅读全文
0 0
- web前后台乱码总结
- 前后台中文乱码
- 前后台中文乱码问题
- 前后台中文乱码解决方案
- web前后台数据交互
- 前后台搭建error总结
- Android前后台传数据乱码,xml
- 前后台交互中文乱码可能原因
- 关于前后台汉字乱码问题
- javaweb前后台中文参数乱码
- Spring解决前后台乱码问题
- Cookie前后台使用乱码问题
- JavaWeb前后台中文乱码处理
- javaWEB中前后台乱码解决问题小结
- web 前后台数据交互的方式
- web前后台的参数交互方式
- web 前后台数据交互的方式
- web前后台数据交互的方式
- python 读取Linux服务器上的文件
- Android百分比布局
- 通过RSRP和SINR判断LTE信号质量
- 训练营第五天实训
- 阿里巴巴Java开发手册学习小结7-注释规约
- web前后台乱码总结
- Effective Java之避免创建不必要的对象(五)
- CIFAR-10驱动的KNN分类器
- libux创建逻辑卷及扩展
- Jsoup通过URL获取文档,获取href属性内容
- caffe移植到mxnet
- Windows套接字I/O模型(3) -- WSAAsyncSelect模型
- 利用JS实现复选框一键全选/全不选
- 网络流(Dinic && ISAP)