|
首先看是从什么地方开始出现的乱码,只要统一编码,就不会出现乱码,下面以uft-8(个人认为最好)为例,详细说明:
1、如果乱码是从jsp页面出现的,jsp头部页面加上: <%@ page language="java" pageEncoding="UTF-8" %> 在head标签中加上标签。
2、如果乱码是在servlet中出现的,则有两种方法: 一种是在每个servlet中doget和doPost方法头部加上 request.setCharacterEncoding(“UTF-8″); 第二种最保险,一劳永逸,是专门写一个过滤器类,也称国际化,类名为SetCharacterEncodingFilter内容如下 复制代码 代码如下: package com.sharep.filter;//包名 import java.io.IOException; import javax.servlet.Filter; import javax.servlet.FilterChain; import javax.servlet.FilterConfig; import javax.servlet.ServletException; import javax.servlet.ServletRequest; import javax.servlet.ServletResponse; public class SetCharacterEncodingFilter implements Filter { protected String encoding = null; protected FilterConfig filterConfig = null; protected boolean ignore = true; public void init(FilterConfig filterConfig) throws ServletException { this.filterConfig = filterConfig; this.encoding = filterConfig.getInitParameter("encoding"); String value = filterConfig.getInitParameter("ignore"); if (value == null) this.ignore = true; else if (value.equalsIgnoreCase("true")) this.ignore = true; else this.ignore = false; } public void doFilter(ServletRequest request,ServletResponse response, FilterChain chain) throws IOException,ServletException {
if (ignore || (request.getCharacterEncoding() == null)) { String encoding = selectEncoding(request); if (encoding != null) request.setCharacterEncoding(encoding); } chain.doFilter(request,response); } public void destroy() { this.encoding = null; this.filterConfig = null; } protected String selectEncoding(ServletRequest request) { return (this.encoding); } }
然后在web-inf的web.xml中加上如下代码:
复制代码 代码如下: <filter> <filter-name>SetCharacterEncoding</filter-name> <filter-class>com.young.filter.SetCharacterEncodingFilter</filter-class>//注意这里是类名,要有完整包名 <init-param> <param-name>encoding</param-name> <param-value>UTF-8</param-value> </init-param> </filter>
<filter-mapping> <filter-name>SetCharacterEncoding</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
这样就搞定了
3、如果还是有乱码,就是mysql数据库的问题了
1)保证建立数据库的时候数据库编码选择的是utf-8,最好在每个表中也指定编码格式,mysql默认是latin1 2)如果mysql版本是4.x以上,数据库中还是出现乱码,有以下两种解决方法: 一种是在连接数据库的代码中指定编码方式: 复制代码 代码如下:String url = “jdbc:mysql://localhost:3306/test2?autoReconnect=true&useUnicode=true&characterEncoding=gbk&mysqlEncoding=utf8″ ;
如果还是不行的话就是用 复制代码 代码如下:show variables like ‘collation_%'; 这个命令来查看默认字符集,如果不是utf-8的话在my.ini(windows)或者是my.cnf(linux)将相应的编码修改成utf8之后重启mysql服务器就ok了
您可能感兴趣的文章:- jsp页面中获取servlet请求中的参数的办法详解
- JavaWeb实现用户登录注册功能实例代码(基于Servlet+JSP+JavaBean模式)
- Servlet+Jsp实现图片或文件的上传功能具体思路及代码
- JSP+Servlet制作Java Web登录功能的全流程解析
- JSP与Servlet的介绍说明
- Servlet与JSP间的两种传值情况
- jsp和servlet中实现页面跳转的方式实例总结
- JSP+Servlet+JavaBean实现登录网页实例详解
- 基于JSP HttpServlet的详细介绍
- JSP、Servlet中get请求和post请求的区别总结
- Servlet+JavaBean+JSP打造Java Web注册与登录功能
- 基于jsp+servlet实现的简单博客系统实例(附源码)
- jsp+servlet+javabean实现数据分页方法完整实例
- jsp+servlet+jdbc实现对数据库的增删改查
- 在jsp中用bean和servlet联合实现用户注册、登录
- JSP使用Servlet作为控制器实现MVC模式实例详解
- 访问JSP文件或者Servlet文件时提示下载的解决方法
- jsp引用servlet生成的验证码代码演示
- javascript与jsp发送请求到servlet的几种方式实例
(编辑:安卓应用网)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|