SSH配置(一)-struts2(convention插件零配置)

一、新建工程

操作:eclipse下File->New->Dynamic Web Project




项目目录如下


二、Struts2配置如下

1、拷贝struts2所需的jar包到WebConten->WEB-INF->lib下



2、在src下添加action类文件和在WEB-INF下添加web页面

在src下添加action类文件



UserAction.java类代码:

package com.jjh.ssh.web;

import org.apache.struts2.convention.annotation.Namespace;
import org.apache.struts2.convention.annotation.Result;

import com.opensymphony.xwork2.ActionSupport;

@Namespace("/user")
@Result(name = "userlist", location = "userlist.jsp")

public class UserAction extends ActionSupport {
	
	/**
	 * 获取用户列表
	 * @return
	 * @throws Exception
	 */
	public String listUsers() throws Exception{
		System.out.println("-------listusers action begin-------");
		
		System.out.println("-------listusers action end-------");
		
		return "userlist";
	}
	
}

②在WEB-INF下添加view->user->userlist.jsp


userlist.jsp代码:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
	userlist for this.
</body>
</html>

3、在src目录下添加struts.xml 和 struts.properties



①struts.xml内容

<?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>
	
</struts>

②struts.properties

#struts
struts.action.extension=do
struts.ognl.allowStaticMethodAccess=true

#struts-dev
struts.devMode=true
struts.i18n.reload=true

#struts-convention
struts.convention.action.packages=com.jjh
struts.convention.package.locators=web 
struts.convention.result.path=/WEB-INF/view
#struts-convention-dev
struts.convention.classes.reload=true

4、配置web.xml

添加struts2的Filter过滤器

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
	xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
	id="WebApp_ID" version="3.0">
	<display-name>SSHFW</display-name>

	<!-- struts2过滤器 -->
	<filter>
		<filter-name>struts2</filter-name>
		<filter-class>
			org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter
		</filter-class>
	</filter>

	<!-- 过滤器链 -->
	<filter-mapping>
		<filter-name>struts2</filter-name>
		<url-pattern>/*</url-pattern>
	</filter-mapping>

	<welcome-file-list>
		<welcome-file>index.jsp</welcome-file>
	</welcome-file-list>
</web-app>


三、部署到tomcat,运行。

在浏览器中输入http://localhost:8080/SSHFW/user/user!listUsers.do

请求结果显示如下:



  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Struts2中使用Convention插件配置权限拦截器,可以按照以下步骤操作: 1. 在`struts.xml`文件中配置一个拦截器栈,例如: ```xml <struts> <constant name="struts.convention.action.packages" value="com.example.actions"/> <package name="default" extends="struts-default"> <interceptors> <interceptor-stack name="myStack"> <interceptor-ref name="authInterceptor"/> <interceptor-ref name="defaultStack"/> </interceptor-stack> </interceptors> </package> </struts> ``` 2. 定义一个权限拦截器`authInterceptor`,例如: ```xml <struts> <constant name="struts.convention.action.packages" value="com.example.actions"/> <package name="default" extends="struts-default"> <interceptors> <interceptor-stack name="myStack"> <interceptor-ref name="authInterceptor"/> <interceptor-ref name="defaultStack"/> </interceptor-stack> <interceptor name="authInterceptor" class="com.example.interceptors.AuthInterceptor"/> </interceptors> </package> </struts> ``` 3. 在`com.example.interceptors.AuthInterceptor`类中实现权限验证逻辑,例如: ```java public class AuthInterceptor extends AbstractInterceptor { @Override public String intercept(ActionInvocation invocation) throws Exception { // 获取当前请求的Action和方法名 String actionName = invocation.getProxy().getActionName(); String methodName = invocation.getProxy().getMethod(); // 根据Action和方法名判断是否需要进行权限验证 boolean needAuth = checkNeedAuth(actionName, methodName); // 如果需要权限验证,则进行验证 if (needAuth) { // TODO: 实现权限验证逻辑 // 如果权限验证不通过,则返回一个特定的结果 return "authFailed"; } else { // 如果不需要权限验证,则直接执行Action return invocation.invoke(); } } private boolean checkNeedAuth(String actionName, String methodName) { // TODO: 根据Action和方法名判断是否需要进行权限验证 return true; } } ``` 4. 在需要进行权限验证的Action类或方法上添加`@InterceptorRefs`注解,指定使用的拦截器栈,例如: ```java @Namespace("/admin") @InterceptorRefs("myStack") public class AdminAction extends ActionSupport { @Action("/listUsers") public String listUsers() { // TODO: 实现列出用户列表的业务逻辑 return SUCCESS; } } ``` 这样,当用户访问`/admin/listUsers`时,就会先被`authInterceptor`拦截器拦截,进行权限验证,如果验证通过,则执行`listUsers`方法,否则返回`authFailed`结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值