Servlet中文乱码解决

举报
小傅哥 发表于 2021/04/30 03:43:29 2021/04/30
【摘要】 1:比较土鳖的方式 String name = req.getParameter("name"); name = new String(name.getBytes("iso-8859-1"),"GBK"); 2:土鳖方式另一个 req.setCharacterEncoding(encoding); res.setContentType("text/html;char...

1:比较土鳖的方式

String name = req.getParameter("name");

name = new String(name.getBytes("iso-8859-1"),"GBK");

2:土鳖方式另一个

req.setCharacterEncoding(encoding);

res.setContentType("text/html;charset="+encoding);

3:比较正规的用Filter过滤

 配置xml

 <!-- filter xml 配置 -->
 
  <filter>
   <filter-name>MyFilter</filter-name>
   <filter-class>com.xiaofu.filter.MyFilter</filter-class>
   <init-param>
    <param-name>encoding</param-name>
    <param-value>GBK</param-value>
   </init-param>
  </filter>
 
  <filter-mapping>
   <filter-name>MyFilter</filter-name>
   <url-pattern>/*</url-pattern>
 <dispatcher>FORWARD</dispatcher>   
 <dispatcher>REQUEST</dispatcher>
  </filter-mapping>

 Myfilter类

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 MyFilter implements Filter {

 private String encoding = null;
 private FilterConfig filterConfig = null;
 
 public void destroy() {
  this.encoding = null;
  this.filterConfig = null;
 }

 public void doFilter(ServletRequestservletReq,ServletResponseservletRes,
   FilterChain chain) throws IOException, ServletException {
  if(filterConfig!=null){
   servletReq.setCharacterEncoding(encoding);
   servletRes.setContentType("text/html;charset="+encoding);
  }
  chain.doFilter(servletReq, servletRes);
 }

 public void init(FilterConfigfilterConfig) throws ServletException {
  this.filterConfig = filterConfig;
  this.encoding = filterConfig.getInitParameter("encoding");
 }

}

 

4:Mysql数据库乱码(改完记得重启)

--1步

在D:\MySql下有个my.ini文件编辑打开

找到里面的default-storage-set=XXX(这个东西有的有两个,有的有一个,有几个改几个

XXX可以替换为utf-8  或者 gbk(首选)

--2步

当在mysql的控制台输入汉字后插入,select后仍然乱码

在控制台输入set names gbk;

 

5:建表时候设置表编码

--建库

create database 'test' default character set gbk;

--使用库test

use test

--在test库里面建表students

create table students(id int);

此时students表的编码为gbk

文章来源: bugstack.blog.csdn.net,作者:Yao__Shun__Yu,版权归原作者所有,如需转载,请联系作者。

原文链接:bugstack.blog.csdn.net/article/details/7859110

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。