Struts2—->action

Struts2—->action

Action

 

具体视图的返回可以由用户自己定义的Action来决定,具体的手段是根据返回的字符串找到对应的配置项,来决定视图的内容

一、具体Action的实现
1、可以是一个普通的java类,里面有public String execute方法即可

package com.ncepu.struts;

public class Action1 {
	public String execute()
	{
		System.out.print("在普通类中定义execute()方法");
		return("success");
	}


}

2、或者实现Action接口

package com.ncepu.struts;

import com.opensymphony.xwork2.Action;

public class Action2 implements Action {


	public String execute() throws Exception {
	System.out.print("实现Action接口");
		return "success";
	}
}

3、不过最常用的是从ActionSupport继承,好处在于可以直接使用Struts2封装好的方法

package com.ncepu.struts;

import com.opensymphony.xwork2.ActionSupport;

public class Action3 extends ActionSupport {
	public String execute()
	{
		System.out.print("继承ActionSupport类");
		return("success");
	}


}

二、helloworld 例子中里面action没有配置class

<action name="hello">
	    <result>
				/index.jsp
            </result>
		</action>

就是默认为ActionSupport,里面的execute方法返回success   

public String execute() throws Exception {
        return SUCCESS;
    }

三、DMI(dynami method invocation)动态方法调用

1、action不一定非得执行execute方法,可以指定调用具体的方法。不写的话默认为execute方法

    action方法中的method方法指定调用具体的方法。

<action name="action1" class="com.ncepu.struts2.Action1" method="notexecute">
   <result name="success">
    /index.jsp
   </result>
  </action>

2、DMI 动态方法调用 用!号

<action name="user" class="com.ncepu.struts2.Action1" >
   <result name="success">
    /add.jsp
     </result>
  </action>

jsp中<a href=”user!add”>添加学生</a>  自动调用Action1下面的add方法
也可直接访问 
http://localhost:8080/Struts2_DMI/user!add

四、通配符
 action配置 

<action name="*_*" class="com.ncepu.struts2.{1}Action" method="{2}{1}">
   <result name="success">
    /{2}_{1}.jsp
            </result>
  </action> 

jsp页面链接   

  <a href="Student_add">添加学生</a>
  <a href="Student_delete">删除学生</a>
  <a href="Teacher_add">添加教师</a>
  <a href="Teacher_delete">删除教师</a>

也可直接访问http://localhost:8080/Struts2_tongpeifu2/Student_delete思考: 仅用动态方法调用,result对于不同的action无法配置。要不只能到学生的jsp 要不只能到教师的jsp。
五、action接收参数
1、<a href=”user!add?name=12345&password=12345″>添加学生</a> 其中name和password是 action中的参数,并且有相应的getter和setter方法
2、使用Domain Model接收参数(最常用)

<a href=”user/user!add?user.name=a&user.password=8″>添加用户</a>
其中user是action中的参数,有getter和setter方法,而user是我们自己定义的域模型,里面有name和password参数

package com.ncepu.struts2;

import com.ncepu.struts2.entity.User;

public class Action1 {

private User user;

	public User getUser() {
	return user;
}

public void setUser(User user) {
	this.user = user;
}

	public String add() {
        System.out.println("添加的name="+this.user.getName()+"添加的password="+this.user.getPassword());
		return ("success");
	}

}

或者用DTO传输数据,相当于VO  value object ),比如注册的时候,得输入两遍密码,可以定义一个vo,包含3个属性,用户名,密码,确认密码,然后根据vo生成实体,该实体只包含用户名和密码两个属性。

3、使用ModelDriven接收参数

action实现ModelDriven接口,里面生成一个模型对象

public class Action1 extends ActionSupport implements ModelDriven<User>{
 private User user = new User();
 public String add() {
  System.out.println("name=" + user.getName());
  System.out.println("age=" + user.getPassword());
  return SUCCESS;
 }
 public User getModel() {
  return user;
 }
 
}

<a href=”user/user!add?name=a&password=8″>添加用户</a> 

会直接把属性设置到getModel方法获得的模型上面。

六、中文乱码问题

 <form action=”user!add” method=”post”>  必须为post ,get就出错,action得不到值

七、简单验证

 public String add() {
  if(name == null || !name.equals("admin")) {
   this.addFieldError("nameerror", "name is error");
   this.addFieldError("nameerror", "name is too long");
   this.addFieldError("passworderror", "password is not correct!");
   return ERROR;
  } 
  return SUCCESS;
 
 }

