**Action的访问(重点)**
1.通过<action>标签中的method属性,访问到Action中的具体的方法。
* 传统的配置方式,配置更清晰更好理解!但是扩展需要修改配置文件等!
* 具体的实例如下:
* 页面代码
* <a href="${pageContext.request.contextPath}/addBook.action">添加图书</a>
* <a href="${pageContext.request.contextPath}/deleteBook.action">删除图书</a>
* 配置文件的代码
<package name="demo2" extends="struts-default" namespace="/">
<action name="addBook" class="cn.itcast.demo2.BookAction" method="add"></action>
<action name="deleteBook" class="cn.itcast.demo2.BookAction" method="delete"></action>
</package>
* Action的代码
public String add(){
System.out.println("添加图书");
return NONE;
}
public String delete(){
System.out.println("删除图书");
return NONE;
}
2.通配符的访问方式:(访问的路径和方法的名称必须要有某种联系.) 通配符就是 * 代表任意的字符
* 使用通配符的方式可以简化配置文件的代码编写,而且扩展和维护比较容易。
* 具体实例如下:
* 页面代码
<a href="${pageContext.request.contextPath}/order_add.action">添加订单</a>
<a href="${pageContext.request.contextPath}/order_delete.action">删除订单</a>
* 配置文件代码
* <action name="order_*" class="cn.itcast.demo2.OrderAction" method="{1}"></action>
* Action的代码
public String add(){
System.out.println("添加订单");
return NONE;
}
public String delete(){
System.out.println("删除订单");
return NONE;
}
* 具体理解:在JSP页面发送请求,http://localhost/struts2_01/order_add.action,配置文件中的order_*可以匹配该请求,*就相当于变成了add,method属性的值使用{1}来代替,{1}就表示的是第一个*号的位置!!所以method的值就等于了add,那么就找到Action类中的add方法,那么add方法就执行了!
3.通配符更抽象的写法(了解即可)
* 具体的实例如下:
* 页面的代码
* <a href="${pageContext.request.contextPath}/OrderAction_add.action">添加订单</a>
* 配置文件代码
* <action name="*_*" class="cn.itcast.demo2.{1}" method="{2}"></action>
* Action的代码
public class OrderAction extends ActionSupport{
public String add(){
System.out.println("添加订单");
return NONE;
}
}
4.动态方法访问的方式(有的开发中也会使用这种方式)
* 如果想完成动态方法访问的方式,需要开启一个常量,struts.enable.DynamicMethodInvocation = false,把值设置成true。
* 注意:不同的Struts2框架的版本,该常量的值不一定是true或者false,需要自己来看一下。如果是false,需要自己开启。
* 在struts.xml中开启该常量。
* <constant name="struts.enable.DynamicMethodInvocation" value="true"></constant>
* 具体代码如下
* 页面的代码
* <a href="${pageContext.request.contextPath}/product!add.action">添加商品</a>
* <a href="${pageContext.request.contextPath}/product!delete.action">删除商品</a>
* 配置文件代码
* <action name="product" class="cn.itcast.demo2.ProductAction"></action>
* Action的类的代码
public class ProductAction extends ActionSupport{
public String add(){
System.out.println("添加订单");
return NONE;
}
public String delete(){
System.out.println("删除订单");
return NONE;
}
}
5.总结:怎么样访问Action
* 传统的方式
* 编写一个请求,需要提供一个配置文件
* 通配符的方式
* 编写请求和Action类中的方法需要有一定的联系
* 需要使用 * 号作为占位符出现,匹配任意的字符
* 动态方法访问的方式
* 先开启动态方法访问的常量 <constant name="struts.enable.DynamicMethodInvocation" value="true"/>
* 发送请求的时候,请求路径!方法的名称
demo3.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>
<h3>传统的配置文件的方式</h3>
<a href="${pageContext.request.contextPath }/addBook.action">添加图书</a>
<a href="${pageContext.request.contextPath }/deleteBook.action">删除图书</a>
<h3>通配符的方式</h3>
<a href="${pageContext.request.contextPath}/order_add.action">添加订单</a>
<a href="${pageContext.request.contextPath}/order_delete.action">删除订单</a>
<a href="${pageContext.request.contextPath}/order_update.action">修改订单</a>
<h3>抽象通配符的方式</h3>
<a href="${pageContext.request.contextPath}/UserAction_add.action">添加用户</a>
</body>
</html>
struts_demo3.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>
<package name="demo3" extends="struts-default" namespace="/">
<!-- 基本的配置文件的方式 -->
<action name="addBook" class="demo3.BookAction" method="add"></action>
<action name="deleteBook" class="demo3.BookAction" method="delete"></action>
<!-- 配置通配符的方式 -->
<action name="order_*" class="demo3.OrderAction" method="{1}"></action>
<!-- 抽象的通配符的方式 -->
<action name="*_*" class="demo3.{1}" method="{2}"> </action>
<!-- 动态方法访问的方式 说明:没有配置method属性-->
<action name="product" calsss="demo3.ProductAction"></action>
</package>