java 拦截器的作用?

java 拦截器的作用?转载注明出处~1.拦截器都是做什么的?做的事和请求和响应有关。(比如前端的css或者一些加载的路径都会走这个拦截器)访问日志(记录访客的ip,来源),在线统计人数,字符集转换,身份验证可以不破坏你的业务逻辑在你的业务之外做一些其他事情~.过滤器(Filter):所谓过滤器顾名思义是用来过滤的,Java的过滤器能够为我们提供系统级别的过滤,也就是说,能过滤所有的web请求,…

大家好,又见面了,我是你们的朋友全栈君。

转载注明出处~

1.拦截器都是做什么的?

做的事和请求和响应有关。(比如前端的css或者一些加载的路径都会走这个拦截器)

访问日志(记录访客的ip,来源),在线统计人数,字符集转换,身份验证

可以不破坏你的业务逻辑  在你的业务之外做一些其他事情~

.过滤器(Filter):所谓过滤器顾名思义是用来过滤的,Java的过滤器能够为我们提供系统级别的过滤,也就是说,能过滤所有的web请求,
这一点,是拦截器无法做到的。在Java Web中,你传入的request,response提前过滤掉一些信息,或者提前设置一些参数,然后再传入servlet或
者struts的action进行业务逻辑,比如过滤掉非法url(不是login.do的地址请求,如果用户没有登陆都过滤掉),或者在传入servlet或者struts
的action前统一设置字符集,或者去除掉一些非法字符(聊天室经常用到的,一些骂人的话)。filter 流程是线性的,url传来之后,检查之后,
可保持原来的流程继续向下执行,被下一个filter, servlet接收。
    2.监听器(Listener):Java的监听器,也是系统级别的监听。监听器随web应用的启动而启动。Java的监听器在c/s模式里面经常用到,它
会对特定的事件产生产生一个处理。监听在很多模式下用到,比如说观察者模式,就是一个使用监听器来实现的,在比如统计网站的在线人数。
又比如struts2可以用监听来启动。Servlet监听器用于监听一些重要事件的发生,监听器对象可以在事情发生前、发生后可以做一些必要的处理。
    3.拦截器(Interceptor):java里的拦截器提供的是非系统级别的拦截,也就是说,就覆盖面来说,拦截器不如过滤器强大,但是更有针对性。
Java中的拦截器是基于Java反射机制实现的,更准确的划分,应该是基于JDK实现的动态代理。它依赖于具体的接口,在运行期间动态生成字节码。
拦截器是动态拦截Action调用的对象,它提供了一种机制可以使开发者在一个Action执行的前后执行一段代码,也可以在一个Action执行前阻止其
执行,同时也提供了一种可以提取Action中可重用部分代码的方式。在AOP中,拦截器用于在某个方法或者字段被访问之前,进行拦截然后再之前或
者之后加入某些操作。java的拦截器主要是用在插件上,扩展件上比如 Hibernate Spring Struts2等,有点类似面向切片的技术,在用之前先要在
配置文件即xml,文件里声明一段的那个东西。

转自:https://www.cnblogs.com/austinspark-jessylu/p/7453302.html

 

通过项目的调试,在自己的项目中,拦截器是要取一下token的,然后从redis中获取到用户的信息。

比如:

  private void conversionUserInfo(HttpServletRequest request, String authToken) {
        try {
            Object obj = redisService.get(authToken);
            if (null != obj) {
                UserInfo userInfo = (UserInfo) obj;
                request.setAttribute("requestUserName", "LOGIN_" + userInfo.getUserName());
            } else {
                request.setAttribute("requestUserName", "LOGIN_UNKNOWN_USER");
            }
        } catch (Exception e) {
            log.error("[BaseInterceptor] 失败; error message = {}", e.getMessage());
        }
    }

在preHandle之后,便要进行postHandle也就是把刚刚set进去的属性,打印出来~

 比如打印一下请求开始的时间,还有从预处理到preHandle的时间。

打印日志可以追加一下请求的URI 还有请求的类型,是POST还是GET等等

private StringBuilder prepareRequestContentLog(HttpServletRequest request, String username, Long timeDiff) {
        StringBuilder content = new StringBuilder();
        content.append("[");
        content.append(username);
        content.append("] ");
        if (timeDiff != null) {
            content.append("[");
            content.append(timeDiff);
            content.append("ms] ");
        }
        content.append(request.getRequestURI());
        String method = request.getMethod();
        if ("POST".equals(method)) {
            appendPostParams(content, request);
        } else if ("GET".equals(method)) {
            appendGetParams(content, request);
        }
        return content;
    }

 

