Struts2中为用户提供等待页面并测试Action的执行时间

2024-03-16 18:58

本文主要是介绍Struts2中为用户提供等待页面并测试Action的执行时间,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这是一个Struts2.0.11应用,代码如下

首先是web.xml文件

<?xml version="1.0" encoding="UTF-8"?> <web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> <filter> <filter-name>struts2</filter-name> <filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class> </filter> <filter-mapping> <filter-name>struts2</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <welcome-file-list> <welcome-file>waitLogin.jsp</welcome-file> </welcome-file-list> </web-app>

然后是用于输入用户名和密码以激活等待页面的waitLogin.jsp

<%@ page pageEncoding="UTF-8"%> <h1>使用Struts2中的execAndWait拦截器为用户提供等待页面</h1> <h3><font color="red">提示:</font>程序设定的用户名和密码各为<font color="blue"><strong>admin</strong></font>和<font color="blue"><strong>jadyer</strong></font></h3> <h3><font color="red">注意:</font>用户名或密码不正确时将停留在该页面不动</h3> <br><br> <form action="<%=request.getContextPath()%>/waitLogin.action" method="POST"> 姓名:<input type="text" name="username"><br> 密码:<input type="text" name="password"><br> <input type="submit" value="测试等待页面"> </form>

用户名和密码均正确时显示的登录成功页面waitLoginSuc.jsp

<%@ page language="java" pageEncoding="UTF-8"%> <h1>Login Success</h1>

然后是位于WEB-INF目录下的等待页面wait.jsp

<%@ page language="java" pageEncoding="UTF-8"%> <%-- <meta http-equiv="refresh" content="2;URL=waitLogin.action"> --%> <% response.setHeader("refresh", "2;URL=waitLogin.action"); %> <h2>数据已经提交,正在等待服务器返回信息,<font color="blue"><strong>请您耐心等待......</strong></font></h2> <br/> <br/> <h2><a href="<%=request.getContextPath()%>/waitLogin.action">如果该页面长时间没有响应,请点这里刷新</a></h2>

然后是Struts2的配置文件struts.xml

<?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="waitLogin" extends="struts-default"> <action name="waitLogin" class="com.zhangbing.action.WaitLoginAction" method="testWait"> <interceptor-ref name="timer"/><!-- 测试WaitLoginAction的执行时间 --> <interceptor-ref name="defaultStack"/> <interceptor-ref name="execAndWait"> <param name="delay">1000</param> </interceptor-ref> <!-- 配置execAndWait拦截器时,要求它必须位于所有拦截器的最下面 --> <!-- delay是指:若1秒之内处理完请求,就显示SUCCESS页面,否则显示WAIT页面 --> <result name="wait">/WEB-INF/wait.jsp</result> <result name="success">/waitLoginSuc.jsp</result> <result name="login">/waitLogin.jsp</result> </action> </package> </struts>

最后是Struts2的Action类WaitLoginAction.java

package com.zhangbing.action; import com.opensymphony.xwork2.ActionSupport; /** * 测试execAndWait拦截器时用到的Action */ @SuppressWarnings("serial") public class WaitLoginAction extends ActionSupport { private String username; private String password; /* 两个属性的setter和getter略 */ public String testWait() throws Exception { if(username.trim().equalsIgnoreCase("admin") && password.equals("jadyer")){ System.out.println("---------醒目的分隔线---------"); Thread.sleep(4000); //令当前线程休眠 4 秒 System.out.println("---------无敌的分隔线---------"); return SUCCESS; }else{ return LOGIN; } } }

这篇关于Struts2中为用户提供等待页面并测试Action的执行时间的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/816400

相关文章

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

Java实现远程执行Shell指令

《Java实现远程执行Shell指令》文章介绍使用JSch在SpringBoot项目中实现远程Shell操作,涵盖环境配置、依赖引入及工具类编写,详解分号和双与号执行多指令的区别... 目录软硬件环境说明编写执行Shell指令的工具类总结jsch(Java Secure Channel)是SSH2的一个纯J

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则

python 线程池顺序执行的方法实现

《python线程池顺序执行的方法实现》在Python中,线程池默认是并发执行任务的,但若需要实现任务的顺序执行,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录方案一:强制单线程(伪顺序执行)方案二:按提交顺序获取结果方案三:任务间依赖控制方案四:队列顺序消

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

MySQL按时间维度对亿级数据表进行平滑分表

《MySQL按时间维度对亿级数据表进行平滑分表》本文将以一个真实的4亿数据表分表案例为基础,详细介绍如何在不影响线上业务的情况下,完成按时间维度分表的完整过程,感兴趣的小伙伴可以了解一下... 目录引言一、为什么我们需要分表1.1 单表数据量过大的问题1.2 分表方案选型二、分表前的准备工作2.1 数据评估

MySQL中DATE_FORMAT时间函数的使用小结

《MySQL中DATE_FORMAT时间函数的使用小结》本文主要介绍了MySQL中DATE_FORMAT时间函数的使用小结,用于格式化日期/时间字段,可提取年月、统计月份数据、精确到天,对大家的学习或... 目录前言DATE_FORMAT时间函数总结前言mysql可以使用DATE_FORMAT获取日期字段

基于Python Playwright进行前端性能测试的脚本实现

《基于PythonPlaywright进行前端性能测试的脚本实现》在当今Web应用开发中,性能优化是提升用户体验的关键因素之一,本文将介绍如何使用Playwright构建一个自动化性能测试工具,希望... 目录引言工具概述整体架构核心实现解析1. 浏览器初始化2. 性能数据收集3. 资源分析4. 关键性能指

Python标准库datetime模块日期和时间数据类型解读

《Python标准库datetime模块日期和时间数据类型解读》文章介绍Python中datetime模块的date、time、datetime类,用于处理日期、时间及日期时间结合体,通过属性获取时间... 目录Datetime常用类日期date类型使用时间 time 类型使用日期和时间的结合体–日期时间(

解密SQL查询语句执行的过程

《解密SQL查询语句执行的过程》文章讲解了SQL语句的执行流程,涵盖解析、优化、执行三个核心阶段,并介绍执行计划查看方法EXPLAIN,同时提出性能优化技巧如合理使用索引、避免SELECT*、JOIN... 目录1. SQL语句的基本结构2. SQL语句的执行过程3. SQL语句的执行计划4. 常见的性能优