一、API的访问

在使用Struts2的框架的过程中,发现Struts2和Servlet的API是解耦合的。在实际开发中,经常使用到Servlet的API,比如进行登录,将用户的信息保存到Session中,

有的时候需要向页面输出一些内容,用到response对象。涉及到Servlet的API的访问。

1、完全解耦合的方式,通过ActionContext类访问[推荐]

Struts2框架提供了ActionContext类来访问Servlet API,ActionContext是Action执行的上下文对象。在ActionContext中保存了Action执行所需要的所有对象,

包括parameters,request,session,application等。

// 将key-value键值对放入ActionContext中,模拟Servlet API中的HTTPServletRequest
的setAttribute()方法
void put(String key,Object value) // 通过参数Key来查找当前ActionContext中的值
Object get(String key) // 返回一个Application级的对象
Map<String,Object> getApplication() // 获取当前线程的ActionContext对象
static ActionContext getContext() // 返回一个包含所有HttpServletRequest参数信息
Map<String,Object> getParameters() // 返回一个Map类型的HttpSession对象
Map<String,Object> getSession() // 设置Application上下文
void SetApplication(Map<String,Object> application) // 设置一个Map类型的Session值
void setSession(Map<String,Object> session)

注意:这种方式只能获得代表request、session、application的数据的Map集合,不能操作这些对象的本身的方法。

案例:

Action类

package com.turtle.demo4.action;

import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionSupport; import java.util.Map; public class Demo4Action extends ActionSupport { public String save(){ // 从前端返回来的参数中取值
// 通过ActionContext来取得ActionContext对象
ActionContext actionContext = ActionContext.getContext();
// actionContext.getParameters()可以取到map值的对象
Map<String, Object> contextParameters = actionContext.getParameters();
// 遍历输出值
for (Map.Entry<String,Object> entry : contextParameters.entrySet()){
String key = entry.getKey();
String value = entry.getValue().toString();
} // 向返回前端的参数中设置值
// 把值设置到session中
actionContext.getSession().put("name1","session");
// request.setAttribute("","")
actionContext.put("name2","request");
// application.setAttribute("","")
actionContext.getApplication().put("name3", "application"); return SUCCESS;
}
}

Jsp页面

<%--
Created by IntelliJ IDEA.
User: 22274
Date: 2019/10/27
Time: 23:52
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Servlet</title>
</head>
<body>
<h1>使用ServletContext</h1>
<form action="${pageContext.request.contextPath}/demo4Action.action" method="post">
用户名:<input type="text" name="name" value=""/><br/>
密 码:<input type="password" name="password" value=""/><br/>
<input type="submit" value="提交">
</form>
</body>
</html>
<%--
Created by IntelliJ IDEA.
User: 22274
Date: 2019/10/27
Time: 23:52
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<html>
<head>
<title>Servlet</title>
</head>
<body>
<h1>使用ServletContext</h1>
<form action="${pageContext.request.contextPath}/demo4Action.action" method="post">
Session :<input type="text" name="name1" value="${name1}"/><br/>
Request :<input type="text" name="name2" value="${name2}"/><br/>
Application:<input type="text" name="name3" value="${name3}"/><br/>
<input type="submit" value="提交">
</form>
</body>
</html>

配置文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd"> <struts>
<package name="demo4" extends="struts-default" namespace="/">
<action name="demo4Action" class="com.turtle.demo4.action.Demo4Action" method="save">
<result name="success">/demo4/success.jsp</result>
</action>
</package>
</struts>

结果:

                

2、使用Servlet的API的原生方式

该方法可以直接访问Servle API,提供了ServletActionContext类,该类包含了我么所需要的几个方法

// 获取web应用中的HttpServletRequest对象
static HttpServletRequest() // 获取web应用中的HttpServletResponse对象
static HttpServletResponse getResponse() // 获取web应用中的ServletContext对象
static ServletContext getServletContext() // 获取WEb应用中的PageContext对象
static PageContext getPageContext()

