后台前台传入编码处理filter(最完善版本)(根据不同请求post/get不同处理)

本文介绍了一个名为CharacterEncode的拦截器,用于解决在使用Struts2框架时,通过GET和POST方法传入JSON数据时可能出现的乱码问题。通过设置响应的字符集为utf-8,并在请求中进行相应的字符编码转换,确保了数据传输的正确性和一致性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

package com.ewanshang.wenzhou.filter;

import java.io.UnsupportedEncodingException;
import java.util.Iterator;

import javax.servlet.http.HttpServletRequest;

import org.apache.struts2.ServletActionContext;
import org.apache.struts2.StrutsStatics;

import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;

@SuppressWarnings("serial")
public class CharacterEncode extends AbstractInterceptor {

	@Override
	public String intercept(ActionInvocation arg0) throws Exception {
		ActionContext actionContext = arg0.getInvocationContext();     
 	   HttpServletRequest request= (HttpServletRequest) actionContext.get(StrutsStatics.HTTP_REQUEST); 
 	   ServletActionContext.getResponse().setContentType("text/html;charset=utf-8");//解决json传值的乱码问题
 	  System.out.println("Encoding Intercept...");  
 	  /** 
 	   * 此方法体对GET 和 POST方法均可 
 	   */  
 	  if( request.getMethod().compareToIgnoreCase("post")>=0){  
 	      try {  
 	       request.setCharacterEncoding("utf-8");  
 	      } catch (UnsupportedEncodingException e) {    	  
 	       e.printStackTrace();  
 	      }  
 	     }else{              
 	      Iterator iter=request.getParameterMap().values().iterator();  
 	      while(iter.hasNext())  
 	      {  
 	       String[] parames=(String[])iter.next();  
 	       for (int i = 0; i < parames.length; i++) {  
 	        try {  
 	         parames[i]=new String(parames[i].getBytes("iso8859-1"),"utf-8");//此处GBK与页面编码一样  
 	        } catch (UnsupportedEncodingException e) {  
 	         e.printStackTrace();  
 	        }  
 	       }     
 	      }     
 	       }  
 	         return arg0.invoke();  
 	 }   
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值