相应的在页面上

  <s:fielderror fieldName="nameerror" theme="simple" />
  <s:fielderror fieldName="passworderror" theme="simple" />
  <s:property value="errors.nameerror" />  <s:property value="errors.nameerror[0]" />
  <s:property value="errors.nameerror[1]" />
  <s:property value="errors.passworderror" /><s:property value="errors.passworderror[0]" />
  <s:debug></s:debug>

errors fieldErrors和action中所有的属性都会存在Value Stack Contents中
fielderror相当于一个数组,可以取所有,也可以取一个。
八、获得web元素4种方法

map类型的request session application(1、通过容器获得,2、实现aware接口通过IoC获得)

真实类型的request session application(3、通过容器获得,4、实现aware接口通过IoC获得)

1、通过容器获得map类型的request session application

package com.struts2.action;

import java.util.Map;

import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionSupport;

public class Action1 extends ActionSupport {
	/**
	 * 
	 */
	private static final long serialVersionUID = 1L;
	private Map<String, Object> request;
	private Map<String, Object> session;
	private Map<String, Object> application;

	public Action1() {
		request = (Map) ActionContext.getContext().get("request");
		session = ActionContext.getContext().getSession();
		application = ActionContext.getContext().getApplication();
	}

	public String execute() {
		request.put("r1", "requestpara");
		session.put("s1", "sessionpara");
		application.put("a1", "applicationpara");
		return SUCCESS;

	}

}

2、实现aware接口通过IoC获得map类型的request session application,(最常用)

package com.struts2.action;

import java.util.Map;

import org.apache.struts2.interceptor.ApplicationAware;
import org.apache.struts2.interceptor.RequestAware;
import org.apache.struts2.interceptor.SessionAware;

import com.opensymphony.xwork2.ActionSupport;

public class Action2 extends ActionSupport implements RequestAware,
		SessionAware, ApplicationAware {
	/**
	 * 
	 */
	private static final long serialVersionUID = 1L;
	private Map<String, Object> request;
	private Map<String, Object> session;
	private Map<String, Object> application;

	public void setRequest(Map<String, Object> request) {
		this.request = request;

	}

	public void setSession(Map<String, Object> session) {
		this.session = session;
	}

	public void setApplication(Map<String, Object> application) {
		this.application = application;

	}

	public String execute() {
		request.put("r1", "requestpara");
		session.put("s1", "sessionpara");
		application.put("a1", "applicationpara");
		return SUCCESS;

	}
}

3、通过容器获得真实类型的request session application

package com.struts2.action;

import javax.servlet.ServletContext;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;

import org.apache.struts2.ServletActionContext;

import com.opensymphony.xwork2.ActionSupport;

public class Action3 extends ActionSupport {
	/**
	 * 
	 */
	private static final long serialVersionUID = 1L;
	HttpServletRequest request;
	HttpSession session;
	ServletContext application;

	public Action3() {
		request = ServletActionContext.getRequest();
		session = request.getSession();
		application = session.getServletContext();
	}

	public String execute() {
		request.setAttribute("r1", "requestpara");
		session.setAttribute("s1", "sessionpara");
		application.setAttribute("a1", "applicationpara");
		return SUCCESS;

	}

}

4、实现aware接口通过IoC获得真实类型的request session application

package com.struts2.action;

import javax.servlet.ServletContext;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;

import org.apache.struts2.interceptor.ServletRequestAware;

import com.opensymphony.xwork2.ActionSupport;

public class Action4 extends ActionSupport implements ServletRequestAware {
	/**
	 * 
	 */
	private static final long serialVersionUID = 1L;
	HttpServletRequest request;
	HttpSession session;
	ServletContext application;

	public void setServletRequest(HttpServletRequest request) {
		this.request = request;
		this.session = request.getSession();
		application = session.getServletContext();

	}

	public String execute() {
		request.setAttribute("r1", "requestpara");
		session.setAttribute("s1", "sessionpara");
		application.setAttribute("a1", "applicationpara");
		return SUCCESS;

	}
}

login_success.jsp

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
    <%@taglib uri="/struts-tags" prefix="s" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=GB18030" />
<title>Insert title here</title>
</head>
<body>
	User Login Success!
	<br />
	<s:property value="#request.r1"/> | <%=request.getAttribute("r1") %> <br />
	<s:property value="#session.s1"/> | <%=session.getAttribute("s1") %> <br />
	<s:property value="#application.a1"/> | <%=application.getAttribute("a1") %> <br />
	<s:property value="#attr.a1"/><br />
	<s:property value="#attr.s1"/><br />
	<s:property value="#attr.r1"/><br />
	<s:debug></s:debug>
	<br />