Action类:

package com.turtle.demo4.action;

import com.opensymphony.xwork2.ActionSupport;
import org.apache.struts2.ServletActionContext; import javax.servlet.http.HttpServletRequest;
import java.util.Map; public class Demo4Action extends ActionSupport { public String save(){ // 取从前端页面带过来的数据
HttpServletRequest request = ServletActionContext.getRequest();
Map<String, String[]> parameterMap = request.getParameterMap();
for(Map.Entry<String,String[]> entry : parameterMap.entrySet()){
String key = entry.getKey();
String[] value = entry.getValue();
} // 往前端传的数据
request.setAttribute("name1","request");
request.getSession().setAttribute ("name2","session");
ServletActionContext.getServletContext().setAttribute("name3","servletContext");
return SUCCESS;
}
}

JSP页面和配置文件不做改变,显示的结果也是一样的。

3、接口注入的方式

// 实现该接口可以直接访问WEb应用中的HttpServletRequest实例
ServletRequestAware // 实现该接口可以直接访问WEb应用中的HttpServletResponse实例
ServletResponseAware // 实现该接口可以直接访问WEb应用中的HttpSession实例
SessionAware // 实现该接口可以直接访问WEb应用中的ServletContexte实例
ServletContextAware

Action:

package com.turtle.demo4.action;

import com.opensymphony.xwork2.ActionSupport;
import org.apache.struts2.ServletActionContext;
import org.apache.struts2.interceptor.ServletRequestAware; import javax.servlet.http.HttpServletRequest;
import java.util.Map; public class Demo4Action extends ActionSupport implements ServletRequestAware { private HttpServletRequest request; @Override
public void setServletRequest(HttpServletRequest httpServletRequest) {
this.request = httpServletRequest;
}
public String save(){
// 取从前端页面带过来的数据
Map<String, String[]> parameterMap = request.getParameterMap();
for(Map.Entry<String,String[]> entry : parameterMap.entrySet()){
String key = entry.getKey();
String[] value = entry.getValue();
} // 往前端传的数据
request.setAttribute("name1","request");
request.getSession().setAttribute ("name2","session");
ServletActionContext.getServletContext().setAttribute("name3","servletContext");
return SUCCESS;
}
}

配置文件和结果显示页面与上面的一致。

Servlet是单例的,多个程序访问同一个Servlet只会创建一个Servlet的实例。Action是多例的,一次请求,创建一个Action的实例(不会出现线程安全的问题)。

二、结果页面的配置

1、局部结果页面的配置:

局部结果页面指的是,只能在当前的action中的配置有效。

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd"> <struts>
<package name="demo4" extends="struts-default" namespace="/">
<action name="demo4Action" class="com.turtle.demo4.action.Demo4Action" method="save">
<result name="success">/demo4/success.jsp</result>
</action>
</package>
</struts>

2、全局结果页面的配置:

全局结果页面:全局结果页面指的是,在包中配置一次,其他的在这个包中的所有的action只要返回了这个值,都可以跳转到这个页面。

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd"> <struts>
<package name="demo4" extends="struts-default" namespace="/">
<global-results>
<result name="success">/demo4/success.jsp</result>
</global-results>
<action name="demo4Action" class="com.turtle.demo4.action.Demo4Action" method="save">
<!--<result name="success">/demo4/success.jsp</result>-->
</action>
</package>
</struts>

3、result标签的配置

result标签用于配置页面的跳转。在result标签上有两个属性:

name属性      :逻辑视图的名称。默认值:success

