Struts2自定义拦截器实例—登陆权限验证
版本:struts2.1.6
此实例实现功能:用户需要指定用户名登陆,登陆成功进入相应页面执行操作,否则返回到登陆页面进行登陆,当直接访问操作页面(登陆后才能访问的页面)时则不允许,须返回登陆页面。
代码如下:
一、页面
login.jsp
- <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
- <html>
- <head>
- <title>yuewei'Login</title>
- <!--
- <link rel="stylesheet" type="text/css" href="styles.css" mce_href="styles.css">
- -->
- </head>
- <body>
- <form action="login.action" method="post">
- User:<input type="text" name="username"><br>
- Passoword:<input type="password" name="password"><br>
- <input type="submit" value="submit">
- </form>
- </body>
- </html>
welcome.jsp
- <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
- <html>
- <head>
- <title> yuewei's Welcome</title>
- <!--
- <link rel="stylesheet" type="text/css" href="styles.css" mce_href="styles.css">
- -->
- </head>
- <body>
- <h1>登录成功后显示此页面</h1>
- <a href="show.action" mce_href="show.action">show</a>
- </body>
- </html>
show.jsp
- <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
- <html>
- <head>
- <title>yuewei's Show</title>
- <!--
- <link rel="stylesheet" type="text/css" href="styles.css" mce_href="styles.css">
- -->
- </head>
- <body>
- Show This Page
- 登录后执行此页面<br>
- </body>
- </html>
二、Action
LoginFormAction
- package com.ywjava.action;
- import com.opensymphony.xwork2.ActionSupport;
- public class LoginFormAction extends ActionSupport {
- public String exexcute() {
- return "success";
- }
- }
LoginAction
- package com.ywjava.action;
- import com.opensymphony.xwork2.ActionContext;
- import com.opensymphony.xwork2.ActionSupport;
- import com.ywjava.utils.Constants;
- public class LoginAction extends ActionSupport{
- private String username;
- private String password;
- public String getPassword() {
- return password;
- }
- public void setPassword(String password) {
- this.password = password;
- }
- public String getUsername() {
- return username;
- }
- public void setUsername(String username) {
- this.username = username;
- }
- private boolean isInvalid(String value) {
- return (value == null || value.length() == 0);
- }
- public String execute(){
- System.out.println(username);
- System.out.println(password);
- if (isInvalid(getUsername()))
- return INPUT;
- if (isInvalid(getPassword()))
- return INPUT;
- if(this.getUsername().equals("yuewei")&& this.getPassword().equals("yuewei")){
- ActionContext.getContext().getSession().put(Constants.USER_SESSION,getUsername());
- ActionContext.getContext().getSession().put(Constants.PASS,getPassword());
- return "success";
- }
- return "error";
- }
- }
ShowAction
- package com.ywjava.action;
- import com.opensymphony.xwork2.ActionSupport;
- public class ShowAction extends ActionSupport {
- public String execute() {
- return "success";
- }
- }
三、拦截器
- package com.ywjava.interceptot;
- import java.util.Map;
- import com.opensymphony.xwork2.Action;
- import com.opensymphony.xwork2.ActionContext;
- import com.opensymphony.xwork2.ActionInvocation;
- import com.opensymphony.xwork2.interceptor.AbstractInterceptor;
- import com.ywjava.utils.Constants;
- public class LoginInterceptor extends AbstractInterceptor {
- @Override
- public String intercept(ActionInvocation invocation) throws Exception {
- // 取得请求相关的ActionContext实例
- ActionContext ctx = invocation.getInvocationContext();
- Map session = ctx.getSession();
- String user = (String) session.get(Constants.USER_SESSION);
- // 如果没有登陆,或者登陆所有的用户名不是yuewei,都返回重新登陆
- if (user != null && user.equals("yuewei")) {
- System.out.println("test");
- return invocation.invoke();
- }
- ctx.put("tip", "你还没有登录");
- return Action.LOGIN;
- }
- }
四 struts.xml
- <?xml version="1.0" encoding="UTF-8"?>
- <!DOCTYPE struts PUBLIC
- "-//Apache Software Foundation//DTD Struts Configuration 2.1//EN"
- "http://struts.apache.org/dtds/struts-2.1.dtd">
- <struts>
- <package name="authority" extends="struts-default">
- <!-- 定义一个拦截器 -->
- <interceptors>
- <interceptor name="authority"
- class="com.ywjava.interceptot.LoginInterceptor">
- </interceptor>
- <!-- 拦截器栈 -->
- <interceptor-stack name="mydefault">
- <interceptor-ref name="defaultStack" />
- <interceptor-ref name="authority" />
- </interceptor-stack>
- </interceptors>
- <!-- 定义全局Result -->
- <global-results>
- <!-- 当返回login视图名时,转入/login.jsp页面 -->
- <result name="login">/login.jsp</result>
- </global-results>
- <action name="loginform"
- class="com.ywjava.action.LoginFormAction">
- <result name="success">/login.jsp</result>
- </action>
- <action name="login" class="com.ywjava.action.LoginAction">
- <result name="success">/welcome.jsp</result>
- <result name="error">/login.jsp</result>
- <result name="input">/login.jsp</result>
- </action>
- <action name="show" class="com.ywjava.action.ShowAction">
- <result name="success">/show.jsp</result>
- <!-- 使用此拦截器 -->
- <interceptor-ref name="mydefault" />
- </action>
- </package>
- </struts>
Struts2自定义拦截器实例—登陆权限验证相关推荐
- Struts2自己定义拦截器实例—登陆权限验证
版本号:struts2.1.6 此实例实现功能:用户须要指定username登陆,登陆成功进入对应页面运行操作,否则返回到登陆页面进行登陆,当直接訪问操作页面(登陆后才干訪问的页面)时则不同意,须返回 ...
- struts2自定义拦截器(登陆校验拦截器)
需求:有些页面需要先登录才可以访问,如果没有登陆就跳转到login.jsp去登陆 此案例为访问login方法的时候不拦截,只有把user放到session中才可以访问别的方法 web.xml 配置拦截 ...
- struts2自定义拦截器一——模拟登陆权限验证
1.http://localhost:8083/struts2/user.jsp 表示用户已登陆,存放session对象 2.http://localhost:8083/struts2/quit.js ...
- Struts2 自定义拦截器
所属栏目:AbstractInterceptor 如果要编写自定义拦截器,那么可以只用实现com.opensymphony.xwork2.interceptor.Interceptor这个接口即可. ...
- Struts2 自定义拦截器(easy example)
要自定义拦截器需要实现com.opensymphony.xwork2.interceptor.Interceptor接口: 新建一个MyIntercept package com.action;imp ...
- Struts2自定义拦截器
1. 需求 自定义拦截器实现,用户登录的访问控制. 2. 定义拦截器类 1 public class LoginInterceptor extends AbstractInterceptor 2 { ...
- struts2自定义拦截器并配置拦截器使其生效
首先编写一个struts2的拦截器,要继承 MethodFilterInterceptor 并获取其中的方法 package star.july.d_interceptor;import com.op ...
- Struts2 自定义拦截器(方法拦截器)
转自:http://05061107cm.iteye.com/blog/365504 struts2系统自带了很多拦截器,有时需要我们自己定义,一般有两种方式: 一.实现Interceptor接口 J ...
- 使用mybatis plus自定义拦截器,实现数据权限
需求 为了增强程序的安全性,需要在用户访问数据库的时候进行权限判断后选择性进行判断是否需要增强sql,来达到限制低级别权限用户访问数据的目的. 根据业务需要,这里将角色按照数据范围做权限限定.比如,角 ...
最新文章
- Android Studio——字体大小的修改
- oracle对比两列数据_oracle与mysql对同一张表 两列数据的某一字段进行值的交换
- dailybuild
- 零基础入门Python I/O:从print函数开始
- 浅析NVR主流芯片方案
- 判断字符串中是否包含Emoji表情代码
- 对Spring Boot还陌生吗?
- position之属性
- 四元数与欧拉角的转换
- 支持Linux系统双网卡ARM平台AM3352/AM3354
- NCURSES程序设计之皇后问题
- mysql 从大到小排序
- 深圳超美海边烧烤场 深圳户外烧烤攻略
- vuex的基本应用(vuex的购物车案例)
- svm matlab 图像分割,勇哥的视觉实验:SVM分类器(二) 支持向量机的应用例子,图片分割...
- 通过ffmpeg实时读取宇视摄像头的高清帧流数据,并保存4张图片进行4合一照片的生成。
- XMind商业思维导图——市场营销!
- 电脑文件误删除如何恢复?可以快速找回
- mit app中计算器制作程序_“个税APP”,防不胜防啊
- Java编程思想读书笔记——第十章:内部类
热门文章
- 【Linux 内核 内存管理】优化内存屏障 ① ( barrier 优化屏障 | 编译器优化 | CPU 执行优化 | 优化屏障源码 barrier 宏 )
- 【Android 逆向】Linux 文件权限 ( Linux 权限简介 | 系统权限 | 用户权限 | 匿名用户权限 | 读 | 写 | 执行 | 更改组 | 更改用户 | 粘滞 )
- 【Java 虚拟机原理】垃圾回收算法 ( 设置 JVM 命令参数输出 GC 日志 | GC 日志输出示例 | GC 日志分析 )
- 【MATLAB】二维绘图 ( 绘制二维图像 | 设置图像样式 )
- 【RecyclerView】 三、RecyclerView 布局 ( 线性布局管理器 LinearLayoutManager )
- 【Android 应用开发】Paint 渲染 之 BitmapShader 位图渲染 ( 渲染流程 | CLAMP 拉伸最后像素 | REPEAT 重复绘制图片 | MIRROR 绘制反向图片 )
- 实践作业3 (2017-12-4)
- 构建ASP.NET MVC5+EF6+EasyUI 1.4.3+Unity4.x注入的后台管理系统(61)-如何使用框架来开发?...
- 通用用户权限管理系统组件V3.8功能改进说明 - 行政审批流程组件的改进
- Windows Phone 7 开发资源汇总