用Jbulder9开发基于webwork框架的web应用入门
引言:
看了不少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也是正在学习中,文中不妥之处,敬请不吝赐教。
如果您有好的意见或者建议,欢迎和我联系。cahjxszhl@msn.com。
再次感谢您的阅读。