国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

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

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - 防止未登錄用戶操作—基于struts2攔截器的簡單實現

防止未登錄用戶操作—基于struts2攔截器的簡單實現

2021-01-16 11:22逐兔郎 Java教程

下面小編就為大家帶來一篇防止未登錄用戶操作—基于struts2攔截器的簡單實現。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

一般,我們的web應用都是只有在用戶登錄之后才允許操作的,也就是說我們不允許非登錄認證的用戶直接訪問某些頁面或功能菜單項。我還記得很久以前我的做法:在某個jsp頁面中查看session中是否有值(當然,在用戶登錄邏輯中會將用戶名或者用戶對象存入session中),如果session中用戶信息為空,那么redirect 到登錄頁面。然后在除了登錄頁面外的其它所有需要驗證用戶已登錄的頁面引入這個jsp 。

比如,我們將檢查用戶是否登錄的代碼放入一個jsp頁面中,如 checkUser.jsp

?
1
2
3
4
5
6
7
8
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
 Object username = session.getAttribute("username");
 if(null == username){
     
     response.sendRedirect("login.jsp");
 }
%>

登錄頁面為 login.jsp

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
 <head>
 <title>登錄頁面</title>
 
 </head>
 
 <body>
 <h1>用戶登錄</h1>
        用戶名:<input type="text" name="username" /><br />
        密碼:<input type="text" name="pwd" />
 </body>
</html>

假設登錄成功后跳轉到菜單頁面 menu.jsp

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
 <head>
 <%@ include file="checkUser.jsp" %>
 <title>菜單頁</title>
 </head>
 
 <body>
 <h1>菜單1</h1> <br />
 <h1>菜單2</h1> <br />
 <h1>菜單3</h1> <br />
 <h1>菜單4</h1> <br />
 </body>
</html>

在其中引入了 checkUser.jsp ,這樣當用戶沒有經過登錄而試圖訪問menu.jsp 頁面時就會被強制轉到 login.jsp 頁面。

以上這種方法當然是可行的,可是太過丑陋和麻煩。后來,我學到可以把除了登錄頁面外的 jsp 或html 頁面放到 WEB-INF 目錄下, 這樣用戶就無法直接在瀏覽器中敲url 來訪問頁面了。可是,如果有人通過某種方式得知我們的action 名和方法名了呢?難道我們要在action的每個方法中,檢查用戶是否登錄嗎?這樣子做光是想一想就覺得很蠢。好在我們有struts2 攔截器

先來看看怎樣實現。

我們寫一個攔截器類,讓它繼承 MethodFilterInterceptor。

?
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
36
37
38
39
40
41
/**
 * @Title: LoginInterceptoe.java
 * @Description: 攔截非登錄用戶請求
 * @author ThinkPad
 * @version 1.0
 * @date 2014年8月2日
 */
package com.exam.interceptor;
 
import com.exam.utils.Constants;
import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.MethodFilterInterceptor;
 
/**
 * @author ThinkPad
 *
 */
public class LoginInterceptor extends MethodFilterInterceptor{
 
    /**
     *
     */
    private static final long serialVersionUID = -4409507846064552966L;
 
 
    /* (non-Javadoc)
     * @see com.opensymphony.xwork2.interceptor.MethodFilterInterceptor#doIntercept(com.opensymphony.xwork2.ActionInvocation)
     */
    @Override
    protected String doIntercept(ActionInvocation invoker) throws Exception {
        // TODO Auto-generated method stub
 
        Object loginUserName = ActionContext.getContext().getSession().get(Constants.USERNAME);
        if(null == loginUserName){
            return Constants.VIEW_LOGIN; // 這里返回用戶登錄頁面視圖
        }
        return invoker.invoke();
    }
 
}

在struts.xml 文件中 填入:

?
1
2
3
4
5
6
7
8
9
10
11
<interceptors>
      <interceptor name="loginInteceptor" class="com.exam.interceptor.LoginInterceptor" />
      <interceptor-stack name="loginStack">
        <interceptor-ref name="loginInteceptor">
         <param name="excludeMethods">goLogin,login</param>
        </interceptor-ref>
        <interceptor-ref name="defaultStack"></interceptor-ref>
      </interceptor-stack>
