struts2常用常量的定义与意义

每一次请求都会创建一个新的action,所以struts2的action是线程安全的

拆分struts

为应用指定多个struts配置文件
src 下为各应用配置的(.xml)struts配置文件,都需在struts.xml进行调用
<include file="customer.xml"></include>

配置错误页

配置 package范围的错误页  只在当前package范围内有效
<package name="customer" namespace="/customer" extends="struts-default">
<global-results>
<result type="dispatcher" name="error">/customer/error.jsp</result>
</global-results>
<action name="addCustomer" class="cn.gs.wwg.CustomerAction" method="addcustomer">
<result type="dispatcher" name="success">/customer/success.jsp</result>
</action>
<action name="updateCustomer" class="cn.gs.wwg.CustomerAction" method="updatecustomer">
<result type="dispatcher" name="success">/customer/success.jsp</result>
</action>
</package> 配置全局错误页
<package name="mypackage" extends="struts-default">
<global-results>
<result type="dispatcher" name="error">/customer/error.jsp</result>
</global-results>
</package>
需要处理错误的package, 都继承mypackage

动态方法调用: !+方法名,

可以访问同一action中另一方法 http://localhost:8080/struts2day02/customer/addCustomer!updatecustomer本来

应该执行“添加方法” 动态调用变成访问“修改方法”(开发中禁止使用)

使用通配符

     <package name="orders" namespace="/orders" extends="mypackage">
<action name="orders_*" class="cn.itcast.action.OrdersAction" method="{1}">
<result type="dispatcher" name="success">/orders/success.jsp</result>
</action>
</package>
接收请求参数
使用post。正常接收
使用get提交会出现乱码,解决方式:在加载 struts2 过滤器之前加入 编码过滤器
解决乱码:
web.xml中注册
<!-- 过滤器配置开始 -->
<filter>
<description>全站乱码过滤器</description>
<filter-name>EncodeFilter</filter-name>
<filter-class>com.zj.filter.EncodeFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>EncodeFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
解决乱码的另一方法
<!-- 全站参数配置 -->
<context-param>
<description>全站编码配置</description>
<param-name>encode</param-name>
<param-value>utf-8</param-value>
</context-param>

 自定义类型转换器:
  input:当数据类型转换及数据验证出现错误信息时,框架自动转向result 属性 name=input 所指定的页面,
  <result type="dispatcher" name="input">/customer/add.jsp</result>

  1、继承DefaultTypeConverter类

  2、覆盖掉其中的convertValue方法

 package cn.gs.ly.converter;

 import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Map; import com.opensymphony.xwork2.conversion.impl.DefaultTypeConverter; public class DateConverter extends DefaultTypeConverter{
/**
* 1.继承DefaultTypeConverter类
* 2.重写 convertValue 方法。写逻辑。在里面进行数据转型
* 3.注册类型转换器
* 1局部类型转换器--只对当前action有效
* 在action类所在的包下放置ActionClassName(动作类名)-conversion.properties文件
* 内容如下:要验证的字段=类型转换器的全类名(既包名.类名)(例:birthday = cn.gs.ly.converter.DateConverter)
* 2全局类型转换器--对所有的action都有效
* WEB-INF/classes目录下(即工程src根目录下) 建立一个名称为:xwork-conversion.properties"的配置文件
* 内容如下:待转换的类型=类型转换器的全类名(例:java.util.Date = cn.gs.ly.converter.DateConverter)
*
*/ @Override
public Object convertValue(Map<String, Object> context, Object value, Class toType) {
/**
* context:OGNL 表达式上下文
* value: 实际的值,用户输入的字符串,是一个数组
* toType:目标类型
* */ DateFormat df = new SimpleDateFormat("yyyy/MM/dd");
DateFormat df1 = new SimpleDateFormat("yyyy-MM-dd");
//if(value.toString().split("//").length>1){ // 按"/"拆分大于1个,即输入是yyyy/MM/dd形式的,if对各形式进行转换格式
if(toType==Date.class){ //是否为Date类型 // 当字符串向Date类型转换时
try {
// yyyy/MM/dd-->date
String strVal = ((String [])value)[]; //取用户输入的第一个字符串
return df.parse(strVal); } catch (ParseException e) {
e.printStackTrace();
}
}else{
// date-->yyyy/MM/dd // 当Date转换成字符串时
Date dVal = (Date)value;
return df.format(dVal);
}
//}
return null;
} }

  3、注册类型转换器

 .局部类型转换器:只对当前action有效
