温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

解决全站字符编码问题--动态代理和静态代理

发布时间:2020-07-09 18:23:02 来源:网络 阅读:739 作者:奔跑吧爽爽 栏目:开发技术

动态代理和静态代理的区别
动态代理是在运行时,将代理类加载到内存中
静态代理是提前把代理类写好,然后再启动项目的时候把代理类加载到内存中

动态代理

public class EncodingFilter implements Filter { public void destroy() { } public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws IOException, ServletException { //0 强转 final HttpServletRequest request = (HttpServletRequest) req; HttpServletResponse response = (HttpServletResponse) resp; //1 post乱码 request.setCharacterEncoding("UTF-8"); //2 使用动态代理增强request HttpServletRequest proxyRequest = (HttpServletRequest)Proxy.newProxyInstance( EncodingFilter.class.getClassLoader(), new Class[] { HttpServletRequest.class } , new InvocationHandler(){ @Override public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { //增强 String methodName = method.getName(); if("getParameter".equals(methodName)){ //args 所有参数 --> getParameter("username"); //1 从tomcat request获得原始数据(乱码) String value = request.getParameter((String)args[0]); //2 如果get请求处理乱码 if("GET".equals(request.getMethod())){ value = new String( value.getBytes("ISO-8859-1") , "UTF-8"); } //3 将结果返回 return value; } //不需要增强的直接执行目标类的方法 return method.invoke(request, args); } }); chain.doFilter(proxyRequest, response); } public void init(FilterConfig fConfig) throws ServletException { } }

静态代理(装饰者模式)

public class EncodingFilter implements Filter { public void destroy() { } public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws IOException, ServletException { //0 强转 HttpServletRequest request = (HttpServletRequest) req; HttpServletResponse response = (HttpServletResponse) resp; //1 post乱码 request.setCharacterEncoding("UTF-8"); //2 使用装饰者增强request MyRequest myRequest = new MyRequest(request); chain.doFilter(myRequest, response); } public void init(FilterConfig fConfig) throws ServletException { } }

/**

  • 设计模式:固定的代码,用于解决固定问题
    • 装饰者:对方法进行增强
      1.确定接口
      2.提供成员变量
      3.构造方法
      4.增强需要的方法
      *5.其他方法默认调用tomcat对应方法即可
  • sun 提供 HttpServletRequest 接口使用装饰者编写默认类,及所有的方法都没有增强的。
    • 之后我们只需要继承即可
  • 增强response对象,提供使用装饰者设计模式编写默认类:HttpServletResponseWrapper
    */

    public class MyRequest extends HttpServletRequestWrapper {
    private HttpServletRequest request; //tomcat request

    public MyRequest(HttpServletRequest request){ super(request); this.request = request; }

    //增强

    @Override
    public String getParameter(String name) {

    //1 直接从tomcat的request获得数据 String value = this.request.getParameter(name); //2 如果是get,处理 // * 请求方式 String method = this.request.getMethod(); if("GET".equals(method)){ try { value = new String( value.getBytes("ISO-8859-1"), "UTF-8"); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } } return value; } }
向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI