struts2框架学习第一天
来源:互联网 发布:国外手机号码数据库 编辑:程序博客网 时间:2024/06/09 16:35
struts2框架学习大纲:
- 介绍struts2
关于struts2配置(关于Action配置)—重点
关于struts2结果类型 - struts2处理请求参数—重点
struts2的类型转换
struts2的校验 - struts2国际化
struts2拦截器—-重点
struts2文件上传与下载
struts2中ognl与valuestack—-重点 - ognl与valuestatck—–重点
struts2中的防止表单重复提交
struts2中ajax插件. - 练习
1.介绍struts2框架
问题:什么是框架,框架有什么用?
框架 是 实现部分功能的代码 (半成品),使用框架简化企业级软件开发 ,提高开发效率。
学习框架 ,清楚的知道框架能做什么? 还有哪些工作需要自己编码实现 ?
问题:什么是struts2框架,它有什么用?
Struts 2是Struts的下一代产品,是在 struts 1和WebWork的技术基础上进行了合并的全新的Struts 2框架。
其全新的Struts 2的体系结构与Struts 1的体系结构差别巨大。Struts 2以WebWork为核心
struts2=struts1+webwork;
struts2框架是apache产品。
struts2是一个标准的mvc框架。 javaweb中的model2模式就是一个mvc模式。 model2=servlet+jsp+javaBean
struts2框架是在javaweb开发中使用的。
使用struts2框架,可以简化我们的web开发,并且降低程序的耦合度。类似于struts2框架的产品 :
struts1 webwork jsf springmvc
ssh—struts2 spring hibernate
ssi—springmvc spring ibatis
XWork—它是webwork核心
Xwork提供了很多核心功能:前端拦截机(interceptor),运行时表单属性验证,类型转换,强大的表达式语言(OGNL – the Object Graph Navigation Language),IoC(Inversion of Control反转控制)容器等
2.struts2快速入门:
index.jsp——>HelloServlet——–>hello.jsp web开发流程.
index.jsp——>HelloAction———>hello.jsp struts2流程
1.导入jar包
下载struts2的jar包 struts-2.3.15.1-all 版本. struts2的目录结构: apps: 例子程序 docs:文档 lib:struts2框架所应用的jar以及插件包 src:源代码 core 它是struts2的源代码 xwork-core struts2底层使用了xwork,xwork的源代码
注意:在struts2开发,一般情况下最少导入的jar包,去apps下的struts2-blank示例程序中copy
2.创建index.jsp页面,创建hello.jsp页面
3.对struts2框架进行配置
- web.xml文件中配置前端控制器(核心控制器)—–就是一个Filter
目的:是为了让struts2框架可以运行。
<filter> <filter-name>struts2</filter-name> <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class></filter> <filter-mapping> <filter-name>struts2</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
- 创建一个struts.xml配置文件 ,这个是struts2框架配置文件。
目的:是为了struts2框架流程可以执行。
名称:struts.xml
位置:src下(classes下)
4.创建一个HelloAction类
要求,在HelloAction类中创建一个返回值是String类型的方法,注意,无参数。
public String say(){ return "good";}
5.在struts.xml文件中配置HelloAction
<package name="default" namespace="/" extends="struts-default"> <action name="hello" class="cn.itcast.action.HelloAction" method="say"> <result name="good">/hello.jsp</result> </action></package>
6.在index.jsp中添加连接,测试
<a href="${pageContext.request.contextPath}/hello">第一次使用struts2</a>
在地址栏中输入:http://localhost/项目名/index.jsp 访问连接,就可以看到HelloAction类中的say方法执行了,也跳转到了hello.jsp.
3.struts2的流程分析以及工具配置
1.流程分析
请求 —- StrutsPrepareAndExecuteFilter 核心控制器 —– Interceptors 拦截器(实现代码功能 ) —– Action 的execute — 结果页面 Result
* 拦截器 在 struts-default.xml定义
* 执行拦截器 是 defaultStack 中引用拦截器
—- 通过源代码级别断点调试,证明拦截器是执行
2.关于手动配置struts.xml文件中提示操作
如果安装Aptana编辑器 ,请不要用Aptana自带xml编辑器 编写struts2配置文件 struts.xml提示来自于 DTD约束,
<!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN""http://struts.apache.org/dtds/struts-2.3.dtd">
如果可以上网,自动缓存dtd,提供提示功能
如果不能上网,也可以配置本地DTD提示
注意:导入DTD时,应该和配置DTD版本一致
3.关联struts2源文件
如果是com.opensymphony.xxx 在xwork-core下
如果是org.apache.struts2 在core下
4.使用插件 struts2-config-browser-plugin-2.3.15.1
提供在浏览器中查看 struts2 配置加载情况
将解压struts2/lib/struts2-config-browser-plugin-2.3.7.jar 复制WEB-INF/lib下
访问 http://localhost/struts2_day01/config-browser/index.action 查看 struts2配置加载情况
4.struts2配置(重点)
1.struts2配置文件加载顺序
struts2框架要能执行,必须先加载StrutsPrepareAndExecuteFilter.
在StrutsPrepareAndExecuteFilter的init方法中对Dispatcher进行了初始化.在Dispatcher类中定义的init方法内就描述了struts2配置文件加载的顺序
init_DefaultProperties(); // [1] ---------- org/apache/struts2/default.properties init_TraditionalXmlConfigurations(); // [2] --- struts-default.xml,struts-plugin.xml,struts.xmlinit_LegacyStrutsProperties(); // [3] --- 自定义struts.properties init_CustomConfigurationProviders(); // [5] ----- 自定义配置提供init_FilterInitParameters() ; // [6] ----- web.xml init_AliasStandardObjects() ; // [7] ---- Bean加载
- default.properties文件
作用:定义了struts2框架中所有常量
位置: org/apache/struts2/default.properties - struts-default.xml
作用:配置了bean,interceptor,result等。位置:在struts的core核心jar包.
struts-plugin.xml
它是struts2框架中所使用的插件的配置文件。
struts.xml
我们使struts2所使用的配置文件。 - 自定义的struts.properties
就是可以自定义常量。 - web.xml
在开发中,后加载文件中的配置会将先加载文件中的配置覆盖。
default.properties
struts-default.xml
struts.xml
2.关于Action的配置
1. <package> 作用:是用于声明一个包。用于管理action。
- name 它用于声明一个包名,包名不能重复,也就是它是唯一的。
- namespace 它与action标签的name属性合并确定了一个唯一访问action的路径。
- extends 它代表继承的包名。
- abstrace 它可以取值为true/false,如果为true,代表这个包是用于被继承的。
2<action> 用于声明 一个action
- name :就是action的一个名称,它是唯一的(在同包内) 它与package中的namespace确定了访问action的路径。
- class :Action类的全名
- method: 要访问的Action类中的方法的名称,方法无参数 ,返回值为String.
3.<result>用于确定返回结果类型
- name 它与action中的方法返回值做对比,确定跳转路径。
关于action配置其它细节:
1.关于默认值问题 <package namespace="默认值">
namespace的默认值是”“ <action class="默认值" method="默认值">
class的默认值是 com.opensymphony.xwork2.ActionSupport
method的默认值是 execute <result\d X name="默认值">
name的默认值是 “success”
2.关于访问action的路径问题
现在的action的配置是:
<package name="default" namespace="/" extends="struts-default"> <action name="hello" class="cn.itcast.action.DefaultAction"> <result>/hello.jsp</result> </action></package>
当我们输入:http://localhost/struts2_day01_2/a/b/c/hello也访问到了action。
原因:struts2中的action被访问时,它会首先查找
①namespace=”/a/b/c” action的name=hello 没有.
②namespace=”/a/b action的name=hello 没有
③namespace=”/a” action的name=hello 没有
④namespace=”/” action的name=hello 查找到了.
如果最后也查找不到,会报404错误.
3.默认的action。
作用:处理其它action处理不了的路径。
<default-action-ref name="action的名称" />
配置了这个,当访问的路径,其它的action处理不了时,就会执行name指定的名称的action。
4.action的默认处理类
在action配置时,如果class不写。默认情况下是 com.opensymphony.xwork2.ActionSupport。 <default-class-ref class="cn.itcast.action.DefaultAction"/>
如果设置了,那么在当前包下,默认处理action请的的处理类就为class指定的类。
5.关于常量配置
default.properties 它声明了struts中的常量。
问题:人为设置常量,可以在哪些位置设置 ?
1. struts.xml(应用最多) <constant name="常量名称" value="常量值"></constant>
2.struts.properties(基本不使用)
3. web.xml(了解)
配置常量,是使用StrutsPrepareAndExecuteFilter的初始化参数来配置的.
<init-param> <param-name>struts.action.extension</param-name> <param-value>do,,</param-value></init-param>
常用常量
struts.action.extension=action,,
这个常量用于指定strus2框架默认拦截的后缀名. <constant name="struts.i18n.encoding" value="UTF-8"/>
相当于request.setCharacterEncoding(“UTF-8”); 解决post请求乱码 <constant name="struts.serve.static.browserCache" value="false"/>
false不缓存,true浏览器会缓存静态内容,产品环境设置true、开发环境设置false <constant name="struts.devMode" value="true" />
提供详细报错页面,修改struts.xml后不需要重启服务器 (要求)
6.struts.xml文件的分离:
目的:就是为了阅读方便。可以让一个模块一个配置文件,在struts.xml文件中通过 <include file="test.xml"/>
导入其它的配置文件。
7.Action的创建
①关于Action类的创建方式介绍:有三种方式
1.创建一个POJO类.
简单的Java对象(Plain Old Java Objects)
指的是没有实现任何接口,没有继承任何父类(除了Object)
优点:无耦合。
缺点:所以工作都要自己实现。
在struts2框架底层是通过反射来操作:
* struts2框架 读取struts.xml 获得 完整Action类名
* obj = Class.forName(“完整类名”).newInstance();
* Method m = Class.forName(“完整类名”).getMethod(“execute”); m.invoke(obj); 通过反射 执行 execute方法
2.创建一个类,实现Action接口. com.opensymphony.xwork2.Action
优点:耦合低。提供了五种结果视图,定义了一个行为方法。
缺点:所以工作都要自己实现。
public static final String SUCCESS = “success”; // 数据处理成功 (成功页面)
public static final String NONE = “none”; // 页面不跳转 return null; 效果一样
public static final String ERROR = “error”; // 数据处理发送错误 (错误页面)
public static final String INPUT = “input”; // 用户输入数据有误,通常用于表单数据校验 (输入页面)
public static final String LOGIN = “login”; // 主要权限认证 (登陆页面)
3.创建一个类,继承自ActionSupport类. com.opensymphony.xwork2.ActionSupport
ActionSupport类实现了Action接口。
优点:表单校验、错误信息设置、读取国际化信息 三个功能都支持.
缺点:耦合度高。
在开发中,第三种会使用的比较多.
8.关于action的访问
1.通过设置method的值,来确定访问action类中的哪一个方法. <action name="book_add" class="cn.itcast.action.BookAction" method="add"></action>
当访问的是book_add,这时就会调用BookAction类中的add方法。 <action name="book_update" class="cn.itcast.action.BookAction" method="update"></action>
当访问的是book_update,这时就会调用BookAction类中的update方法。
2.使用通配符来简化配置
- 在struts.xml文件中
<action name="*_*" class="cn.itcast.action.{1}Action" method="{2}"></action>
- 在jsp页面上
book.jsp
<a href="${pageContext.request.contextPath}/Book_add">book add</a><br><a href="${pageContext.request.contextPath}/Book_update">book update</a><br><a href="${pageContext.request.contextPath}/Book_delete">book delete</a><br><a href="${pageContext.request.contextPath}/Book_search">book search</a><br>
product.jsp
<a href="${pageContext.request.contextPath}/Product_add">product add</a><br><a href="${pageContext.request.contextPath}/Product_update">product update</a><br><a href="${pageContext.request.contextPath}/Product_delete">product delete</a><br><a href="${pageContext.request.contextPath}/Product_search">product search</a><br>
当访问book add时,这时的路径是 Book_add,那么对于struts.xml文件中.第一个星就是 Book第二个星就是 add
对于{1}Action—->BookAction
对于method={2}—>method=add
使用通配符来配置注意事项:
①必须定义一个统一的命名规范。
②不建议使用过多的通配符,阅读不方便。
3.动态方法调用 (了解)
在struts.xml文件中 <action name="book" class="cn.itcast.action.BookAction"></action>
访问时路径: http://localhost/struts2_day01_2/book!add
就访问到了BookAction类中的add方法。
对于book!add 这就是动态方法调用。
注意:struts2框架支持动态方法调用,是因为在default.properties配置文件中设置了动态方法调用为true. struts.enable.DynamicMethodInvocation = true
9.在struts2框架中获取servlet api
对于struts2框架,不建议直接使用servlet api;
在struts2中获取servlet api有三种方式:
1.通过ActionContext来获取
①获取一个ActionContext对象。
ActionContext context=ActionContext.getContext();
②获取servlet api
注意:通过ActionContext获取的不是真正的Servlet api,而是一个Map集合。
- context.getApplication()
- context.getSession()
- context.getParameter();—得到的就相当于request.getParameterMap()
- context.put(String,Object) 相当于request.setAttribute(String,String);
2.注入方式获取(这种方式是真正的获取到了servlet api)
①要求action类必须实现提定接口。
ServletContextAware : 注入ServletContext对象
ServletRequestAware :注入 request对象
ServletResponseAware : 注入response对象
②重定接口中的方法。
private HttpServletRequest request;
③声明一个web对象,使用接口中的方法的参数对声明的web对象赋值.
public void setServletRequest(HttpServletRequest request) { this.request = request;}
扩展:分析其实现:
是使用struts2中的一个interceptor完成的.
<interceptor name="servletConfig" class="org.apache.struts2.interceptor.ServletConfigInterceptor"/>
if (action instanceof ServletRequestAware) { //判断action是否实现了ServletRequestAware接口 HttpServletRequest request = (HttpServletRequest) context.get(HTTP_REQUEST); //得到request对象. ((ServletRequestAware) action).setServletRequest(request);//将request对象通过action中重写的方法注入。}
3.通过ServletActionContext获取.
在ServletActionContext中方法都是static。
getRequest();
getResposne();
getPageContext();
10.Result结果类型
<result>标签
1.name 与action中的method的返回值匹配,进行跳转.
2.type 作用:是用于定义跳转方式
对于type属性它的值有以下几种:
在struts-default.xml文件中定义了type可以取的值
<result-type name="chain" class="com.opensymphony.xwork2.ActionChainResult"/><result-type name="dispatcher" class="org.apache.struts2.dispatcher.ServletDispatcherResult" default="true"/><result-type name="freemarker" class="org.apache.struts2.views.freemarker.FreemarkerResult"/><result-type name="httpheader" class="org.apache.struts2.dispatcher.HttpHeaderResult"/><result-type name="redirect" class="org.apache.struts2.dispatcher.ServletRedirectResult"/><result-type name="redirectAction" class="org.apache.struts2.dispatcher.ServletActionRedirectResult"/><result-type name="stream" class="org.apache.struts2.dispatcher.StreamResult"/><result-type name="velocity" class="org.apache.struts2.dispatcher.VelocityResult"/><result-type name="xslt" class="org.apache.struts2.views.xslt.XSLTResult"/><result-type name="plainText" class="org.apache.struts2.dispatcher.PlainTextResult" />
必会: chain dispatcher redirect redirectAction stream
dispatcher:它代表的是请求转发,也是默认值。它一般用于从action跳转到页面。
chain:它也相当于请求转发。它一般情况下用于从一个action跳转到另一个action。
redirect:它代表的是重定向 它一般用于从action跳转到页面
redirectAction: 它代表的是重定向 它一般用于从action跳转另一个action。
stream:代表的是服务器端返回的是一个流,一般用于下载。
了解: freemarker velocity
11.局部结果页面与全局结果页面
局部结果页面和全局结果页面
<action name="result" class="cn.itcast.struts2.demo6.ResultAction"> <!-- 局部结果 当前Action使用 --> <result name="success">/demo6/result.jsp</result> </action><global-results> <!-- 全局结果 当前包中 所有Action都可以用--> <result name="success">/demo6/result.jsp</result></global-results>
- struts2框架学习第一天
- struts2框架搭建第一天
- Struts2源码学习--第一天
- Struts2 学习记录-第一天
- struts2学习之第一天
- YII框架学习 第一天
- Slim 框架学习,第一天
- Struts2整体学习(第一天)
- 第一天重新学习Struts2的体验
- Struts2入门-第一天学习笔记
- Struts2学习笔记(第一天)
- ThinkPhp框架学习之入门第一天
- 框架学习第一天——struts2_01
- TP框架学习笔记第一天
- CI框架学习笔记第一天
- 学习笔记 Bootstrap 第一天--UI框架
- struts2第一天
- struts2的第一天
- Easy-16
- 分治算法——棋盘覆盖
- Maven依赖范围
- Trie树的建立—查找字典中以特定字符串开头的单词数量(java实现)
- 第二天-2017-05-03
- struts2框架学习第一天
- Android框架之路——Banner实现轮播图(RecyclerView添加Header)
- enum注意事项
- HDU 5974 A Simple Math Problem(数论)
- Android中商品展示案例
- 2016年Linux视频教程基础入门到精通Shell高级编程实战Nginx\MySQL运维下载
- jsp页面中获取session中的值
- 继承中的成员方法
- 05.03面试小结