在动作类相同的包下,建立一个名称是:"动作类名-conversion.properties"的配置文件
内容:要验证的字段=验证器类全名(birthday=cn.gs.ly.converter.DateConverter)
.全局类型转换器:对所有action都有效
WEB-INF/classes目录下(src) 建立一个名称为"xwork-conversion.properties"的配置文件
内容: 目标类型全名=验证器类全名 (java.util.Date = cn.gs.ly.converter.DateConverte)

访问或添加request/session/application

 package cn.gs.ly;

 import java.util.Map;

 import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionSupport;
/**
* 域范围
* 向各大域范围存放点数据
* */
public class ScopeAction extends ActionSupport {
@Override
public String execute() throws Exception {
ActionContext ac = ActionContext.getContext();
Map<String, Object> map = ac.getApplication(); //这个就是ServletContext对象中维护的那个Map
// ServletContext.setAttribute(key,object);
map.put("message", "application test"); //servletContext 范围
// HttpSession.setAttribute(key,object);
ac.getSession().put("message", "session test"); //session 范围
//相当于ServletRequest.setAttribute(key,obj);
ac.put("message", "request test"); //request 范围 return SUCCESS; //或 其父类 return super.execute(); }
}

在jsp中可以得到

applicationScope生存周期是整个应用 
sessionScope生存周期是整个会话 
requestScope生存周期是一次请求

 <body>
APPLICATION:${applicationScope.message} <br/>
SESSION:${sessionScope.message} <br/>
REQUEST:${requestScope.message} <br/>
</body>

常用servlet对象的获取

方式一:ServletActionContext

     public String execute1() {
HttpSession se = ServletActionContext.getRequest().getSession();
System.out.println(se);
// ServletRequest request = ServletActionContext.getRequest();
// System.out.println(request);
return SUCCESS;
}

方式二:实现指定接口,由struts框架运行时注入

 package cn.gs.ly;

 import javax.servlet.ServletContext;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession; import org.apache.struts2.ServletActionContext;
import org.apache.struts2.interceptor.ServletRequestAware;
import org.apache.struts2.interceptor.ServletResponseAware;
import org.apache.struts2.util.ServletContextAware; import com.opensymphony.xwork2.ActionSupport;
/**
* 获取应用中常用对象的引用方法
* 1.ServletActionContext
* 2.实现 ***Aware 接口。实现指定接口,由struts框架运行时注入
* */
public class webAction extends ActionSupport implements Serializable,ServletContextAware,ServletRequestAware,ServletResponseAware {
private ServletContext context;
private HttpServletRequest request;
private HttpServletResponse response; public String execute2(){
System.out.println(context);
System.out.println(request);
System.out.println(response);
return SUCCESS;
}
public void setServletContext(ServletContext context) {//如果动作类实现了ServletContextAware接口,就会自动调用该方法
this.context = context;
}
public void setServletRequest(HttpServletRequest request) {
this.request = request;
}
public void setServletResponse(HttpServletResponse response) {
this.response = response;
}
}

struts2 基础2 类型转换器的更多相关文章

  1. struts2基础---->自定义类型转换器

    这一章,我们开始struts2中自定义类型转换器的学习. 自定义类型转换器

  2. struts2自己定义类型转换器