type属性        :页面跳转的类型。

  dispatcher       :默认值,请求转发。(Action转发JSP

  redirect            :重定向。(Action重定向JSP

  chain                 :转发。(Action转发Action)

  redirectAction :重定向。(Action重定向Action)

  stream              :Struts2中提供文件下载的功能。

三、数据封装:

1、属性驱动:提供属性set方法的方式(不常用)

Action类:

package com.turtle.demo5;

import com.opensymphony.xwork2.ActionSupport;

public class Demo5Action extends ActionSupport {

    // 用户名
private String name;
// 密码
private String password; public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public String getPassword() {
return password;
} public void setPassword(String password) {
this.password = password;
} public String save() {
System.out.println("用户名"+name);
System.out.println("密码"+password);
return null;
}
}

前端页面:

<%--
Created by IntelliJ IDEA.
User: 22274
Date: 2019/10/27
Time: 23:52
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Servlet</title>
</head>
<body>
<h1>属性驱动第一种方法</h1>
<form action="${pageContext.request.contextPath}/demo5Action.action" method="post">
用户名:<input type="text" name="name" /><br/>
密 码:<input type="password" name="password"/><br/>
<input type="submit" value="提交">
</form>
</body>
</html>

2、属性驱动:页面中提供表达式方式

封装的对象

package com.turtle.demo5;

public class User {
// 名字
private String name;
// 密码
private String password; public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public String getPassword() {
return password;
} public void setPassword(String password) {
this.password = password;
}
}

Action类

package com.turtle.demo5;

import com.opensymphony.xwork2.ActionSupport;

public class Demo5Action extends ActionSupport {

    // 用户对象
private User user; public String save() {
System.out.println("用户名"+user.getName());
System.out.println("密码"+user.getPassword());
return null;
} public User getUser() {
return user;
} public void setUser(User user) {
this.user = user;
}
}

Jsp页面:

<%--
Created by IntelliJ IDEA.
User: 22274
Date: 2019/10/27
Time: 23:52
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Servlet</title>
</head>
<body>
<h1>属性驱动第一种方法</h1>
<form action="${pageContext.request.contextPath}/demo5Action.action" method="post">
用户名:<input type="text" name="user.name" /><br/>
密 码:<input type="password" name="user.password"/><br/>
<input type="submit" value="提交">
</form>
</body>
</html>

3、模型驱动,采用模型驱动方式(最常用)

通过实现ModelDriven接口来接收参数,Action类必须实现ModelDerven接口,并且要重写getModel方法,这个方法返回的是Action类所要使用的数据模型对象。

Action类

package com.turtle.demo5;

import com.opensymphony.xwork2.ActionSupport;
import com.opensymphony.xwork2.ModelDriven; public class Demo5Action extends ActionSupport implements ModelDriven<User> { // 用户对象,需要手动进行实例化
private User user = new User(); /**
* 主要就是这个方法
* @return
*/
@Override
public User getModel() {
return user;
} public String save() {
System.out.println("用户名"+user.getName());
System.out.println("密码"+user.getPassword());
return null;
} public User getUser() {
return user;
} public void setUser(User user) {
this.user = user;
}
}

jsp页面

<%--
Created by IntelliJ IDEA.
User: 22274
Date: 2019/10/27
Time: 23:52
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Servlet</title>
</head>
<body>
<h1>属性驱动第一种方法</h1>
<form action="${pageContext.request.contextPath}/demo5Action.action" method="post">
用户名:<input type="text" name="name" /><br/>
密 码:<input type="password" name="password"/><br/>
<input type="submit" value="提交">
</form>
</body>
</html>

汇总:大部分我们会优先使用模型驱动的方式,因为Struts2内部有很多结果都是围绕模型驱动设计的。但如果页面中向

多个对象中封装,那么就要使用属性驱动的方式二了。

4、封装到List集合中

Action类

package com.turtle.demo5;

import com.opensymphony.xwork2.ActionSupport;
import com.opensymphony.xwork2.ModelDriven; import java.util.List; public class Demo5Action extends ActionSupport { // 用户对象,需要手动进行实例化
// 该变量和jsp中使用的list名字要一致,而且get/set方法也要一致
private List<User> userList; public String save() {
for(User user : userList){
System.out.println("用户名"+user.getName());
System.out.println("密码"+user.getPassword());
}
return null;
}
public List<User> getUserList() {
return userList;
} public void setUserList(List<User> userList) {
this.userList = userList;
} }

JSp页面:

<%--
Created by IntelliJ IDEA.
User: 22274
Date: 2019/10/27
Time: 23:52
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Servlet</title>
</head>
<body>
<h1>属性驱动第一种方法</h1>
<form action="${pageContext.request.contextPath}/demo5Action.action" method="post">
用户名:<input type="text" name="userList[0].name" /><br/>
密 码:<input type="password" name="userList[0].password"/><br/>
<hr/>
用户名:<input type="text" name="userList[1].name" /><br/>
密 码:<input type="password" name="userList[1].password"/><br/>
<input type="submit" value="提交">
</form>
</body>
</html>

5、封装到Map集合中

Action类

package com.turtle.demo5;

import com.opensymphony.xwork2.ActionSupport;
import com.opensymphony.xwork2.ModelDriven; import java.util.List;
import java.util.Map; public class Demo5Action extends ActionSupport { private Map<String,User> userMap; public String save() {
for(Map.Entry<String,User> user : userMap.entrySet()){
System.out.println("用户名"+user.getValue().getName());
System.out.println("密码"+user.getValue().getPassword());
}
return null;
} public Map<String, User> getUserMap() {
return userMap;
} public void setUserMap(Map<String, User> userMap) {
this.userMap = userMap;
}
}

Jsp页面

<%--
Created by IntelliJ IDEA.
User: 22274
Date: 2019/10/27
Time: 23:52
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Servlet</title>
</head>
<body>
<h1>属性驱动第一种方法</h1>
<form action="${pageContext.request.contextPath}/demo5Action.action" method="post">
用户名:<input type="text" name="userMap['0'].name" /><br/>
密 码:<input type="password" name="userMap['0'].password"/><br/>
<hr/>
用户名:<input type="text" name="userMap['1'].name" /><br/>
密 码:<input type="password" name="userMap['1'].password"/><br/>
<input type="submit" value="提交">
</form>
</body>
</html>

四、总结

3、Struts2的API访问和数据封装的更多相关文章

  1. struts2 servlet api 访问方式

    Action中访问ServletAPI. 主要就是接收表单参数及向域对象中存取值. 关于SevletAPI的方法在Action中有三种方式: 1.完全解耦合的形式: * 使用一个类:ActionCon ...

  2. struts2的action访问servlet API的三种方法

    学IT技术,就是要学习... 今天无聊看看struts2,发现struts2的action访问servlet API的三种方法: 1.Struts2提供的ActionContext类 Object g ...

  3. 5 weekend01、02、03、04、05、06、07的分布式集群的HA测试 + hdfs--动态增加节点和副本数量管理 + HA的java api访问要点

    weekend01.02.03.04.05.06.07的分布式集群的HA测试 1)  weekend01.02的hdfs的HA测试 2)  weekend03.04的yarn的HA测试 1)  wee ...

  4. API访问客户端

    API访问客户端(WebApiClient适用于MVC/WebForms/WinForm) 这几天没更新主要是因为没有一款合适的后端框架来支持我们的Web API项目Demo, 所以耽误了几天, 目前 ...

  5. asp.net core系列 57 IS4 使用混合流(OIDC+OAuth2.0)添加API访问

    一.概述 在上篇中,探讨了交互式用户身份验证,使用的是OIDC协议. 在之前篇中对API访问使用的是OAuth2.0协议.这篇把这两个部分放在一起,OpenID Connect和OAuth 2.0组合 ...

  6. 第13章 切换到混合流并添加API访问 - Identity Server 4 中文文档(v1.0.0)

    在之前的快速入门中,我们探讨了API访问和用户身份验证.现在我们想把这两个部分放在一起. OpenID Connect和OAuth 2.0组合的优点在于,您可以使用单个协议和使用令牌服务进行单次交换来 ...

  7. 大数据实操2 - hadoop集群访问——Hadoop客户端访问、Java API访问

    上一篇中介绍了hadoop集群搭建方式,本文介绍集群的访问.集群的访问方式有两种:hadoop客户端访问,Java API访问. 一.集群客户端访问 Hadoop采用C/S架构,可以通过客户端对集群进 ...

  8. IdentityServer4 中文文档 -13- (快速入门)切换到混合流并添加 API 访问

    IdentityServer4 中文文档 -13- (快速入门)切换到混合流并添加 API 访问 原文:http://docs.identityserver.io/en/release/quickst ...

  9. IdentityServer4【QuickStart】之切换到混合流并且添加API访问

    切换到混合流并且添加API访问 前面的示例中我们开发了API访问和用户认证,现在我们要将两个合并到一起. OpenID Connect&OAuth 2.0组合的美妙之处是,你可以使用单一协议和 ...

