标签:resource ati 实现类 patch ret 文件导入 this oba load
一.struts框架得到环境搭建
首先我们建一个maven项目(里面有很多细节问题可以看 https://www.cnblogs.com/chenjiahao9527/p/11079245.html)
这次在pom.xml加下面的代码
<dependency> <groupId>org.apache.struts</groupId> <artifactId>struts2-core</artifactId> <version>2.5.13</version> </dependency>
然后我们把下面配置文件导入项目中的src/amin/resources中
struts.xml
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.5//EN" "http://struts.apache.org/dtds/struts-2.5.dtd"> <struts> <include file="struts-default.xml"></include><!-- 原有的配置文件 --> <include file="struts-base.xml"></include><!-- 基础的配置文件 --> <include file="struts-sy.xml"></include> </struts>
struts-base.xml
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.5//EN" "http://struts.apache.org/dtds/struts-2.5.dtd"> <struts> <constant name="struts.i18n.encoding" value="UTF-8" /><!-- 编码格式 --> <constant name="struts.devMode" value="true" /><!-- 动态方法调用 --> <constant name="struts.configuration.xml.reload" value="true" /><!-- 不重启项目修改代码立即生效 --> <constant name="struts.i18n.reload" value="true" /> <constant name="struts.enable.DynamicMethodInvocation" value="true" /><!-- 开起动态方法调用 --> <package name="base" extends="struts-default" abstract="true"> <global-allowed-methods>regex:.*</global-allowed-methods> </package> </struts>
struts-sy.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.5//EN"
"http://struts.apache.org/dtds/struts-2.5.dtd">
<struts>
<!-- 这包能更加细分action的归类 -->
<package name="sy" extends="base" namespace="/sy">
</action>
</package>
</struts>
配置web.xml
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
version="3.1">
<display-name>Archetype Created Web Application</display-name>
<filter>
<filter-name>Struts</filter-name>
<filter-class>org.apache.struts2.dispatcher.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>Struts</filter-name>
<url-pattern>*.action</url-pattern>
</filter-mapping>
</web-app>
二.struts的动态方法调用、struts传参(jsp和后台的互传)
1、动态动态方法调用

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}/sy/demo_add.action">新增</a>
<a href="${pageContext.request.contextPath}/sy/demo_del.action">删除</a>
</body>
</html>
在struts-sy.xml里面配置了方法传递
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.5//EN"
"http://struts.apache.org/dtds/struts-2.5.dtd">
<struts>
<!-- 这包能更加细分action的归类 -->
<package name="sy" extends="base" namespace="/sy">
<action name="/demo_*" class="com.chenjiahao.web.HelloAction" method="{1}">
<result name="rs">/rs.jsp</result>
</action>
</package>
</struts>
java代码
//动态方法的调用
public class HelloAction(){ public String add() { System.out.println("调用add方法......."); return "rs"; } public String del() { System.out.println("调用del方法......."); return "rs"; } }
这样就可以调用动态方法了
2、jsp传递参数到后台,后台如何接受
先建一个实体类
package com.chenjiahao.emtity;
public class Cal {
private String num1;
private String num2;
public String getNum1() {
return num1;
}
public void setNum1(String num1) {
this.num1 = num1;
}
public String getNum2() {
return num2;
}
public void setNum2(String num2) {
this.num2 = num2;
}
@Override
public String toString() {
return "Cal [num1=" + num1 + ", num2=" + num2 + "]";
}
}
implements modelDrivern
set/get
类实例.属性名
public class HelloAction implements ModelDriven<Cal>{
private HttpServletRequest request;
private Cal cal1=new Cal();
private Cal cal2;
private String sex;
public Cal getCal2() {
return cal2;
}
public void setCal2(Cal cal2) {
this.cal2 = cal2;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
/**
* implements ModelDriven 接收参数值
* @return
*/
public String accept1() {
System.out.println("cal1:"+cal1);
return "rs";
}
/**
* 类实例.属性名 接收参数值
* @return
*/
public String accept2() {
System.out.println("cal2:"+cal2);
return "rs";
}
/**
* set/get 接收参数值
* @return
*/
public String accept3() {
System.out.println(sex);
return "rs";
}
}
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>后台接收jsp传递参数的三种方法</h3>
<a href="${pageContext.request.contextPath}/sy/demo_accept1.action?num1=20&&num2=5">accept1</a>
<a href="${pageContext.request.contextPath}/sy/demo_accept2.action?cal2.num1=20&&cal2.num2=5">accept2</a>
<a href="${pageContext.request.contextPath}/sy/demo_accept3.action?sex=nv">accept3</a>
</body>
</html>
结果:

3、后台传递到jsp的方式
set/get定义的属性是可以接受到的不需要任何操作
直接在jsp用el表达式

req.set.....
public class HelloAction ServletRequestAware{
private HttpServletRequest request;
public String accept1() {
System.out.println("cal1:"+cal1);
/**
*后台传递到jsp的方式
*set/get定义的属性是可以接受到的
*req.set.....
*/
//注入耦合
// request.setAttribute("cal1", cal1);
//非注入耦合
HttpServletRequest request2 = ServletActionContext.getRequest();
request2.setAttribute("cal1", cal1);
// 非注入解耦(这种方式一般没人用,因为记不住context的实现类路径)
// ActionContext context = ActionContext.getContext();
// context.get("XXXX");
return "rs";
}
}
标签:resource ati 实现类 patch ret 文件导入 this oba load
原文地址:https://www.cnblogs.com/chenjiahao9527/p/11093518.html