struts2介绍
Struts 2是在WebWork2基础发展而来的。好处在于struts 2 能帮助我们很好的将前端的view层和后端逻辑层分开。
PS:struts 2和struts 1在代码风格上几乎不一样。
Struts 2 相比Struts 1的优点:
1、在软件设计上Struts 2 没有像Struts 1那样跟Servlet API 和 struts API 有着紧密的耦合。
Struts 2的应用可以不依赖于Servlet API和Struts API 。
2、Struts 2 提供了拦截器,利用拦截器可以进行AOP编程。
3、Struts 2 提供了类型转换器。
4、Struts 2 提供支持多种表现层技术,如:JSP 、 freeMarker等。
5、Struts 2 的输入校验可以指定方法进行校验。
6、Struts 2 提供了全局范围、包范围和Action范围的国际化资源文件管理实现。
Struts 2 流程原理
1、Web浏览器客户端发起request请求。
2、过滤器Dispatcher查找方法,确定适当的Action。
3、拦截器自动对请求应用通用功能,如验证和文件上传操作。
4、Action的execute方法通常用来存储和重新获得信息。
5、结果被返回到浏览器。
开发环境搭建1、找到开发Struts 2的应用需要用到的jar包。
2、编写Struts 2的配置文件。
3、在web.xml中加入Struts 2 MVC启动框架配置。
开发Struts 2 最少用到的jar文件:
Struts-core-2.x.x.jar : Struts 2 框架的核心类库
xwork-2.x.x.jar : XWork类库,Struts 2 在其上构建
ognl-2.6.x.jar : Object Graph Navigation Language , Struts 2 框架通过其读写对象的属性。
freemarker-2.3.x.jar : Struts 2 的UI标签的模版使用 Freemarker编写。
commons-logging-1.1.x.jar : ASF出品的日志包。
commons-fileupload-1.2.1.jar : 文件上传组件。
1 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">
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
<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>
</web-app>
可以看出,在Struts 2中,Struts框架是通过Filter启动的,在StrutsPrepareAndExecuteFilter的init()方法中读取类路径下默认的配置文件struts.xml完成初始化操作。
注意:struts2读取到struts.xml中的内容后,以javabean的形式保存在内存中,以后struts2对用户的每次请求处理将使用内存中的数据,而不是每次都读取struts.xml文件。
Filter 过滤器是用户请求和处理程序之间的一层处理程序。它可以对用户请求和处理程序响应的类容进行处理,通常用于权限、编码转换等场合。
2 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>
<!--打开dmi Struts2.3之后该功能默认是关闭的,若需要使用action!method 需要手动打开-->
<constant name="struts.enable.DynamicMethodInvocation" value="true" />
<!-- dev-mode,好处在于我们修改了配置文件的时候能够自动热替换 开发时很方便 -->
<constant name="struts.devMode" value="true" />
<package name="user" extends="struts-default" namespace="/user">
<action name="userAdd" class="com.struts.ActionMethod" method="add">
<result name="add">
/user_add_success.jsp
</result>
</action>
<action name="user" class="com.struts.ActionMethod" >
<result name="add">
/user_add_success.jsp
</result>
</action>
</package>
</struts>
struts.xml需要存放在WEB-INF/classes下,Struts.xml是 Struts 2 的核心配置文件,主要用于配置开发人员编写的action。
注意:
result中的name属性有下:
1、success : 表示请求处理成功,该值也是默认值。
2、error :表示请求处理失败。
3、none :表示请求处理完成后不跳转到任何页面。
4、input :表示输入时如果验证失败应该跳转到什么地方。
5、login :表示登录失败后跳转的目标。
3、ActionSupport 类
ActionSupport 类为 Action 提供了一些默认实现,主要包括预定义常量、从资源文件中取文本资源、接收验证错误信息和验证的默认实现。
以下开始就记录一下学习Struts是记录的一些笔记吧
2016年6月18日,今天学习了Struts通配符的使用,没学习多少,但是感觉是很好的吸收了学习内容了:
<?xml version="1.0" encoding="GB18030" ?>
<%@ page language="java" contentType="text/html; charset=GB18030"
pageEncoding="GB18030"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
//在head中<base href>指定basePath
%>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<%-- <base href=<%= basePath %> /> --%>
<meta http-equiv="Content-Type" content="text/html; charset=GB18030" />
<title>Insert title here</title>
</head>
<body>
使用通配符,是配置量降到最低<br />
<a href="actions/Studentadd">添加学生</a>
<br />
<a href="actions/Studentdelete">删除学生</a>
<br />
不过,一定要遵守“约定优于配置”的原则<br />
<a href="actions/Teacher_add">添加老师</a>
<a href="actions/Teacher_delete">删除老师</a>
</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>
<!--打开dmi Struts2.3之后该功能默认是关闭的,若需要使用action!method 需要手动打开-->
<constant name="struts.enable.DynamicMethodInvocation" value="true" />
<!-- dev-mode,好处在于我们修改了配置文件的时候能够自动热替换 开发时很方便 -->
<constant name="struts.devMode" value="true" />
<package name="actions" extends="struts-default" namespace="/actions">
<action name="Student*" class="com.struts.action.StudentAction" method="{1}">
<result>
/Student{1}_success.jsp
</result>
</action>
<action name="*_*" class="com.struts.action.{1}Action">
<result>/{1}_{2}_success.jsp</result>
</action>
</package>
</struts>
PS:今天学习重点是“约定优于配置”,一个好的项目的约定是非常重要的,有了约束就有了规范,这在开发过程中能省下不少时间。
前台点击链接之后,Struts会去优先找精确匹配的名字,如果没有则在通配了*的action去自上而下找,自动去匹配符合前台传过来的action名字和方法,在xml里找到对应的页面返回到浏览器。