</interceptors>
    
<default-interceptor-ref name="loginStack" />

其中,<param name="excludeMethods">goLogin,login</param> 配置的過濾方法,意思是攔截器對其中的方法不起作用。在我這里, goLogin 是跳轉到登錄頁面的方法。login 是驗證用戶名和密碼的方法,在其中會將通過驗證的用戶名放入session中。沒錯,這就是我們需要做的全部事情了,是不是很方便呢?

我在這里稍微總結下:

1、在struts2 中,所有的攔截器都會繼承 Interceptor 這個接口。

2、攔截器寫好之后要在 struts.xml 文件中配置,如果該攔截器是用來攔截某個action的,那么,就在該action 的result 后面放入該攔截器。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<struts>&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp; <package&nbsp;name="struts2"&nbsp;extends="struts-default">&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <interceptors>&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <interceptor&nbsp;name="myinterceptor"&nbsp;class="com.interceptor.MyInterceptor">&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <param&nbsp;name="hello">world</param>&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </interceptor>&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </interceptors>&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <action&nbsp;name="register"&nbsp;class="com.test.action.RegisterAction"&nbsp;>&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <result&nbsp;name="input">/register.jsp</result>&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <result&nbsp;name="success">/success.jsp</result>&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <interceptor-ref&nbsp;name="myinterceptor"></interceptor-ref>&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </action>&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp; </package>&nbsp;&nbsp;
&nbsp;<struts>&nbsp;

3、如果我們沒有添加攔截器,struts2 會為我們添加默認攔截器。而如果我們指定了攔截器,我們自己的攔截器就會取代默認的攔截器,那么我們就不能享受默認攔截器提供的一些功能。所以,一般我會把默認攔截器也加上。例如,在以上配置項中,action 里面再加上<interceptor-ref name="defaultStack"></interceptor-ref>

4、Interceptor 接口有三個方法:init 、 destroy、intercept 。但一般我們不關心 init 和 destroy 方法。所以struts2 為我們提供了一個簡化的攔截器類:AbstractInterceptor ,它實現了init 和 destroy 方法,我們只需實現 intercept 方法。

5、關于攔截器棧。可以把攔截器棧看成是一個“大”攔截器,里面由若干個攔截器組成。把它當成一個攔截器一樣的引用。

6、方法過濾攔截器,需要繼承 MethodFilterInterceptor 類(也就是我們這里示例使用的攔截器類的做法)。你可以指定該攔截器攔截哪些方法(使用<param name="includeMethods">method1,method2</param>
),也可以指定該攔截器不去攔截哪些方法(<param name="excludeMethods">method1,method2</param>)

以上這篇防止未登錄用戶操作—基于struts2攔截器的簡單實現就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持服務器之家。

原文鏈接:http://blog.csdn.net/zhutulang/article/details/38351629

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 成人午夜性a一级毛片免费看 | 欧美一区在线视频 | 成年人免费观看在线视频 | 女人高潮视频网站 | 天堂资源最新在线 | 人人澡人人爽 | 国产乱来视频 | 国产中文视频 | 91嫩草国产露脸精品国产 | 狠久久| 久久国产精品无码网站 | av一区二区三区免费观看 | 久久国产精品一区二区三区 | 国产日韩欧美高清 | 欧美一区二区三区在线视频 | 国产精品成人一区二区三区夜夜夜 | 午夜精品福利在线观看 | 欧美成人精品高清视频在线观看 | 日韩在线精品强乱中文字幕 | 日韩视频在线观看 | 欧美一级在线 | 日本中文字幕在线观看 | 日韩午夜在线视频 | 伊人最新网址 | 亚洲视频综合 | 日韩成人av电影在线观看 | 日韩精品一区二区在线观看 | 日韩中文视频 | 日本不卡免费新一二三区 | 99精品视频一区二区三区 | 亚洲综合婷婷 | 欧美一级二级视频 | 欧美日韩亚洲国产精品 | 国产一区二区欧美 | 91久久精品国产 | 欧美第一页 | 黄色精品网站 | 日韩精品一区二区在线观看 | 欧美一级看片a免费观看 | 亚洲国产精品一区二区久久 | 色视频www在线播放国产人成 |