</body>
</html>

九、include 包含其他配置action的xml文件

<struts>
 <constant name="struts.devMode" value="true" />
 <include file="module1.xml"></include>
</struts>

而module1.xml文件中配置着action

十、namespace的默认action

<struts>
 <constant name="struts.devMode" value="true" />
	<package name="default" namespace="/action" extends="struts-default">
	<default-action-ref name="action1"></default-action-ref>
	<action name="action1" class="com.ncepu.struts2.Action1">
			<result name="success">
				/default.jsp
            </result>
	</action>	
	</package>
</struts>

每个package可以有一个默认的action,当没有匹配的时候时,就使用它,如用户输入错误时,根据他跳到默认的错误界面

十一、路径问题

1、action跳转

result都需要指定目标资源的URL,如果这个路径以“/”开始。代表的是应用程序根目录。

<package name="default" namespace="/path" extends="struts-default">
	
		<action name="hello">
			<result>
				/path.jsp
                        </result>
		</action>
	</package>

其中path在webroot根目录下。能找到。如果是下面的配置

<package name="default" namespace="/path" extends="struts-default">
	
		<action name="hello">
			<result>
				path.jsp
                        </result>
		</action>
	</package>

则不行,当前目录是Struts2_path/path/hello.action,相当于在当前目录查找,即/Struts2_path/path/path.jsp

2、jsp链接都使用绝对路径:

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <base href="<%=basePath%>">
    
    <title>My JSP 'index.jsp' starting page</title>
	<meta http-equiv="pragma" content="no-cache">
	<meta http-equiv="cache-control" content="no-cache">
	<meta http-equiv="expires" content="0">    
	<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
	<meta http-equiv="description" content="This is my page">
	<!--
	<link rel="stylesheet" type="text/css" href="styles.css">
	-->
  </head>
  
  <body>
  <a href="path.jsp"> path.jsp</a> <br>
  </body>
</html>

定义path ,然后再head便签中添加<base href=”<%=basePath%>”>,相当于都从web应用的根目录下面找

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/110335.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • oracle自动共享内存管理(ASMM) .

    oracle自动共享内存管理(ASMM) .一篇关于ASSM的好文章:http://blog.csdn.net/liyongjie/article/details/7443825oracle自动共享内存管理(ASMM)从Oracle10g开始,Oracle提供了自动SGA的管理(简称ASMM,即AutomaticSharedMemoryManagement)新特性。所谓ASMM,就是指我们不再需要手工设置sharedpoo

  • 寻求全站搜索功能开发思路

    寻求全站搜索功能开发思路

  • 搭建自己的云计算平台

    1.Enomalism(http://www.enomaly.com/)云计算平台。Enomalism是一个开放源代码项目,它提供了一个功能类似于EC2的云计算框架。Enomalism基于Linux,同时支持Xen和KernelVirtualMachine(KVM)。Enomalism提供了一个基于TurboGearsWeb应用程序框架和Python的软件栈。

  • Haier数字可视对讲系列(转)「建议收藏」

    Haier数字可视对讲系列(转)「建议收藏」数字可视对讲系列楼宇可视对讲这一家庭安防设备是智能化小区建设的必要项目之一,也是家居安全的护身符。对讲系统是在各小区、单元门入口安装防盗门和对讲装置,其主要目的是实现访客与住户可视、对讲。住户可通过系统遥控开启防盗门,从而有效…

  • python中的%s%是什么意思

    python中的%s%是什么意思python中的%s%是什么意思它是一个字符串格式化语法(它从C借用)。请参阅“格式化字符串”:Python支持将值格式化为字符串。虽然这可以包括非常复杂的表达式,但最基本的用法是将值插入到%s占

  • 常见计算机病毒种类及特征介绍与分析

    常见计算机病毒种类及特征介绍与分析什么是计算机病毒通俗来讲,计算机病毒是一个程序,一段可执行代码。它可以很快地通过网络、U盘等蔓延,又常常难以根除。它能影响计算机使用,并且具有破坏性,复制性和传染性。病毒又分为很多种类,下面,我就来说说最常见的一些病毒吧!系统病毒系统病毒的前缀为:Win32、PE、Win95、W32、W95等。这些病毒的一般共有的特性是可以感染windows操作系统的*.exe和*.dll

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号