博客
关于我
struts2 session传值 通配符 validate 动态方法调用 倒计时刷新跳转
阅读量:327 次
发布时间:2019-03-04

本文共 1759 字,大约阅读时间需要 5 分钟。

1.通配符*

<action name="login_*" class="com.action.LoginAction" method="Login{1}">

<result name="success">/success.jsp</result>

</action>

 

Login_*:*表示接收任意字符,

{1}:表示第一个通配符*所传递过来的内容,如果*为A,那{1}就代表A,那么method就是LoginA方法

{0}:表示匹配所用action name的内容 例如:login_A

2.DynamicMethodInvocation:动态方法调用

<constant name="struts.enable.DynamicMethodInvocation" value="true"></constant>

 

设置是否动态方法调用,value设置为true,就表示为开启状态,允许动态方法调用

 

动态方法如何调用:

        在浏览器地址栏输入要访问的Action名字(name)由!+方法调用,格式为 login!LoginA    表示访问action的name为login的类中LoginA的方法。

 

  1. 如何获取session向Session中存储值(3种方式)
  1. ActionContext上下文获取

ActionContext.getContext().getSession().put(name,value);

  1. ServletActionContext方式获取

HttpServletSession session=ServletACtionContex t.getRequest().getSession();

Session.setAttribute(anme,value);

  1. 通过实现ServletRequestAware里的方法,获取

Class login implements ServletRequestAware{

public void  setServletRequest(HttpServletRequest request) {

// TODO Auto-generated method stub

Request.getSession().Session.setAttribute(a nme,value);

 

} 

}

 

  1. Validate

this.addFieldError("namenull", "用户名或密码不能为空!");  在validate验证方法里,加上这行代码的效果是添加错误字段验证,在前台获取的方式是

1.加载struts2标签,

<%@ page taglib uri=/struts-tags prefix=s%>

  1. 获取字段验证错误信息:

<s:fielderror fieldname=namenull></s:fielderror>

 

  1. 如何在Action类中执行LoginA()方法之前,执行验证LoginA()的方法

1.在类名上继承ActionSupport

Class loginAction extends ActionSupport{

 

}

  1. 添加LoginA()方法

Public String LoginA(){

Return success;

}

  1. 添加验证LoginA的方法(一般都是    validate+XXX(LoginA))例如:

Public void validateLoginA(){

在里面添加判断或者验证错误信息

this.addFieldError("namenull", "用户名或密码不能为空!"); 

}

5.前端网页倒计时刷新跳转

<meta http-equiv="refresh" content="5;url=menu.jsp">

网页5秒后刷新跳转到menu.jsp页面

倒计时代码:

<script type="text/javascript">

$(function(){

var t=5;

function a(){

if (t<0){}else{

$("h2").text(t+" s!");

t--;

setTimeout(a,1000);

}

 

}

a();

})

</script>

 

 

 

大概今天就这么多内容。

 

转载地址:http://esnq.baihongyu.com/

你可能感兴趣的文章
mysql 数据库中 count(*),count(1),count(列名)区别和效率问题
查看>>
mysql 数据库备份及ibdata1的瘦身
查看>>
MySQL 数据库备份种类以及常用备份工具汇总
查看>>
mysql 数据库存储引擎怎么选择?快来看看性能测试吧
查看>>
MySQL 数据库操作指南:学习如何使用 Python 进行增删改查操作
查看>>
MySQL 数据库的高可用性分析
查看>>
MySQL 数据库设计总结
查看>>
Mysql 数据库重置ID排序
查看>>
Mysql 数据类型一日期
查看>>
MySQL 数据类型和属性
查看>>
mysql 敲错命令 想取消怎么办?
查看>>
Mysql 整形列的字节与存储范围
查看>>
mysql 断电数据损坏,无法启动
查看>>
MySQL 日期时间类型的选择
查看>>
Mysql 时间操作(当天,昨天,7天,30天,半年,全年,季度)
查看>>
MySQL 是如何加锁的?
查看>>
MySQL 是怎样运行的 - InnoDB数据页结构
查看>>
mysql 更新子表_mysql 在update中实现子查询的方式
查看>>
MySQL 有什么优点?
查看>>
mysql 权限整理记录
查看>>