UML学习(一)-----用例图
2016-04-07 11:23
344 查看
java;jsp;tomcat;mysql;hibernate;j2ee 编码中文乱码全面解决方案
java、jsp中设置编码
首先说在java里那些地方能够设置编码 开发工具会有好多地方设置编码这个不解少了,这里不介绍了。 下面两种设置编码格式方法适用于jsp页面(*.jsp)
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <%@ page contentType="text/html; charset=UTF-8" %>
下面方式适合于jsp、servlet、action中(*.java)
request.setCharacterEncoding("UTF-8"); response.setCharacterEncoding("UTF-8");
下面适合html页面(*.htm;*.html)
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
Tomcat设置编码(server.xml)
<Connector 其他省略 port="80" URIEncoding="UTF-8">
mysql设置编码命令
SET character_set_client = utf8; SET character_set_connection = utf8; SET character_set_database = utf8; SET character_set_results = utf8;/*这里要注意很有用*/ SET character_set_server = utf8; SET collation_connection = utf8_bin; SET collation_database = utf8_bin; SET collation_server = utf8_bin;
my.ini中配置默认编码
default-character-set=utf8
连接数据库设置编码
jdbc:mysql://192.168.0.5:3306/test?characterEncoding=utf8
java与mysq编码对应
NAME | ||||
---|---|---|---|---|
JAVA | UTF-8 | GBK | GB2312 | ISO-8859-1 |
MYSQL | utf8 | gbk | gb2312 | latin1 |
过滤器使用
//过滤器设置编码过滤(SetCharacterEncodingFilter.java) package com.sorc; import java.io.*; import javax.servlet.*; import javax.servlet.http.*; public class SetCharacterEncodingFilter extends HttpServlet implements Filter{ private FilterConfig filterConfig; private String encoding=null; //Handle the passed-in FilterConfig public void init(FilterConfig filterConfig){ this.filterConfig=filterConfig; encoding=filterConfig.getInitParameter("encoding"); } //Process the request/response pair public void doFilter(ServletRequest request,ServletResponse response,FilterChain filterChain){ try{ request.setCharacterEncoding(encoding); filterChain.doFilter(request,response); } catch(ServletException sx){ filterConfig.getServletContext().log(sx.getMessage()); } catch(IOException iox){ filterConfig.getServletContext().log(iox.getMessage()); } } //Clean up resources public void destroy(){ } }
//web.xml配置过滤器方法(web.xmd) <filter> <filter-name>setcharacterencodingfilter</filter-name> <filter-class>com.sorc.SetCharacterEncodingFilter</filter-class> <init-param> <param-name>encoding</param-name> <param-value>utf8</param-value> </init-param> </filter> <filter-mapping> <filter-name>setcharacterencodingfilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
有了上面的基础下面试完满解决方案
1.使用GBK编码的解决方案 这个最简单 遇到设置编码的地方就是用GBK数据库gbk 然后在使用个过滤器过滤编码为gbk一切搞定。 效果为添加数据无乱码 读出无乱码 数据库管理工具无乱码 到处sql结构和数据无乱码 2.使用UTF-8编码解决方案 所有编码都设置为UTF-8 数据库编码utf8 设置过滤器编码utf8 数据库连接?`characterEncoding=utf8` 然后在数据库管理工具或mysql命令行 运行 `SET character_set_results = gbk;` 效果为添加数据无乱码 读出无乱码 数据库管理工具无乱码 到处sql结构和数据时存在乱码 3.页面使用UTF8 数据库使用latin1的解决方案 jap java tomcat 设置为UTF-8 过滤器 utf8 数据库连接?characterEncoding=latin1 数据库其他latin1 然后在数据库管理工具或mysql命令行 运行 SET character_set_results = gbk; 效果为添加数据无乱码 读出无乱码 数据库管理工具无乱码 到处sql结构和数据时存在乱码 以上都不需要页面或java代码中手动转码
相关文章推荐
- 自定义复合控件并进行封装
- c++实验3-个人所得税计算器
- 如何增加swap 大小
- 团队开发介绍
- 工作总结二
- 程序界劝退系列之 从入门到放弃/要饭/痴呆/出家/转行/住院/猝死/跑路
- 沫沫金:Java快速合并两个数组【绝技】
- 普通电脑使用iscsiTarget模拟成iscsi磁盘
- 【mysql学习】linux安装mysql
- iOS 开发库
- linux下升级gcc的方法
- AFNetworking 2.0到3.0 迁移指南
- Linux下异步I/0: Linux上的AIO简介
- openwrt之直接安装iperf
- Appium API介绍
- 5.3.1.2 smtpd_check_*函数的ACL验证方法
- 使用Poco实现插件方式加载动态库
- grunt前端打包——css篇
- .net 配置文件 分析 EntityName 时出错
- curl