java攔截器的代碼 java interceptor攔截器

求JAVA struts攔截器配置代碼

!-- 整合Spring --

為西城等地區用戶提供了全套網頁設計制作服務,及西城網站建設行業解決方案。主營業務為網站建設、成都做網站、西城網站設計,以傳統方式定制建設網站,并提供域名空間備案等一條龍服務,秉承以專業、用心的態度為用戶提供真誠的服務。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!

constant name="struts.objectFactory" value="spring"/

!-- 開啟使用開發模式,詳細錯誤提示 --

constant name="struts.devMode" value="false"/

!-- 指定每次請求到達,重新加載資源文件 --

!-- constant name="struts.i18n.reload" value="true"/ --

!-- 指定每次配置文件更改后,自動重新加載 --

!-- constant name="struts.configuration.xml.reload" value="true"/ --

!-- 指定XSLT Result使用樣式表緩存 --

!-- constant name="struts.xslt.nocache" value="true"/ --

!-- 設置該應用使用的解碼集 --

constant name="struts.i18n.encoding" value="UTF-8"/constant

!-- struts2 中默認提供了一些訪問靜態成員的方式,但是默認是關閉的,所以應該在struts2的配置文件中先設置 --

constant name="struts.ognl.allowStaticMethodAccess" value="true"/

include file="struts-default.xml" /

include file="struts-action.xml" /

---------------------------------------------------

struts-action.xml:

package name="com.lj.actions" extends="struts-default"

!-- 攔截器-驗證用戶登錄 --

interceptors

!-- interceptor name="check" class ="com.lj.interceptor.CheckLoginInterceptor" / --

interceptor name="authority" class="com.lj.interceptor.MyFilterInterceptor"/ !--上面自定義的攔截器類--

interceptor-stack name="myDefault"

interceptor-ref name="authority" !-- 引用攔截器 --

param name="includeMethods"queryByAll,queryByWhere,queryByAdId,queryByAdminAll,queryByWhere2CSV,adCheck,adDelete,delete,save,update,accredit,showInfo,appCheck/param !-- 設置需要攔截的方法,多個以逗號隔開 --

/interceptor-ref

interceptor-ref name="defaultStack"/interceptor-ref

/interceptor-stack

/interceptors

default-interceptor-ref name="myDefault"/default-interceptor-ref

!-- 全局跳轉頁面 --

global-results

result name="error_limit"/jsp/admin/error_limit.jsp/result

result name="list_sys_login"/jsp/admin/list_sys_login.jsp/result

/global-results

!-- 廣告管理——廣告審核 --

action name="AdCheck" class="com.lj.actions.AdCheckAction"

result name="list_ad_sh"/jsp/admin/list_ad_sh.jsp/result

/action

!-- 廣告管理——廣告列表 --

action name="AdList" class="com.lj.actions.AdListAction"

result name="list_ad_ls"/jsp/admin/list_ad_ls.jsp/result

/action

Java實現的攔截器

攔截器在在流行的開源框架中很常見 依賴的技術就是Java的動態代理

理解攔截器的核心原理對理解這些開源框架的體系結構至關重要

下面以一個簡單的模型的來說明攔截器的實現的一般方法

模型分為以下模塊

業務組件 是被代理和被攔截的對象

代理處理器 實現了InvocationHandler接口的一個對象

代理對象 Proxy對象

攔截器 普通的JavaBean 在調用業務方法的之前或者之后會自動攔截并執行自己的一些方法

客戶端 執行業務處理的入口

以下是模型的實現

一 業務組件 分為業務接口和業務類

/**

* 業務組件接口

*/

public interface BusinessInterface {

public void doSomething();

}

/**

* 業務組件

*/

public class BusinessClass implements BusinessInterface{

public void doSomething() {

System out println( 業務組件BusinessClass方法調用:doSomething() );

}

}

二 代理處理器 包含了業務對象綁定動態代理類的處理 并實現了 InvocationHandler接口的invoke方法

import java lang reflect InvocationHandler;

import java lang reflect Method;

import java lang reflect Proxy;

/**

* 動態代理處理器工具

*/

public class DynamicProxyHandler implements InvocationHandler {

private Object business;??? //被代理對象

private InterceptorClass interceptor = new InterceptorClass();??? //攔截器

/**

* 動態生成一個代理類對象 并綁定被代理類和代理處理器

*

* @param business

* @return 代理類對象

*/

public Object bind(Object business) {

this business = business;

return Proxy newProxyInstance(

//被代理類 的ClassLoader

business getClass() getClassLoader()

//要被代理 的接口 本方法返回對象會自動聲稱實現了這些接口

business getClass() getInterfaces()

//代理處理 器對象

this);

}

/**

* 代理要調用的方法 并在方法調用前后調用連接器的方法

*

* @param proxy? 代理類對象

* @param method 被代理的接口方法

* @param args?? 被代理接口方法的參數

* @return 方法調用返回的結果

* @throws Throwable

*/

public Object invoke(Object proxy Method method Object[] args) throws Throwable {

Object result = null;

interceptor before();

result=method invoke(business args);

interceptor after();

return null;? //To change body of implemented methods use File | Settings | File Templates

}

}

