Struts2使用拦截器完成权限控制示例
http://aumy2008.iteye.com/blog/146952
Struts2使用拦截器完成权限控制示例
示例需求:
要求用户登录,且必须为指定用户名才可以查看系统中某个视图资源;否则,系统直接转入登陆页面。
一、页面部分
1、登陆页面代码(login.jsp)
- <%@ page language="java" contentType="text/html; charset=GBK"%>
- <%@taglib prefix="s" uri="/struts-tags"%>
- <html>
- <head>
- <title><s:text name="loginPage" /></title>
- </head>
- <body>
- <!-- 使用form标签生成表单元素 -->
- <s:form action="login">
- <s:textfield name="username" label="%{getText('user')}" />
- <s:textfield name="password" label="%{getText('pass')}" />
- <s:submit value="%{getText('login')}" />
- </s:form>
- </body>
- </html>
2、登陆成功页面(welcome.jsp)
- <%@ page language="java" contentType="text/html; charset=GBK"%>
- <%@taglib prefix="s" uri="/struts-tags"%>
- <html>
- <head>
- <title><s:text name="succPage" /></title>
- <s:head />
- </head>
- <body>
- <s:text name="succTip" />
- <br />
- <!-- 欢迎,${sessionScope.user},您已经登录!
- ${sessionScope.pass}-->
- <p />
- <s:a href="show.action">show</s:a>
- <p />
- <s:a href="add.action">add</s:a>
- <p />
- <s:a href="qurey.action">qurey</s:a>
- </body>
- </html>
3、登陆失败页面(error.jsp)
- <%@ page language="java" contentType="text/html; charset=GBK"%>
- <%@taglib prefix="s" uri="/struts-tags"%>
- <html>
- <head>
- <title><s:text name="errorPage" /></title>
- </head>
- <body>
- <s:text name="failTip" />
- <p />
- <s:a href="login.jsp">return</s:a>
- </body>
- </html>
4、和权限有关的几个显示页面
(add.jsp)
- <%@ page language="java" contentType="text/html; charset=GBK"%>
- <%@taglib prefix="s" uri="/struts-tags"%>
- <html>
- <head>
- <title><s:text name="addPage"/></title>
- </head>
- <body>
- <s:text name="addTip"/>
- <p />
- <s:a href="login.jsp">return login</s:a>
- </body>
- </html>
(show.jsp)
- <%@ page language="java" contentType="text/html; charset=GBK"%>
- <%@taglib prefix="s" uri="/struts-tags"%>
- <html>
- <head>
- <title><s:text name="showPage"/></title>
- </head>
- <body>
- <s:text name="showTip"/>
- <p />
- <s:a href="login.jsp">return login</s:a>
- </body>
- </html>
(qurey.jsp)
- <%@ page language="java" contentType="text/html; charset=GBK"%>
- <%@taglib prefix="s" uri="/struts-tags"%>
- <html>
- <head>
- <title><s:text name="qureyPage"/></title>
- </head>
- <body>
- <s:text name="qureyTip"/>
- <p />
- <s:a href="login.jsp">return login</s:a>
- </body>
- </html>
二、Action部分(LoginAction.java)
- public class LoginAction extends ActionSupport {
- private static final long serialVersionUID = 1030294046920869257L;
- private String username;
- private String password;
- // 处理用户请求的execute方法
- public String execute() throws Exception {
- if (isInvalid(getUsername()))
- return INPUT;
- if (isInvalid(getPassword()))
- return INPUT;
- if ((getUsername().equals("mm") || getUsername().equals("aumy"))
- && getPassword().equals("111")) {
- // 通过ActionContext对象访问Web应用的Session
- ActionContext.getContext().getSession().put("user", getUsername());
- ActionContext.getContext().getSession().put("pass", getPassword());
- System.out.println(getUsername() + "----" + getPassword());
- return SUCCESS;
- } else {
- System.out.println(getUsername() + "----" + getPassword());
- return ERROR;
- }
- }
- private boolean isInvalid(String value) {
- return (value == null || value.length() == 0);
- }
- public String add() {
- return SUCCESS;
- }
- public String show() {
- return SUCCESS;
- }
- public String qurey() {
- return SUCCESS;
- }
- public String getUsername() {
- return username;
- }
- public void setUsername(String username) {
- this.username = username;
- }
- public String getPassword() {
- return password;
- }
- public void setPassword(String password) {
- this.password = password;
- }
- }
三、拦截器部分(AuthorityInterceptor.java)
- public class AuthorityInterceptor extends AbstractInterceptor {
- private static final long serialVersionUID = 1358600090729208361L;
- //拦截Action处理的拦截方法
- public String intercept(ActionInvocation invocation) throws Exception {
- // 取得请求相关的ActionContext实例
- ActionContext ctx=invocation.getInvocationContext();
- Map session=ctx.getSession();
- //取出名为user的session属性
- String user=(String)session.get("user");
- //如果没有登陆,或者登陆所有的用户名不是aumy,都返回重新登陆
- if(user!=null && user.equals("aumy")){
- return invocation.invoke();
- }
- //没有登陆,将服务器提示设置成一个HttpServletRequest属性
- ctx.put("tip","您还没有登录,请登陆系统");
- return Action.LOGIN;
- }
- }
四、配置文件部分
(struts.xml)
- <!DOCTYPE struts PUBLIC
- "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
- "http://struts.apache.org/dtds/struts-2.0.dtd">
- <struts>
- <include file="struts-default.xml"/>
- <!--不受权限控制的Action请求配置-->
- <package name="non-authority" extends="struts-default" >
- <action name="login" class="com.aumy.struts.example.LoginAction">
- <result name="input">/login.jsp</result>
- <result name="error">/error.jsp</result>
- <result name="success">/welcome.jsp</result>
- </action>
- <action name="qurey" class="com.aumy.struts.example.LoginAction" method="qurey">
- <result name="success">/qurey.jsp</result>
- </action>
- </package>
- <!--受权限控制的Action请求配置-->
- <package name="authority" extends="struts-default">
- <interceptors>
- <!--定义一个名为authority的拦截器-->
- <interceptor
- class="com.aumy.struts.example.intercepter.AuthorityInterceptor"
- name="authority"/>
- <!--定义一个包含权限检查的拦截器栈-->
- <interceptor-stack name="mydefault">
- <!--配置内建默认拦截器-->
- <interceptor-ref name="defaultStack"/>
- <!--配置自定义的拦截器-->
- <interceptor-ref name="authority"/>
- </interceptor-stack>
- </interceptors>
- <default-interceptor-ref name="mydefault" />
- <!--定义全局Result-->
- <global-results>
- <result name="login">/login.jsp</result>
- </global-results>
- <action name="show" class="com.aumy.struts.example.LoginAction"
- method="show">
- <result name="success">/show.jsp</result>
- </action>
- <action name="add" class="com.aumy.struts.example.LoginAction"
- method="add">
- <result name="success">/add.jsp</result>
- </action>
- </package>
- </struts>
(struts.properties)
- struts.custom.i18n.resources=message.messageResouce
(web.xml)
- <?xml version="1.0" encoding="UTF-8"?>
- <web-app version="2.4"
- xmlns="http://java.sun.com/xml/ns/j2ee"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
- http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
- <display-name>Struts test</display-name>
- <filter>
- <filter-name>struts2</filter-name>
- <filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class>
- </filter>
- <filter-mapping>
- <filter-name>struts2</filter-name>
- <url-pattern>/*</url-pattern>
- </filter-mapping>
- <welcome-file-list>
- <welcome-file>login.jsp</welcome-file>
- </welcome-file-list>
- </web-app>
五、国际化资源文件(messageResouce.properties)
- loginPage=Login Page
- errorPage=Error Page
- succPage=Welcome Page
- failTip=Sorry,You can't log in!
- succTip=welcome,you has logged in!
- user=User Name
- pass=User Pass
- login=Login
- showPage=Show Page
- showTip=show a example!
- addPage=Add Page
- addTip=add a example!
- qureyPage=Qurey Page
- qureyTip=qurey a example!
Struts2使用拦截器完成权限控制示例的更多相关文章
- Struts2基础-4-2 -struts拦截器实现权限控制案例+ 模型驱动处理请求参数 + Action方法动态调用
1.新建项目,添加jar包到WEB-INF目录下的lib文件夹,并添加到builde path里面 整体目录结构如下 2.新建web.xml,添加struts2核心过滤器,和默认首页 <?xml ...
- 6、Struts2拦截器实现权限控制
1.创建如下项目结果 2.在com.entity包下创建 package com.entity; public class User { private String name; private St ...
- struts自己定义拦截器--登录权限控制
说明:该自己定义的拦截器实现用户登录的权限控制. login.jsp--->LoginAction--重定向-->MainAction--->main.jsp 一.1.整体的步骤: ...
- JavaWeb框架_Struts2_(三)---->Struts2的拦截器
2. Struts2的拦截器(使用拦截器实现权限控制) 2.1 拦截器的概述 拦截器是Struts2的核心组成部分,它可以动态的拦截Action调用的对象,类似与Servlet中的过滤器.Struts ...
- 简单理解Struts2中拦截器与过滤器的区别及执行顺序
简单理解Struts2中拦截器与过滤器的区别及执行顺序 当接收到一个httprequest , a) 当外部的httpservletrequest到来时 b) 初始到了servlet容器 传递给一个标 ...
- struts2之拦截器
1. 为什么需要拦截器 早期MVC框架将一些通用操作写死在核心控制器中,致使框架灵活性不足.可扩展性降低, Struts 2将核心功能放到多个拦截器中实现,拦截器可自由选择和组合,增强了灵活性,有利于 ...
- (六)Struts2的拦截器
一.简介 拦截器体系是struts2重要的组成部分.正是大量的内建拦截器完成了该框架的大部分操作. 比如params拦截器将请求参数解析出来,设置Action的属性.servletConfig拦截器负 ...
- Struts2 自定义拦截器
自定义拦截器(权限管理),包含了对ajax和表单请求的拦截 package com.interceptor; import java.io.IOException; import java.io.Pr ...
- struts2总结六: Struts2的拦截器
一.Struts2的系统结构图
随机推荐
- 洛谷 P1063 能量项链
题目描述 在Mars星球上,每个Mars人都随身佩带着一串能量项链.在项链上有N颗能量珠.能量珠是一颗有头标记与尾标记的珠子,这些标记对应着某个正整数.并且,对于相邻的两颗珠子,前一颗珠子的尾标记一定 ...
- writeToFile 读写文件问题
关于 writeToFile 读写文件:当字典中键值对以 Model(例如:studentModel)为值时发现 Dictionary 调用 writeToFile 方法无法生成 plist 文件,经 ...
- 异步IO模型和Overlapped结构
.NET中的 Overlapped 类 异步IO模型和Overlapped结构(http://blog.itpub.net/25897606/viewspace-705867/) 数据结构 OVERL ...
- EWS小记
前段时间和同事完成了一个Exchange 2010 OWA的改造版,他狠狠的把网易邮箱抄了一把,而我则狠狠的被EWS坑了一把.今天打开项目粗略看了一下,发现很多东西都有点记不起来了,思细极恐,决定还是 ...
- bzoj 4004: [JLOI2015]装备购买 拟阵 && 高消
4004: [JLOI2015]装备购买 Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 337 Solved: 139[Submit][Status ...
- zoj 3716
题目给我们四个点,要求我们以这四个点为圆心,形成四个相切的圆: 求他们的半径和: 首先我们从他们中间选出三个点,以这三个点为圆心的三个圆最大可以两两互相相切: 证明:假设这三个圆的半径分别为a,b,c ...
- 用 JMH 检测 Lambdas 序列化性能
本文将介绍如何进行 Java Lambdas 序列化性能检测.Lambdas 的重要性以及 Lambdas 在分布式系统中的应用. Lambdas 表达式是 Java 8 中万众期待的新特性,其若干用 ...
- SQL分组查询GroupBy
一.分组查询1.使用group by进行分组查询在使用group by关键字时,在select列表中可以指定的项目是有限制的,select语句中仅许以下几项:〉被分组的列〉为每个分组返回一个值得表达式 ...
- 练习C之SELECT形式的非阻塞IO
呵呵,理解得不深,但毕竟手打全版,且无错.但select.h不知何处找头文件, 粘下来作个记录. POLL,EPOLL感觉代码类似,只是函数和系统实现不一样,,EPOLL目前最合理的.定位精确,算法复 ...
- POJ2301+水~~~~~~
有比这更水的么.............. #include<stdio.h> int main(){ int n; scanf("%d",&n); while ...