版本: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>
- <formaction="login.action"method="post">
- User:<inputtype="text"name="username"><br>
- Passoword:<inputtype="password"name="password"><br>
- <inputtype="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>
- <ahref="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;
- publicclass 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;
- publicclass LoginAction extends ActionSupport{
- private String username;
- private String password;
- public String getPassword() {
- return password;
- }
- publicvoid setPassword(String password) {
- this.password = password;
- }
- public String getUsername() {
- return username;
- }
- publicvoid setUsername(String username) {
- this.username = username;
- }
- privateboolean 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;
- publicclass 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;
- publicclass 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中,拦截器(Interceptor)扮演着至关重要的角色,它允许开发者在动作执行前后插入自定义逻辑,如日志记录、权限验证等。在本案例中,我们将深入探讨如何使用Struts2拦截器实现登录权限验证,同时结合...
本示例将聚焦于如何在Struts2中实现一个自定义拦截器。 首先,我们需要了解拦截器在Struts2中的作用。拦截器是AOP(面向切面编程)的一个核心概念,它允许开发者在动作执行前后插入额外的逻辑,如日志记录、权限...
在上面的例子中,`myInterceptor`是自定义拦截器的引用。 3. **运行与测试**:运行项目,当请求`myAction`时,会先执行`myInterceptor`中的`intercept()`方法,然后执行Action,最后返回结果。 ### 三、全局...
总之,"struts2自定义类型转换、拦截器实例练习"将引导你通过实际操作掌握Struts2的核心功能,加深对MVC模式的理解,提高你在Java web开发中的技能水平。在完成这个实例后,你将具备使用Struts2框架构建复杂应用程序...
本实例可能会展示如何使用Struts2的拦截器进行权限控制,确保只有登录用户才能访问特定的页面或功能。 除了以上核心功能,这个实例可能还涵盖了其他相关知识点,如JSP、Servlet、数据库操作(可能使用JDBC或ORM框架...
自定义拦截器是Struts2提供的一种功能强大且灵活的机制,通过自定义拦截器可以实现各种复杂的业务逻辑,例如身份验证、权限管理、日志记录等。自定义拦截器只需继承Struts2提供的抽象拦截器类,并override其中的方法...
Struts2是一个强大的Java web开发框架,它提供了一种组织和控制MVC(模型-视图-控制器)架构的方式...通过自定义拦截器和合理配置,我们可以实现诸如日志记录、事务管理、权限验证等多种业务需求,大大提升了开发效率。
### Struts2拦截器实例——登录校验 #### 概述 在Web应用开发中,登录验证是一项重要的功能。为了确保只有已登录的用户才能访问特定的资源或页面,通常会采用拦截器来实现这一需求。本文档将详细介绍如何在Struts2...
接下来,我们需要在Struts2的配置文件(通常为struts.xml)中声明并配置这个自定义拦截器。这样,当Action被调用时,Struts2会自动应用这个拦截器。 ```xml <struts> ...
在这个“structs2拦截器实例2-权限验证拦截器”的主题中,我们将深入探讨如何使用Struts2拦截器进行权限验证。 首先,拦截器是基于AOP(面向切面编程)的概念实现的,它们可以插入到请求处理流程中,在Action执行前...
拦截器实例通常是线程安全的,因此对于多线程环境,Struts2会为每个请求创建新的ActionInvocation实例,但拦截器实例是共享的。 **6. 文件98struts201** 根据提供的文件名"98struts201",这可能是指一个包含Struts2...
在Struts2框架中,拦截器扮演着至关重要的角色,它们是实现业务逻辑、验证、日志记录等功能的核心组件。下面将详细探讨Struts2拦截器的源码及其工作原理。 首先,理解拦截器的定义:拦截器是AOP(面向切面编程)的...
在“struts2拦截器权限判断实例”中,我们将创建一个自定义的拦截器来检查用户是否具有访问特定资源的权限。这个拦截器可能包括以下几个步骤: 1. **创建拦截器类**: 首先,我们需要创建一个实现了`Interceptor`...
在这个例子中,我们创建了一个名为`loggingInterceptor`的自定义拦截器,并定义了一个拦截器栈`myStack`,将`loggingInterceptor`插入到默认栈`defaultStack`前面。最后,我们设置`default-interceptor-ref`为`...
在文章"Struts2拦截器原理分析实例"中,作者通过一个具体的应用场景,展示了如何配置和使用拦截器来实现特定的功能,比如日志记录或权限验证。通过阅读这篇博客,我们可以更直观地理解拦截器的工作方式和价值。 ...
开发自定义拦截器需要继承`org.apache.struts2.interceptor.Interceptor`接口或者`com.opensymphony.xwork2.interceptor.AbstractInterceptor`抽象类,并实现`intercept()`方法。在这个方法中,你可以添加自己的业务...
核心拦截器是Struts2框架的重要组成部分,它们允许开发者在动作执行前后插入自定义逻辑,以实现如日志、权限验证、数据校验等常见功能。下面将详细讲解Struts2的核心拦截器以及如何在项目中使用它们。 1. **Struts2...
1. **创建拦截器**:编写自定义拦截器类,实现必要的权限检查逻辑。 2. **配置拦截器**:在Struts2配置文件中注册拦截器,并将其添加到相应的Action路径下。 3. **处理结果**:拦截器根据权限检查结果决定是否调用下...
了解了拦截器的基本原理后,我们可以通过`Struts2.x 拦截器.avi`这个视频文件深入学习Struts2拦截器的实现细节,比如如何编写自定义拦截器、如何配置拦截器链、如何处理异常等。`readme.txt`可能是关于这个主题的...