三 攔截器 普通的JavaBean 在調用業務方法的之前或者之后會自動攔截并執行自己的 一些方法

/**

* 攔截器

*/

public class InterceptorClass {

public void before(){

System out println( 攔截器InterceptorClass方法調用:before()! );

}

public void after(){

System out println( 攔截器InterceptorClass方法調用:after()! );

}

}

四 模擬客戶端 執行業務處理的入口

/**

* 客戶端

*/

public class Client {

public static void main(String args[]) {

DynamicProxyHandler handler = new DynamicProxyHandler();

BusinessInterface business = new BusinessClass();

BusinessInterface businessProxy = (BusinessInterface) handler bind(business);

businessProxy doSomething();

}

lishixinzhi/Article/program/Java/hx/201311/27143

求JAVA攔截器代碼和配置文件!就是每次請求action之前都會執行配置的java類

strut2的攔截器的一個例子。。。

攔截器定義,,這里是一個判斷超時的攔截器功能

interceptors

interceptor name="Timeout" class="com.myproject.util.TimeOutInterceptor"/

/interceptors

action定義。。。。。。。。。。。

action name="cf*" method="{1}" class="com.myproject.action.user.ConfigAction"

!-- 引用自定義的攔截器 --

interceptor-ref name="Timeout"

param name="excludeMethods"

Switch,UpdCss !-- action中的這兩個方法生效 --

/param

/interceptor-ref

interceptor-ref name="basicStack"/ !-- struts 內置的默認攔截器 --

result name="config"/user/config.jsp/result

/result

//攔截器的實現。。。。。。。

package com.myproject.util;

import com.opensymphony.xwork2.ActionInvocation;

import com.opensymphony.xwork2.interceptor.MethodFilterInterceptor;

import java.util.Map;

/**

* 通用攔截器,判斷用戶超時

* @author maodrc

*/

public class TimeOutInterceptor extends MethodFilterInterceptor {

@Override

protected String doIntercept(ActionInvocation ai) throws Exception {

Map sessionMap = ai.getInvocationContext().getSession();

String username = (String) sessionMap.get("username");

if (com.maxneting.util.Util.isNull(username)) {

return "timeout";

} else {

return ai.invoke();

}

}

}

Java實現攔截HTTP請求的幾種方式

在Java的服務端開發當中,攔截器是很常見的業務場景,這里對Java開發當中幾種常見的攔截器的實現方式進行記錄和分析。案例說明基于Spring Boot環境。

一:實現javax.servlet.Filter接口(使用過濾器方式攔截請求)

import org.springframework.stereotype.Component;import javax.servlet.*;import java.io.IOException;import java.util.Date;@Componentpublic class TimeInterceptor implements Filter {@Overridepublic void init(FilterConfig filterConfig) throws ServletException {System.out.println("time filter init");}@Overridepublic void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {System.out.println("time filter start");long start = new Date().getTime();filterChain.doFilter(servletRequest, servletResponse);System.out.println("time filter 耗時:"+(new Date().getTime()-start));System.out.println("time filter finish");}@Overridepublic void destroy() {System.out.println("time filter destroy");}}

如使用@Compent注解聲明不需要加入其它配置即可使得攔截器生效,但是默認攔截/*,會攔截所有請求。

二:使用@Bean注入自定義攔截器,依然上面的代碼,去掉@Compent注解,創建TimeWebConfig配置類:

import org.springframework.boot.web.servlet.FilterRegistrationBean;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import java.util.ArrayList;import java.util.List;@Configurationpublic class TimeWebConfig {@Beanpublic FilterRegistrationBean timeFilter(){FilterRegistrationBean registrationBean = new FilterRegistrationBean();TimeInterceptor interceptor = new TimeInterceptor();registrationBean.setFilter(interceptor);ListString urls = new ArrayList();urls.add("/user/*");registrationBean.setUrlPatterns(urls);return registrationBean;}}

上面這兩種攔截請求的實現是基于JavaEE提供的Filter接口實現的,缺點在于,該攔截器實際上是一個過濾器,執行代碼的方法doFilter只提供了request,response等參數,當請求進入被過濾器攔截的時候,我們并不知道這個請求是由哪個控制器的哪個方法來執行的。

三:使用springMVC提供的攔截器,實現org.springframework.web.servlet.HandlerInterceptor接口:

創建自定義的攔截器:

import org.springframework.stereotype.Component;import org.springframework.web.method.HandlerMethod;import org.springframework.web.servlet.HandlerInterceptor;import org.springframework.web.servlet.ModelAndView;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import java.util.Date;@Componentpublic class MyInterceptor implements HandlerInterceptor {@Overridepublic boolean preHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object handler) throws Exception {System.out.println("preHandler");System.out.println(((HandlerMethod) handler).getBean().getClass().getName());System.out.println(((HandlerMethod) handler).getMethod().getName());httpServletRequest.setAttribute("start", new Date().getTime());return true;}@Overridepublic void postHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, ModelAndView modelAndView) throws Exception {System.out.println("postHandler");Long start = (Long) httpServletRequest.getAttribute("start");System.out.println("time interceptor 耗時:"+(new Date().getTime()-start));}@Overridepublic void afterCompletion(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) throws Exception {System.out.println("afterCompletion");Long start = (Long) httpServletRequest.getAttribute("start");System.out.println("time interceptor 耗時:"+(new Date().getTime()-start));System.out.println("ex is:"+e);}}

創建配置類:

import org.springframework.beans.factory.annotation.Autowired;import org.springframework.context.annotation.Configuration;import org.springframework.web.servlet.config.annotation.InterceptorRegistry;import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;@Configurationpublic class WebConfig extends WebMvcConfigurerAdapter {@Autowiredprivate MyInterceptor interceptor;@Overridepublic void addInterceptors(InterceptorRegistry registry) {registry.addInterceptor(interceptor).addPathPatterns("/user/*").excludePathPatterns("/blog/*");}}

此種方式的攔截器當中我們能夠獲取攔截的請求對應的類和方法的相關信息,缺點在于該handler對象無法獲取具體執行方法的參數信息。

四:利用Spring的切面(AOP)實現攔截器:

引入jar包:

!-- --dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-aop/artifactId/dependency

創建切片類:

import org.aspectj.lang.ProceedingJoinPoint;import org.aspectj.lang.annotation.Around;import org.aspectj.lang.annotation.Aspect;import org.springframework.stereotype.Component;import java.util.Date;@Aspect@Componentpublic class TimeAspect {@Around("execution(* com.qinker.controller.UserController.*(..))")public Object handlerControllerMethod(ProceedingJoinPoint point) throws Throwable {System.out.println("time aspect start");long start = new Date().getTime();Object[] args = point.getArgs();for (Object obj : args) {System.out.println("arg is:"+obj);}Object obj = point.proceed();//具體方法的返回值System.out.println("aspect 耗時:"+(new Date().getTime()-start));System.out.println("time aspect end");return obj;}}

aspectj基于AOP實現的攔截器功能十分強大,具體詳解請參考spring官網網站的文檔。

java有什么注解前置前攔截

本文將用簡潔的代碼構建一個springboot的攔截器。攔截器的使用很簡單,定義一個自己的攔截器,向配置中添加一下就可以使用。為了方便,之后又引入了注解。

目錄和概述

概述

假設需求:訪問項目的controller是都要進行"token驗證",除了某些像登錄之類的方法。

項目結構:

TokenInterceptor.java 自定義攔截器

InterceptorConfig.java 添加攔截器進入項目

NoNeedToken.java 自定義注解

TestController.java 測試接口

1、自定義攔截器

在 TokenInterceptor.java 中輸入以下代碼,以下的代碼將生成一個在請求到達controller前進行攔截的攔截器

import com.alibaba.fastjson.JSONObject;

import org.springframework.lang.Nullable;

import org.springframework.stereotype.Component;

import org.springframework.web.servlet.HandlerInterceptor;

import org.springframework.web.servlet.ModelAndView;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

import java.io.PrintWriter;

import java.util.Arrays;

import java.util.List;

@Component

public class TokenInterceptor implements HandlerInterceptor {undefined

// 假設現在的token有如下數據

List tokenList = Arrays.asList("111", "222", "333");

// 這個方法是在訪問接口之前執行的,我們只需要在這里寫驗證登陸狀態的業務邏輯,就可以在用戶調用指定接口之前驗證登陸狀態了

@Override

public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {undefined

// 設置返回為json格式,使用UTF-8

response.setCharacterEncoding("UTF-8");

response.setContentType("application/json; charset=utf-8");

String token = request.getHeader("token");

PrintWriter out;

// 之后寫你的判斷邏輯:return true是通過攔截器,可以繼續訪問controller,return false是不通過

if (token == null || !tokenList.contains(token)) {undefined

// 如果失敗了返回{state:"false", msg:"token is null or wrong"}

JSONObject res = new JSONObject();

res.put("state","false");

res.put("msg","token is null or wrong");

out = response.getWriter();

out.append(res.toString());

return false;

}

// 否則返回true 進入controller

return true;

}

public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable ModelAndView modelAndView) throws Exception {undefined

}

public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable Exception ex) throws Exception {undefined

}

}

————————————————

版權聲明:本文為CSDN博主「魔王別囂張」的原創文章,遵循CC 4.0 BY-SA版權協議,轉載請附上原文出處鏈接及本聲明。

原文鏈接:

java如何實現攔截短信功能

java里的攔截器是動態攔截Action調用的對象,它提供了一種機制可以使開發者在一個Action執行的前后執行一段代碼,也可以在一個Action

執行前阻止其執行,同時也提供了一種可以提取Action中可重用部分代碼的方式。在AOP中,攔截器用于在某個方法或者字段被訪問之前,進行攔截

然后再之前或者之后加入某些操作。目前,我們需要掌握的主要是Spring的攔截器,Struts2的攔截器不用深究,知道即可。

2,攔截器的原理

大部分時候,攔截器方法都是通過代理的方式來調用的。Struts2的攔截器實現相對簡單。當請求到達Struts2的ServletDispatcher時,Struts2

會查找配置文件,并根據配置實例化相對的攔截器對象,然后串成一個列表(List),最后一個一個的調用列表中的攔截器。Struts2的攔截器是可

插拔的,攔截器是AOP的一個實現。Struts2攔截器棧就是將攔截器按一定的順序連接成一條鏈。在訪問被攔截的方法或者字段時,Struts2攔截器鏈

中的攔截器就會按照之前定義的順序進行調用。

3,自定義攔截器的步驟

第一步:自定義一個實現了Interceptor接口的類,或者繼承抽象類AbstractInterceptor。

第二步:在配置文件中注冊定義的攔截器。

第三步:在需要使用Action中引用上述定義的攔截器,為了方便也可以將攔截器定義為默認的攔截器,這樣在不加特殊說明的情況下,所有的

Action都被這個攔截器攔截。

4,過濾器與攔截器的區別

過濾器可以簡單的理解為“取你所想取”,過濾器關注的是web請求;攔截器可以簡單的理解為“拒你所想拒”,攔截器關注的是方法調用,比如攔截

敏感詞匯。

4.1,攔截器是基于java反射機制來實現的,而過濾器是基于函數回調來實現的。(有人說,攔截器是基于動態代理來實現的)

4.2,攔截器不依賴servlet容器,過濾器依賴于servlet容器。

4.3,攔截器只對Action起作用,過濾器可以對所有請求起作用。

4.4,攔截器可以訪問Action上下文和值棧中的對象,過濾器不能。

4.5,在Action的生命周期中,攔截器可以多次調用,而過濾器只能在容器初始化時調用一次。

5,Spring攔截器

網站名稱:java攔截器的代碼 java interceptor攔截器
本文路徑:http://m.kartarina.com/article40/hgjdho.html

成都網站建設公司_創新互聯,為您提供網頁設計公司網站內鏈小程序開發微信公眾號品牌網站設計關鍵詞優化

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

小程序開發
主站蜘蛛池模板: 亚洲午夜无码久久久久小说| 潮喷大喷水系列无码久久精品 | 亚洲av无码一区二区三区乱子伦| 无码精品国产dvd在线观看9久| 日日摸日日踫夜夜爽无码| 精品无码一区在线观看| 无码办公室丝袜OL中文字幕| 一本大道无码日韩精品影视_| 人妻无码一区二区三区AV| 无码一区二区三区AV免费| 无码激情做a爰片毛片AV片| 特级无码a级毛片特黄| 亚洲最大天堂无码精品区| 国产午夜无码专区喷水| 精品久久久无码中字| 亚洲AV成人无码网天堂| 国产精品无码无卡在线播放| 国产精品无码aⅴ嫩草| 亚洲另类无码专区丝袜| 免费无码毛片一区二区APP| 亚洲国产精品无码久久久秋霞2 | 午夜精品久久久久久久无码| 丰满熟妇乱又伦在线无码视频| 亚洲精品无码AV中文字幕电影网站| 国产aⅴ无码专区亚洲av| 亚洲色无码专区一区| 无码中文字幕av免费放dvd| 人妻丰满熟妇aⅴ无码| 亚洲午夜福利精品无码| 真人无码作爱免费视频| 国产精品无码久久综合网| 国模无码一区二区三区| 内射精品无码中文字幕| 亚洲人成人无码.www石榴 | 亚洲综合最新无码专区| 无码av大香线蕉伊人久久| 国产福利无码一区在线| 人妻系列无码专区久久五月天 | 久久亚洲精品无码AV红樱桃| 亚洲熟妇无码八AV在线播放| 国产成人亚洲综合无码精品|