1、什么是Struts2
Strut是一种基于MVC模式的轻量级的web框架,本质上相当于一个Servlet,Struts2作为控制器来建立模型与视图的数据交互。具有以下优势:
提供Exception处理机制;Result方式的页面导航,通过Result标签很方便的实现重定向和页面跳转;通过简单、集中的配置来调度业务类,使得配置和修改都非常容易;提供简单、统一的表达式语言来访问所有可供访问的数据;提供标准、强大的表达式语言来访问所有可供访问的数据;提供强大的、可以有效减少页面代码的标签;提供良好的Ajax支持。
2、Struts框架的搭建
3、配置详解
HelloAction.java
package cn.ctgu.struts;
//Action类
public class HelloAction {
public String hello() {
System.out.println("hello world");
return "success";
}
}
src下的struts.xml
<struts>
<constant name="struts.i18n.encoding" value="UTF-8">constant>
<constant name="struts.action.extension" value="do,,">constant>
<constant name="struts.devMode" value="true">constant>
<package name="struts" namespace="/hello" extends="struts-default">
<action name="HelloAction" class="cn.ctgu.struts.HelloAction" method="hello">
<result name="success" type="dispatcher">/hello.jspresult>
action>
package>
<include file="cn/ctgu/dynamic/struts.xml">include>
<include file="cn/ctgu/_default/struts.xml">include>
struts>
web.xml
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
<display-name>Struts2_1display-name>
<filter>
<filter-name>struts2filter-name>
<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilterfilter-class>
filter>
<filter-mapping>
<filter-name>struts2filter-name>
<url-pattern>/*url-pattern>
filter-mapping>
<welcome-file-list>
<welcome-file>index.htmlwelcome-file>
<welcome-file>index.htmwelcome-file>
<welcome-file>index.jspwelcome-file>
<welcome-file>default.htmlwelcome-file>
<welcome-file>default.htmwelcome-file>
<welcome-file>default.jspwelcome-file>
welcome-file-list>
web-app>
动态调用
package cn.ctgu.dynamic.Demo2Action.java
package cn.ctgu.dynamic;
//动态方法调用
public class Demo1 {
public String add() {
System.out.println("添加用户");
return "success";
}
public String delete() {
System.out.println("删除用户");
return "success";
}
public String update() {
System.out.println("修改用户");
return "success";
}
public String find() {
System.out.println("查找用户");
return "success";
}
}
cn.ctgu.dynamic下的struts.xml
<struts>
<constant name="struts.i18n.encoding" value="UTF-8">constant>
<constant name="struts.action.extension" value="do,,">constant>
<constant name="struts.devMode" value="true">constant>
<package name="dynamic" namespace="/" extends="struts-default">
<action name="Demo_*" class="cn.ctgu.dynamic.Demo1" method="{1}">
<result name="success" type="dispatcher">/hello.jspresult>
action>
package>
struts>
使用默认配置
package cn.ctgu._default.Demo2Action.java
package cn.ctgu._default;
//测试默认配置
public class Demo2Action {
public String execute() {
System.out.println("Demo2Action~~~~~~");
return "success";
}
}
cn.ctgu._default下的struts.xml
<struts>
<package name="default" namespace="/default" extends="struts-default">
<default-action-ref name="Demo2Action">default-action-ref>
<action name="Demo2Action" class="cn.ctgu._default.Demo2Action" method="execute">
<result name="success">/hello.jspresult>
action>
package>
struts>
4、API类详解
配置文件时上面src下的struts.xml
Demo3Action.java
package cn.ctgu.api;
//方式1:创建一个类,可以使POJO
//POJO:不用继承任何父类,也不需要实现任何接口
//使struts框架的代码侵入性更低
//不常用
public class Demo3Action {
}
Demo4Action.java
package cn.ctgu.api;
import com.opensymphony.xwork2.Action;
//方式2:实现一个接口Action
//里面有execute方法,提供action方法的规范
//Action接口预置了一些字符串,可以在返回结果时使用,为了方便,例如: success none error......
//不常用
public class Demo4Action implements Action{
@Override
public String execute() throws Exception {
// TODO Auto-generated method stub
return null;
}
}
Demo5Action.java
package cn.ctgu.api;
import com.opensymphony.xwork2.ActionSupport;
//方式3:继承一个类,ActionSupport
//帮我们实现了Validateable,ValidationAware,TextProvider,LocaleProvider
//如果我们需要用到这些接口的实现时,不需要自己来实现了
public class Demo5Action extends ActionSupport{
}