随机推荐

  1. linux中必备常用支持库的安装(CentOS)

    在CentOS安装软件的时候,可能缺少一部分支持库,而报错.这里首先安装系统常用的支持库.那么在安装的时候就会减少很多的错误的出现 yum install -y gcc gdb strace gcc- ...

  2. java接收控制台输入

    java控制台输入语句: Scanner sc = new Scanner(System.in); 通过一个变量,例如 int r; r = sc.nextInt();   例子: public st ...

  3. 词义消除歧义NLP项目实验

    词义消除歧义NLP项目实验 本项目主要使用https://github.com/alvations/pywsd 中的pywsd库来实现词义消除歧义 目前,该库一部分已经移植到了nltk中,为了获得更好 ...

  4. Linux初识之Centos7中terminal光标位置偏移问题的解决

    新安装的centos7打开terminal发现光标位置向右偏移,使用起来影响感官,经查询后找到类似情况并顺利解决问题,特记录解决过程以作参考. 1.未解决时光标向右偏移显示: 2.打开设置(Setti ...

  5. 【数据结构与算法】--JavaScript 链表

    一.介绍 JavaScript 原生提供了数组类型,但是却没有链表,虽然平常的业务开发中,数组是可以满足基本需求,但是链表在大数据集操作等特定的场景下明显具有优势,那为何 JavaScript 不提供 ...

  6. elastic集群单节点停机维护

    为了elastic时时提供服务,需要elastic至少状态维持在yellow状态.所有,维护时需要依次对elastic单个节点进行维护. 操作步骤如下: 1.停止elastic的自动分配功能 curl ...

  7. Intellij IDEA 2019 + Java Spring MVC + Hibernate学习笔记(2)

    书接上文 首先根据各种Spring MVC教程,建立了基础的结构,是否合理不知道,姑且先这样,有问题再解决问题.学习新东西,不能怕掉坑里... 查询网上别人的经历说需要把根目录下的lib目录下的所有包 ...

  8. Janus安装教程,ubuntu18.04系统

    Janus安装教程,ubuntu18.04系统     本文介绍Jansu如何安装,操作系统为Ubuntu 18.04.    (1)安装git 执行命令:“sudo apt-get install ...

  9. 【Python】机器学习之单变量线性回归练习(计算Cost Function)

    注:练习来自于吴恩达机器学习 翻译后的题目: 你是一个餐厅的老板,你想在其他城市开分店,所以你得到了一些数据(数据在本文最下方),数据中包括不同的城市人口数和该城市带来的利润.第一列是城市的人口数,第 ...

  10. Kafka常用命令合集

    在上一篇文章<Linux安装Kafka>中,已经介绍了如何在Linux安装Kafka,以及Kafka的启动/关闭和创建发话题并产生消息和消费消息.这篇文章就介绍介绍Kafka的那些常用的命 ...