用Jbulder9开发基于webwork框架的web应用入门

类别:Java 点击:0 评论:0 推荐:

用Jbulder9开发基于webwork框架的web应用入门

 

[email protected]

 

引言:

看了不少webwork的文章,拿着上面的例子总是调试不通。只好看webwork的wikidoc,发现还是看wikidoc比较好。不过,wikidoc指导的方式类似ultraedit + tomcat的教程方式,如果你习惯用jbuilder作开发工具,那么按照这个wiki教程,也许会有一点点的麻烦。

下面,我将自己的用jbuilder9z作为开发工具,来调试开发基于webwork的web应用程序的方法纪录下来,图文并茂,以飨来者。

 

第一篇:webwork的安装篇

1、   webwork的下载

a)          下载地址:

b)         注意:本文所讲述的,是webwork2.1版本,所以,如果您希望纯粹按照本文轻轻松松的就能成功完成一个webwork的例子,请务必也下载2.1版本。这个版本调通了,换了其他版本,是很容易的。

2、   解压缩

将下载来的webwork2.1.zip解压缩到c:\webwork2.1目录,解开之后,出现很多文件和目录,不要看花眼。只要关注一下几个文件:

                         i.              webwork-2.1.jar,这个文件在c:\webwork2.1目录下,是用webwork做项目必需的jar包。

                        ii.              c:\webwork2.1/lib/core/*.jar这个目录下所有的jar都是webwork-2.1.jar所引用到的jar包,所以,这些文件也是必需的。以上所有的jar,运行的时候都要在classpath的lib目录里面。

第二篇:建立jbuilder工程,实现一个简单的功能

1、   建立一个空的jbuilder工程,假设就叫做webworktest吧。建立在c:\webworktest目录。

2、   打开jbuilder的Project Properties的required library面板,加入上述的jar包:webwork2.1.jar和/lib/core/*.jar。如图:

3、   在根路径下新建一个jsp文件:/login.jsp。在jbuilder中,会自动建立一个默认的webapp:<Defautl WebApp>。如图

4、   打开<Default WebApp>下面的Deployment descriptors,可以看到一个web.xml文件。打开该文件,并且将web.xml文件的内容更改为如下代码:

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd">

<web-app>

  <servlet>

    <servlet-name>webwork</servlet-name>

    <servlet-class>com.opensymphony.webwork.dispatcher.ServletDispatcher</servlet-class>

    <load-on-startup>1</load-on-startup>

  </servlet>

  <servlet-mapping>

    <servlet-name>webwork</servlet-name>

    <url-pattern>*.action</url-pattern>

  </servlet-mapping>

  <taglib>

    <taglib-uri>webwork</taglib-uri>

    <taglib-location>/WEB-INF/webwork.tld</taglib-location>

  </taglib>

</web-app>



在这个web.xml中作了3件事情:

a)          告诉web服务器在启动的时候,运行ServletDispatcher这个类

b)         告诉web服务器,以后有.acton结尾的url的请求的时候,交给ServletDispatcher处理

c)          告诉web服务器,webwork的标签库的位置在/WEB-INF/webwork.tld

 

5、   修改login.jsp文件的内容,使之将form里面的数据post到一个叫做LoginAction.action的url中。Login.jsp文件内容如下:

<%@ page contentType="text/html; charset=GBK" %>

<html>

<head><title>post</title></head>

<body bgcolor="#ffffff">

<form method="post" action="loginAction.action">

<input type="text" name="username" value="hulei">

<input type="submit" name="Submit" value="Submit">

<input type="reset" value="Reset">

</form>

</body>

</html>


6、   新建一个类LoginAction.java,用来处理login.jsp中提交过来的数据。该类内容如下:

import com.opensymphony.xwork.ActionSupport;

public class LoginAction extends ActionSupport {

  private String userName;

  public LoginAction() {

  }

  public String getUserName() {

    return userName;

  }

  public String execute() throws Exception{

    this.userName="hulei";

    return this.SUCCESS;

  }

}


在这里我们可以看到,这个LoginAction类是继承了xwork提供的ActionSupport类(关于xwork请查阅关于xwork的相关资料)。在这个类中,有一个私有属性userName,并且有一个该属性的get方法。同时还有一个覆盖父类的execute()方法。该方法的功能很简单,将userName属性设置一个值。并且返回一个this.SUCCESS。
注意2点:

a)          这里return的this.SUCCESS是父类提供的一个常量,其值为”success”。

b)         这里设置this.userName一个值以后,除了返回一个常量外,就什么事情也没有干了。那这个execute()方法中给这个私有变量赋值有什么意义呢?当然有用,这里先卖个关子,后面将会提到。

7、   细心的人应该注意到,我们login.jsp的form标签里面的action设置的值是“loginAction.action”,而这里的扩展ActionSupport父类的LoginAction.java的类名开头是大写的的。这两个之间是如何联系起来的呢?
这就要用到我们下面要讲的xwork.xml文件了。按照下面的步骤进行。

a)          打开c:\webworktext\src目录,在该目录下建立xwork.xml文件。

b)         右键点击jbuilder工程的根节点webworktest.jpx,选择Properties…,如图:

在弹出的窗口中选择Build面板的Resource子面板。找到倒数第五个:xml,用鼠标选择后,点击右边的copy选项,然后点下面的ok。如图:


c)          点击ok后,我们可以发现,在jbulder工程菜单的<Project Source>菜单下,出现了刚才我们新建立的xwork.xml文件。[注意啦,上面讲的这个地方,正是用jbuilder开发webwork项目的精要之处,只有设置好了xml文件可以copy,我们才能在一个ide环境里面完成xml文件的修改,编辑,不然,人们就会说用jbuilder开发webwork项目很麻烦]。

d)         双击xwork.xml文件进行编辑

8、   这里接着上面来,讲述xwork.xml的内容。其实xwork.xml和struts里面的struts-config.xml文件类似,起到一个联系jsp中的post的action和实际执行这个action的类的桥梁的作用。请将xwork.xml文件的内容编辑为如下内容:

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE xwork PUBLIC "-//OpenSymphony Group//XWork 1.0//EN"

"http://www.opensymphony.com/xwork/xwork-1.0.dtd">

<xwork>

         <!-- Include webwork defaults (from WebWork-2.1 JAR). -->

         <include file="webwork-default.xml" />

         <!-- Configuration for the default package. -->

         <package name="default" extends="webwork-default">

                   <default-interceptor-ref name="defaultStack" />

                   <action name="loginAction" class="LoginAction">

                            <result name="success" type="dispatcher">loginok.jsp</result>

                   </action>

         </package>

</xwork>


9、   上面的xwork.xml文件中,<include file="webwork-default.xml" />是xwork继承了一个webwork-default.xml的默认配置。我们加入的内容就是<action>标签内的一段,在这个部分里面,我们定义了一个action,叫做loginAction,这个loginAction对应的类是LoginAction(即:LoginAction.java)。在这个action标签内,还有一个result标签,我们定义了一个叫做success的result,类型type是dispatcher,这个标签的值是loginok.jsp。这是什么意思呢?意思就是说,如果LoginAction这个类执行的结果是success,那么下一个页面就会显示loginok.jsp。

好啦,下面我们来做个loginok.jsp吧。打开jbulder,在站点根目录下新建一个loginok.jsp文件。文件内容如下:

<%@ taglib uri="webwork" prefix="ww" %>

<html>

<head>

<title>

loginok

</title>

</head>

<body bgcolor="#ffffff">

your name is:

<ww:property value="userName" />

</body>

</html>



来看看这个jsp页面。第一行,引用webwork的标签库。在页面的中间的一行:
<ww:property value="userName" />
是干什么用的呢?其实,这个标签就是用来显示来自上一个action类中的变量:userName的。记得我们在前面第6点中,卖了一个关子。那里所说的get方法,正是提供这里使用的。如果你将这个get方法去掉,那么<ww:property value="userName" />将无法获取userName的值。
所以,这里也可以这么理解,<ww:property value="userName" />,中的value对应action类中的同名的属性变量。如果要在标签中得到这个值,必须对其设置get方法。

10、按照上述的步骤,你就可以在jbuilder中进行webwork项目的开发了。不过在jbulder启动tomcat父武器的时候,控制台会输出红色的错误警告,可以不去理会它。但是,如果要用到更多的webwork的特性,那么,还需要其他一些的配置文件。例如:velocity.properties,webwork.properties,validators.xml等。这些文件也都放在jbuilder工程的src目录即可。然后再根据具体情况进行配置。

 

 

 

 

 

 

 

 

本次教程到此结束,希望能够对webwork的新手入门有所帮助。

本文作者对webwork也是正在学习中,文中不妥之处,敬请不吝赐教。

如果您有好的意见或者建议,欢迎和我联系。[email protected]

再次感谢您的阅读。

本文地址:http://com.8s8s.com/it/it12511.htm