    1.1.  struts2自己定义类型转换器 1)        自定类型转换类,继承DefaultTypeConverter类 package com.morris.ticket.conversio ...

  3. Struts2之自定义类型转换器

    Struts2自定义类型转换器分为局部类型转换器和全局类型转换器 (1)局部类型转换器 如果页面传来一个参数reg.action?birthday=2010-11-12到后台action,然后属性用d ...

  4. struts2自定义日期类型转换器

    在java web表单中提交的数据难免会有日期类型,struts2支持的日期类型是yyyy-MM-dd,如果是其他格式,就需要自己进行转换.比如yy-MM-dd 要完成自己定义的转换需要完成. 主要的 ...

  5. 自己定义struts2中action类型转换器

    DateAction.java中代码例如以下: package com.itheima.action; import java.util.Date; public class DateAction { ...

  6. struts2学习笔记之十一:struts2的类型转换器

    Struts2的类型转换器   如何实现Struts2的类型转换器? * 继承StrutsTypeConverter * 覆盖convertFromString和convertToString   注 ...

  7. struts2类型转换器、 类型转换错误 以及INPUT view

    1.1.1    Struts2中的类型转换器 Struts2内置了常见数据类型多种转换器 boolean 和 Boolean char和 Character int 和 Integer long 和 ...

  8. struts2自定义类型转换器

    首先,何为struts2的类型转换器? 类型转换器的作用是将请求中的字符串或字符串数组参数与action中的对象进行相互转换. 一.大部分时候,使用struts2提供的类型转换器以及OGNL类型转换机 ...

  9. Struts2的类型转换器

    Struts2的类型转换器 如何实现Struts2的类型转换器? * 继承StrutsTypeConverter * 覆盖convertFromString和convertToString 注册类型转 ...

随机推荐

  1. Linux系统性能测试工具(七)——网络性能工具之iperf

    本文介绍关于Linux系统(适用于centos/ubuntu等)的网络性能测试工具-iperf.磁盘io性能测试工具包括: iperf: netperf 参考链接:https://www.cnblog ...

  2. Apache 配置外网站点

    基于域名,一般是对外网站 www.etiantian.org/var/www/html/www blog.etiantian.org /var/www/html/blog bbs.tiantian.o ...

  3. 023-OpenStack 创建实例类型临时磁盘的讲解

    临时磁盘占用的那块磁盘的空间查看 [root@linux-node1 dev]# fdisk -l 磁盘 /dev/sdb:26.8 GB, 26843545600 字节,52428800 个扇区 U ...

  4. VB程序设计中Combobox的取值问题

    Private a As Double   Private Sub Combo1_Click()    '1位小数,系数用10    a = Combo1.ItemData(Combo1.ListIn ...

  5. 图像描点标注-labelme的安装及使用

    1.直接使用pip安装lebelme pip install labelme 2.labelme的使用 找到labelme的安装路径,先找到python的安装路径如我的,C:\Users\Think\ ...

  6. 深度复数网络 Deep Complex Networks

    转自:https://www.jiqizhixin.com/articles/7b1646c4-f9ae-4d5f-aa38-a6e5b42ec475  (如有版权问题,请联系本人) 目前绝大多数深度 ...

  7. flask框架上下文

    上下文 上下文:相当于一个容器,保存了 Flask 程序运行过程中的一些信息. Flask中有两种上下文,请求上下文和应用上下文 请求上下文(request context) 在 flask 中,可以 ...

  8. 【学习】021 Nginx

    nginx入门 什么是nginx? nginx是一款高性能的http 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器.由俄罗斯的程序设计师Igor Sysoev所开发,官方测试ngi ...

  9. 【学习】 015 Linux相关

    Linux入门 什么是Linux Linux简介 Linux是一种自由和开放源码的操作系统,存在着许多不同的Linux版本,但它们都使用了Linux内核.Linux可安装在各种计算机硬件设备中,比如手 ...

  10. pandas的settingwithWaring报警

    # 0 读取数据 import pandas as pd df = pd.read_csv("beijing_tianqi_2018.csv") # 换掉温度后面的后缀 df.lo ...