以前都没有用过WebWork这个框架,只是听说过.没想到现在要用,所以就自学了一下.做了个小例子给大家分享下中间遇到的苦难和经验. 
准备工作:首先要去下载WebWork框架的开发包.我用的2.2.6版本的.

开发过程如下: 
1.建立一个WEB工程.你解压WebWork的开发包以后会发现有两个jar文件在第一级目录里面,把他们拷贝进你的工程里面.然后你还会看见lib目录(webwork开发支持的所有jar文件),lib目录下面有个defult的目录,把这个目录里面的jar文件也都拷贝进你的工程,他们是开发webwork最基本的保障. 
2.在你的web.xml加入下面的代码: 
<servlet> 
<servlet-name>webwork</servlet-name> 
<servlet-class> 
   com.opensymphony.webwork.dispatcher.ServletDispatcher 
</servlet-class> 
</servlet> 
<servlet-mapping> 
<servlet-name>webwork</servlet-name> 
<url-pattern>*.action</url-pattern> 
</servlet-mapping> 
3.创建你的xwork.xml文件,在里面加入下面代码: 
<!DOCTYPE xwork PUBLIC "-//OpenSymphony Group//XWork 1.1.1//EN" "http://www.opensymphony.com/xwork/xwork-1.1.1.dtd"> 
<xwork> 
<include file="webwork-default.xml" /> 
<package name="webwork" extends="webwork-default"> 
<action name="hello" 
   <result name="yes" type="dispatcher">/yes.jsp</result> 