2. 获取POST请求中的参数,并打印(使用request.getParameterMap();)

 private void appendPostParams(StringBuilder content, HttpServletRequest request) {
        Map parameterMap = request.getParameterMap();
        if (parameterMap != null && parameterMap.size() != 0) {
            content.append("?");
            for (Object key : parameterMap.keySet()) {
                content.append(key);
                content.append("=");
                content.append(request.getParameterValues(key.toString())[0]);
                content.append("&");
            }
            content.deleteCharAt(content.length() - 1);
        }
    }

3. 获取GET请求的参数,并打印(使用request.getQueryString();)

private void appendGetParams(StringBuilder content, HttpServletRequest request) {
        String queryString = request.getQueryString();
        if (!StringUtils.isBlank(queryString)) {
            content.append("?");
            content.append(queryString);
        }
    }

4. StringBuffer的delete方法与deleteCharAt的区别

delete方法与deleteCharAt两个方法都是用来删除StringBuffer字符串指定索引字符的方法,

delete(int  a,int  b)有两个参数,使用时删除索引从a开始(包含a)到b(不包含b)的所有字符;

deleteCharAt(int  a)只有一个参数,使用时删除索引为a的字符;

5. @Nullable ModelAndView modelAndView

  • @NonNull可以标注在方法、字段、参数之上,表示对应的值不可以为空
  • @Nullable注解可以标注在方法、字段、参数之上,表示对应的值可以为空

ModelAndView :

在我们项目中这一项是为null,也没有用到。 这个是以前会用到的东西 现在HTML和接口分离。也就不怎么用了

ModelAndView包含两部分:一个View和一个Model
View由setViewName()方法来决定,决定让ViewResolver去哪里找View文件,并找到是哪个jsp文件;
Model由addObject()方法来决定,它的本质是java的HashMap,键值对;

核心就是Object\LinkedHashMap,完全是Java的标准容器(对象)。

参考:https://www.cnblogs.com/zhuchuanliang/p/7784772.html

6. HttpServletRequest 请求中都有什么?剖析?

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/144819.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • HTTP请求错误400、401、402、403、404、405、406、407、412、414、500、501、502解析

    HTTP请求错误400、401、402、403、404、405、406、407、412、414、500、501、502解析

  • 基于Apache的反向代理服务器

    基于Apache的反向代理服务器众所周知Apache是目前最优秀的HTTP服务器。实际上它不仅能当作服务器使用,也能够被用来架设代理服务器。本文就如何使用Apache架设HTTP代理服务器进行说明。本文将基于Win32版的Apache2.0.47进行说明。以前的Apache1.x版配置方法稍有不同,但这里不作说明。 首先是Apache的安装。从http://www.apache.org上下载Apache的安装

    2022年10月20日
  • 查看apk签名信息

    查看apk签名信息

  • 虚拟货币二维码骗局_数字货币交易骗局套路

    虚拟货币二维码骗局_数字货币交易骗局套路最近,网络上出现了一种新的诈骗模式,对象仍然是比特币。原理很简单,因为比特币等虚拟货币的地址非常长,每次交易如果纯靠手输会比较麻烦,因此很多人都会选择将…

  • 快速理解线程锁

    快速理解线程锁线程锁线程锁真的好麻烦啊!!!找了几篇博客发现写的都不一样相关联内容太多不容易理解所以现在需要理清什么是线程锁应用场景怎么用优缺点1.什么是线程锁机制多线程可以同时运行多个任务但是当多个线程同时访问共享数据时,可能导致数据不同步,甚至错误!so,不使用线程锁,可能导致错误啰嗦两句:比如你在银行取钱的同时你女朋友用支付宝取钱…

  • javaEE与java的区别

    javaEE与java的区别好程序员Java培训分享JavaEE与Java的区别,有不少想要转行做程序员的朋友都会有一个疑问,JavaEE和Java是不是一种语言,这两者之间又有什么区别呢?  Java一共分为三个版本:JavaSE(标准版)、JavaEE(企业版)以及JavaME(微型版)。  其中JavaSE就是大家所熟知的Java根底,JavaEE在企业最常用的地方就是网站PC端的开发,而JavaME常用于移动端开发,现在熟悉的安卓系统便是用JavaME开发的。  Java既可以被编译,也可以被解说。经过

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号