您好,登錄后才能下訂單哦!
這篇文章將為大家詳細(xì)講解有關(guān)Struts2框架攔截器怎么在Java中使用,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。
具體內(nèi)容如下
在看攔截器的小例子的前我們先來看看sturts2的原理
struts2自己是有攔截器的,通過攔截器可以攔截用戶請求,并作出處理
攔截器作用有很多,譬如:
1.Action里面有個(gè)屬性,這個(gè)屬性我想在action執(zhí)行之前改成別的值,可以用攔截器解決。
2.比如每個(gè)人執(zhí)行action之前,我可以查看他們有沒有這個(gè)權(quán)限執(zhí)行這個(gè)action。
如果不設(shè)置攔截器,你要在每種action方法之前設(shè)置判定程序,非常繁瑣。
攔截器interceptor體現(xiàn)了一種編程理念,叫做AOP(面向切面編程)
實(shí)例1:使用token攔截器控制重復(fù)提交
token是用來解決下面的問題:
一旦有人通過表單提交數(shù)據(jù),在提交表單的時(shí)候頁面提交速度太慢,用戶一直不停的刷新,如果不做一種機(jī)制防止他刷新的話,那么數(shù)據(jù)庫中就會(huì)多出好多垃圾數(shù)據(jù)。
表單提交一般都要寫成post(第一種解決方式,瀏覽器會(huì)提醒你是否重復(fù)提交)
攔截器解決方法:
struts2定義了一個(gè)攔截器(interceptor)叫--token
token的意思是“令牌”,你要提交數(shù)據(jù),我先發(fā)給你一個(gè)令牌,你的令牌要是和我能對上,你就提交,對不上就不允許提交
token為什么可以防止重復(fù)提交?
答:當(dāng)訪問界面時(shí),在服務(wù)器那邊的session里面,生成一個(gè)隨機(jī)數(shù),然后再把隨機(jī)數(shù)寫到form里,提交數(shù)據(jù)時(shí)session就會(huì)被帶到服務(wù)器去。提交完成后session里面的值被清空,再次重復(fù)提交的時(shí)候,發(fā)現(xiàn)此token值在session不存在,說明已經(jīng)被提交過了,這個(gè)時(shí)候就會(huì)顯示友好界面提示用戶。
實(shí)現(xiàn)代碼:
struts.xml:
<package name="test" namespace="/javaee" extends="struts-default"> <action name="pinput" class="cn.edu.hpu.action.PinputAction"> <result>/input.jsp</result> </action> <action name="person" class="cn.edu.hpu.action.PersonAction"> <result>/addOK.jsp</result> <interceptor-ref name="defaultStack"></interceptor-ref> <interceptor-ref name="token"></interceptor-ref> <result name="invalid.token">/error.jsp</result> </action> </package>
PersonAction.java:
package cn.edu.hpu.action; import com.opensymphony.xwork2.ActionSupport; public class PersonAction extends ActionSupport { private String name; private int age; @Override public String execute() throws Exception { System.out.println("a person added!"); return super.execute(); } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } }
input.jsp:
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>" rel="external nofollow" > <title>My JSP 'input.jsp' starting page</title> </head> <body> <form action="<%=basePath %>javaee/person" method="post"> name:<input name="name"> age:<input name="age"> <input type="submit" value="add"> </form><br/> </body> </html>
addOK.jsp:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>My JSP 'addOK.jsp' starting page</title> </head> <body> add ok!! <br/> </body> </html>
error.jsp:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>My JSP 'error.jsp' starting page</title> </head> <body> 嚴(yán)禁做重復(fù)的事?。?! <br> </body> </html>
結(jié)果:
填寫name與age之后,會(huì)跳入界面addOK.jsp,控制臺會(huì)輸出a person added!
返回再次提交時(shí),就會(huì)跳轉(zhuǎn)到error.jsp界面,無法重復(fù)提交
如果在表單中加<s:token></s:token>,則會(huì)看到源碼:
<input type="hidden" name="struts.token.name" value="struts.token" /> <input type="hidden" name="struts.token" value="PZOQNKARYVQYDEVGNKTWFBF17735K6AI" /> <!--相當(dāng)于生成了一個(gè)隨機(jī)數(shù)-->
所原理是:在提交頁面形成了一個(gè)token,這個(gè)token在服務(wù)器端對應(yīng)的session里面已經(jīng)有了,當(dāng)我一點(diǎn)提交的時(shí)候,由于加了<interceptor-ref name="token"></interceptor-ref>(
token的攔截器),服務(wù)器就會(huì)幫我攔截,看看session里面有沒有token的值,如果之前沒有提交,session里面是有這個(gè)token值的,如果上次提交過了,session就會(huì)將token值清除掉。當(dāng)發(fā)現(xiàn)頁面的token值在服務(wù)器的session中找不到時(shí),服務(wù)器發(fā)現(xiàn)出錯(cuò)了,重定向到error.jsp,顯示錯(cuò)誤信息
實(shí)例2:自定義攔截器
struts.xml:
<pre name="code" class="html"><pre name="code" class="html"><pre name="code" class="html"><pre name="code" class="html"><?xml version="1.0" encoding="GBK" ?> <!--指定struts2配置文件的DTD信息--> <!DOCTYPE struts PUBLIC "-//apache Software Foundation//DTD Struts Configuation 2.0//EN" "http://struts.apache.org/dtds/struts-2.0.dtd"> <!-- struts 是struts2配置文件的根元素--> <struts> <constant name="struts.devMode" value="true"></constant> <constant name="struts.i18n.encoding" value="UTF-8"></constant> <!--允許靜態(tài)方法的執(zhí)行--> <constant name="struts.ognl.allowStaticMethodAccess" value="true"></constant> <package name="test" namespace="/" extends="struts-default"> <interceptors> <interceptor name="my" class="cn.edu.hpu.interceptor.MyInterceptor"></interceptor> </interceptors> <action name="test" class="cn.edu.hpu.action.TestAction"> <result>/test.jsp</result> <interceptor-ref name="my"></interceptor-ref> <interceptor-ref name="defaultStack"></interceptor-ref> </action> </package> </struts>
TestAction.java:
package cn.edu.hpu.action; import com.opensymphony.xwork2.ActionSupport; public class TestAction extends ActionSupport{ @Override public String execute() throws Exception { // TODO Auto-generated method stub return super.execute(); } }
MyInterceptor.java:
package cn.edu.hpu.interceptor; import com.opensymphony.xwork2.ActionInvocation; import com.opensymphony.xwork2.interceptor.Interceptor; public class MyInterceptor implements Interceptor{ public void destroy() { } public void init() { } //寫好了一個(gè)攔截(計(jì)算了一個(gè)action運(yùn)行的時(shí)間) public String intercept(ActionInvocation invocation) throws Exception { long start=System.currentTimeMillis(); String r=invocation.invoke(); long end=System.currentTimeMillis(); System.out.println("Action Time="+(end-start)); return r; } }
訪問:http://localhost:8080/struts2_LanJieQi/test后
控制臺輸出:
Action Time=200
關(guān)于Struts2框架攔截器怎么在Java中使用就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。