</action> 
</package> 
</xwork> 
4.创建webwork.properties文件(和xwork.xml放在一个文件夹下),写入下列代码 
webwork.i18n.encoding=GBK 
### Load custom property files (does not override webwork.properties!) 
# added the MockTag to the path of Tags that the TagDirective will search through 
webwork.velocity.tag.path = com.opensymphony.webwork.views.velocity.ui, org.displaytag.tags 
webwork.ui.templateDir = template 
### Load custom default resource bundles 
### XSLT Cache 
webwork.xslt.nocache = true 
5.创建HelloWorldAction类在helloworld包下,填写代码如下: 
package helloWorld; 
import com.opensymphony.xwork.Action; 
public class HelloWorldAction implements Action { 
private String userName; 
public String getUserName() { 
return userName; 

public void setUserName(String userName) { 
this.userName = userName; 

public String execute() throws Exception { 
// 处理乱码 
userName = new String(userName.getBytes("iso-8859-1"),"GBK"); 
System.out.println(userName); 
return "yes"; 


6.然后在创建下列两个jsp页面. 
第一个页面:index.jsp 
<%@ page language="java" import="java.util.*" pageEncoding="GBK"%> 
<% 
String path = request.getContextPath(); 
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; 
%> 
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> 
<html> 
<head> 
    <base href="<%=basePath%>"> 
     
    <title>My JSP 'index.jsp' starting page</title> 
<meta http-equiv="pragma" c> 
<meta http-equiv="cache-control" c> 
<meta http-equiv="expires" c>     
<meta http-equiv="keywords" c> 
<meta http-equiv="description" c> 
<!-- 
<link rel="stylesheet" type="text/css" href="styles.css"> 
--> 
</head> 
   
<body> 
   <form action="hello.action" method="post"> 
    <input type="text" name="userName"/> 
    <br> 
    <input type="submit"/> 
   </form> 
</body> 
</html>

第二个页面:yes.jsp 
<%@ page language="java" import="java.util.*" pageEncoding="GBK"%> 
<%@ taglib prefix = "ww" uri = "/webwork" %> 
<% 
String path = request.getContextPath(); 
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; 
%> 
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> 
<html> 
<head> 
    <base href="<%=basePath%>"> 
     
    <title>My JSP 'yes.jsp' starting page</title> 
     
<meta http-equiv="pragma" c> 
<meta http-equiv="cache-control" c> 
<meta http-equiv="expires" c>     
<meta http-equiv="keywords" c> 
<meta http-equiv="description" c> 
<!-- 
<link rel="stylesheet" type="text/css" href="styles.css"> 
--> 
</head> 
<body> 
    yes. <br> 
    <ww:property value="%{userName}"/> 
</body> 
</html>

到这里就OK了,运行你的项目吧.. 
在index.jsp页面中输入文字,点提交在yes.jsp页面给与显示...

如果你就按照上面这样做,你会发现会出错误.错误原因有可能是因为你的tomcat里面解析xml的jar包版本过低. 
解决办法就是下载xalan.jar文件. 
然后把里面的jar文件都拷贝到tomcat安装目录下面的common目录下的endorsed目录下...就OK了.

webwork框架的更多相关文章

  1. Webwork 学习之路【08】结合实战简析Controller 配置

    虽然现在 MVC 框架层出不穷,但做为 Struts 前身的 webwork. 其经典程度不亚于贝利之于足球,双 11 之于淘宝特卖. 本篇将结合 webwork controller 配置文件 xw ...

  2. Struts,spring,hibernate三大框架的面试

    Struts,spring,hibernate三大框架的面试 1.Hibernate工作原理及为什么要用? 原理: 1.读取并解析配置文件 2.读取并解析映射信息,创建SessionFactory 3 ...

  3. Java工程师三大框架面试题汇总

    1. Hibernate3 提供了属性的延迟加载功能? 当Hibernate在查询数据的时候,数据并没有存在与内存中,当程序真正对数据的操作时,对象才存在与内存中,就实现了延迟加载,他节省了服务器的内 ...

  4. SSH三大框架笔面试总结

    Java工程师(程序员)面题 Struts,Spring,Hibernate三大框架 1.Hibernate工作原理及为什么要用? 原理: 1.读取并解析配置文件 2.读取并解析映射信息,创建Sess ...

  5. Webwork 学习之路【06】Action 调用

    一路走来,终于要开始 webwork 核心业务类的总结,webwork 通过对客户端传递的 web 参数重新包装,进行执行业务 Action 类,并反馈执行结果,本篇源码分析对应下图 WebWork ...

  6. Webwork 学习之路【05】请求跳转前 xwork.xml 的读取

    个人理解 WebWork 与 Struts2 都是将xml配置文件作为 Controler 跳转的基本依据,WebWork 跳转 Action 前 xml 文件的读取依赖 xwork-1.0.jar, ...

  7. Webwork 学习之路【04】Configuration 详解

    Webwork做为经典的Web MVC 框架,个人觉得源码中配置文件这部分代码的实现十分考究. 支持自定义自己的配置文件.自定义配置文件读取类.自定义国际化支持. 可以作为参考,单独引入到其他项目中, ...

  8. Webwork 学习之路【03】核心类 ServletDispatcher 的初始化

    1. Webwork 与 Xwork 搭建环境需要的的jar 为:webwork-core-1.0.jar,xwork-1.0.jar,搭建webwork 需要xwork 的jar呢?原因是这样的,W ...

  9. Webwork 学习之路【01】Webwork与 Struct 的前世今生

    Struts 1是全世界第一个发布的MVC框架,它由Craig McClanahan在2001年发布,该框架一经推出,就得到了世界上Java Web开发者的拥护,经过长达6年时间的锤炼,Struts ...

随机推荐

  1. long long

    1. ll a; scanf("%d",&a); 数据读入后,产生错误 2. const ll inf=1e18; 3. int * ll = ll ll * int = ...

  2. pytest 7 assert断言

    前言:断言是自动化最终的目的,一个用例没有断言,就失去了自动化测试的意义了. 断言用到的是 assert关键字.之前的介绍,有的测试方法中其实用到了assert断言.简单的来说,就是预期的结果去和实际 ...

  3. TestNg-数据驱动-dataProvider

    参考https://blog.csdn.net/hjianhui24/article/details/50554828 之前的用例自己一笔一划写出来的,知道了数据驱动的概念之后,修改了一下用例. @D ...

  4. POJ 2253 Frogger (Floyd)

    Frogger Time Limit: 1000MS   Memory Limit: 65536K Total Submissions:57696   Accepted: 18104 Descript ...

  5. 过滤富文本编辑器中的html元素和其他元素

    https://blog.csdn.net/fjssharpsword/article/details/53467079 1.应用场景:从一份html文件中或从String(是html内容)中提取纯文 ...

  6. STM32F4 ------ RTC

    如果只执行 HAL_RTC_GetTime(),读取完后时间不再跑 HAL_RTC_GetTime() 和 HAL_RTC_GetDate()

  7. SqlServer查询Excel中的数据

    步骤如下: --1.开启远程查询支持 reconfigure reconfigure --2.链接Excel Microsoft ACE 12.0 OLE DB Provider 读Excel数据(注 ...

  8. linux下安装SlickEdit

    title: linux下安装SlickEdit tags: 软件 date: 2018-10-08 21:32:12 --- linux下安装SlickEdit 下载安装包和补丁文件 补丁文件 官方 ...

  9. JSON的简单使用_解析前台传来的JSON数据

    package cn.rocker.json; import org.junit.Test; import net.sf.json.JSONArray; import net.sf.json.JSON ...

  10. flask 钩子函数

    说明: before_request函数,就是一个装饰器,他可以把需要设置为钩子函数的代码放到视图函数执行之前执行 示例: from flask import Flask,url_for,redire ...