激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|編程技術|正則表達式|

服務器之家 - 編程語言 - JAVA教程 - struts2如何使用攔截器進行用戶權限控制實例

struts2如何使用攔截器進行用戶權限控制實例

2020-09-27 15:50阿木俠 JAVA教程

本篇文章主要介紹了struts2如何使用攔截器進行用戶權限控制實例,非常具有實用價值,需要的朋友可以參考下

大多數網站會設置用戶權限,如過濾非法用戶,用戶不登錄時不能進行訪問,或者設置訪問的權限,如部分內容僅對VIP開放等等,這些權限的控制都可以用struts2中的攔截器來實現。

下面通過一個簡單的Demo來模擬這種用戶權限控制的實現流程,設定三種不同身份的用戶,commen為普通用戶,VIP為會員用戶,還有一種admin為管理員。

先看一下Demo的整體結構:

struts2如何使用攔截器進行用戶權限控制實例

首先搭建struts2框架的開發環境(前面博客中有介紹),環境搭建完之后又再看一看如何配置struts.xml:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
 "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
 "http://struts.apache.org/dtds/struts-2.3.dtd">
<struts>
 <package name="hello" extends="struts-default" namespace="/">
  <interceptors>
   <interceptor name="testInterceptor" class="org.interceptor.InterceptorTest"></interceptor>
   <!-- 一個攔截器棧中可以定義多個攔截器 -->
   <interceptor-stack name="testStack">
    <interceptor-ref name="testInterceptor" />
    <interceptor-ref name="defaultStack" />
   </interceptor-stack>
  </interceptors>
  <!--全局結果處理 -->
  <global-results>
   <result name="error">/Error.jsp</result>
  </global-results>
  <action name="login" class="org.interceptor.LoginAction">
   <result>/WEB-INF/pages/index.jsp</result>
  </action>
  <action name="admin" class="org.interceptor.LoginAction" method="AdminExecute">
   <interceptor-ref name="testStack"></interceptor-ref>
   <result>/WEB-INF/pages/admin.jsp</result>
  </action>
  <action name="vip" class="org.interceptor.LoginAction" method="vipExecute">
   <interceptor-ref name="testStack"></interceptor-ref>
   <result>/WEB-INF/pages/vipUser.jsp</result>
  </action>
  <action name="commen" class="org.interceptor.LoginAction" method="commenExecute">
   <interceptor-ref name="testStack"></interceptor-ref>
   <result>/WEB-INF/pages/commen.jsp</result>
  </action>
 </package>
</struts>

 其中,<global-results></global-results>是全局的result,有很多時候一個<result>可供很多<action>使用,這時可以使用<global-results>標簽來定義全局的<result>。執行順序:當一個Action返回的String沒有相應的<result>與之對應,Struts2就會查找全局的<result>,所以本次模擬測試中不符合條件被攔截的請求都會轉到error.jsp。

Action類,不做處理,全部放行,讓攔截器處理:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
public class LoginAction implements SessionAware{
 @SuppressWarnings("unused")
 private String username;
 private Map<String,Object> session;
 public void setUsername(String username) {
  this.username = username;
  session.put("username", username);
 }
 public void setSession(Map<String, Object> session) {
  // TODO Auto-generated method stub
  this.session = session;
 }
  
 public String AdminExecute(){
  return "success";
 }
 public String vipExecute(){
  return "success";
 }
 public String commenExecute(){
  return "success";
 }
 public String execute(){
  return "success";
 }
}

Inteceptor(攔截器類):

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
public class LoginAction implements SessionAware{
 @SuppressWarnings("unused")
 private String username;
 private Map<String,Object> session;
 public void setUsername(String username) {
  this.username = username;
  session.put("username", username);
 }
 public void setSession(Map<String, Object> session) {
  // TODO Auto-generated method stub
  this.session = session;
 }
  
 public String AdminExecute(){
  return "success";
 }
 public String vipExecute(){
  return "success";
 }
 public String commenExecute(){
  return "success";
 }
 public String execute(){
  return "success";
 }
}

 只是 模擬攔截器的實現思路,沒有持久層的數據,這里的方法是使用invocation.getProxy().getActionName()方法來獲取struts.xml中配置的action名稱,和用戶表單提交的名稱做對比,如果輸入的用戶名是以action名開頭的,就放行,否則攔截。

登錄jsp:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
<%@ 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" rel="external nofollow"
 <title>login</title>
 </head>
 
 <body>
 <form action="login.action">
  <input type="text" name="username"/>
  <input type="password" name="password"/>
  <input type="submit" value="login">
 </form>
 </body>
</html>

攔截后跳轉頁:

?
1
2
3
<body>
 <h4>你的權限不足,請先升級權限...</h4>
 </body>

訪問資源代碼:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<%@ 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" rel="external nofollow" >
 <title>index</title>
 </head>
 
 <body>
 <a href="admin.action" rel="external nofollow" >admin</a><br/>
 <a href="vip.action" rel="external nofollow" >vip</a><br/>
 <a href="commen.action" rel="external nofollow" >commen</a>
 </body>
</html>

其余admin.jsp等界面沒有內容,只是為了區分實現跳轉頁面不同。

運行結果:

使用commen角色登錄:

struts2如何使用攔截器進行用戶權限控制實例

點擊VIP以及admin跳轉鏈接時:

struts2如何使用攔截器進行用戶權限控制實例

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:http://blog.csdn.net/weixin_36380516/article/details/71429800?utm_source=tuicool&utm_medium=referral

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产精品久久久久久久四虎电影 | 色猫av| 久久免费视频一区二区三区 | av在线网站观看 | 欧美一级毛片大片免费播放 | 亚洲人成中文字幕在线观看 | 亚洲第一成网站 | 国产成人精品区一区二区不卡 | 国产亚洲精品久久777777 | 欧美精品一区二区三区在线 | 蜜桃视频在线观看免费 | 好吊色37pao在线观看 | 成人免费一区二区三区在线观看 | 免费一级欧美在线观看视频 | 一区二区三级视频 | 日本免费靠逼视频 | 欧美成人免费一区二区三区 | 久久露脸国语精品国产91 | 精品一区二区免费视频视频 | 亚洲一区动漫 | 免费看日韩av| 爱性久久久久久久 | av成人在线播放 | 国产91亚洲精品一区二区三区 | 亚洲成人在线免费观看 | 亚洲一区在线国产 | 免费看黄色一级大片 | 欧美亚洲一级 | 欧洲成人av | av在线收看 | 日韩黄色片网站 | 免费一级特黄做受大片 | 午夜精品在线视频 | 日本黄肉网站在线观看 | 羞羞视频.www在线观看 | 一区二区三区四区高清视频 | 成人福利免费在线观看 | 国产免费一区二区三区最新不卡 | 在线一级片 | 久国久产久精永久网页 | 久久天堂 |