组装并部署JAX-RPC Web服务
JAX-RPC Web服务应用程序能够被组装并且作为一个WAR文件部署到Sun ONE应用服务器上。WAR文件包括了压缩格式下web应用程序所需的文件。
以下步骤讲述了组装和部署Web服务应用程序到Sun ONE应用服务器的过程。
1. 创建WAR文件。为了创建一个包含服务代码的WAR文件,请创建一个build.xml文件,并为目标名称指定create-war命令。以下代码是一个创建WAR文件的示例build.xml文件。
<target name="create-war" depends="compile-server"
description="Packages the WAR file">
<echo message="Creating the WAR...."/>
<delete file="../${portable-war}" />
<delete dir="${assemble}/WEB-INF" />
<copy todir="${assemble}/WEB-INF/classes/">
<fileset dir="${build}/shared/" includes="**/*.class" />
</copy>
<copy file="web.xml" todir="${assemble}/WEB-INF" />
<copy file="jaxrpc-ri.xml" todir="${assemble}/WEB-INF" />
<jar jarfile="${assemble}/${portable-war}" >
<fileset dir="${assemble}" includes="WEB-INF/**" />
</jar>
<move file="${assemble}/${portable-war}" todir="../" /> </target>
当被执行时,这个XML文件把文件打包成一个名为hello-portable.war的WAR文件。这个WAR文件还不能被部署,因为没有包含tie类。WAR(web 应用存档)文件包括了压缩格式下完整的web应用程序。
文件根目录下的一个特定目录WEB-INF中包含了与不在应用程序公共文件树上的应用程序相关的一切。没有任何一个WEB-INF中的文件能够直接服务于客户端。WEB-INF的内容包括:
/WEB-INF/classes/*,存放servlet和其他类的目录
/WEB-INF/lib/*.jar, 存放包含bean和其他工具类的JAR文件的目录
/WEB-INF/web.xml 和 /WEB-INF/sun-web.xml, 基于XML的配置描述文件,其中指定了web应用程序的配置,包括映射、初始化参数、和安全约束。
Web应用程序目录结构符合J2EE规范中描述的结构。
在本例中,hello-portable.war包含以下文件:
WEB-INF/classes/hello/HelloIF.class
WEB-INF/classes/hello/HelloImpl.class
WEB-INF/jaxrpc-ri.xml
WEB-INF/web.xml
2.定义指定服务名称及其服务终端接口和类的配置文件。配置文件的名称必须是jaxrpc-ri.xml。下面是本例子的配置文件:
<?xml version="1.0" encoding="UTF-8"?>
<webServices
xmlns="http://java.sun.com/xml/ns/jax-rpc/ri/dd"
version="1.0"
targetNamespaceBase="http://hello.org/wsdl"
typeNamespaceBase="http://hello.org/types"
urlPatternBase="/ws">
<endpoint
name="HelloWorld"
displayName="HelloWorld Service"
description="A simple web service"
interface="samples.webservices.jaxrpc.simple.HelloIF"
implementation="samples.webservices.jaxrpc.simple. HelloImpl"/>
<endpointMapping
endpointName="HelloWorld"
urlPattern="/simple"/>
</webServices>
配置文件包含了以下web服务属性:
Web服务元素,包括名称、类型命名空间、和目标命名空间属性。
名称属性用来生成在公共注册中心发布的WSDL文件。
类型命名空间属性为wscompile工具生成的类型在WSDL文件内定义了命名空间。
目标命名空间属性用来限定WSDL文件中的任何其他东西。
关于用于创建运行时配置文件的XML schema的信息,请参见"XML Schema定义".
3. 创建web.xml配置描述文件,其中包含了部署服务所需的信息,例如服务到URL的映射、指定WAR文件中配置文件的位置等等。
想要了解关于配置描述文件的更多信息,请参见Sun ONE应用服务器开发人员指南。
关于DTD文件以及XML的基本信息,请参考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>
<display-name>Hello World Application</display-name>
<description>A web application containing a simple JAX-RPC endpoint</description>
<session-config>
<session-timeout>60</session-timeout>
</session-config>
</web-app>
关于用于创建运行时配置文件的XML schema的信息,请参见"XML Schema定义".
Web服务应用程序拥有一个目录结构,通过到应用程序文件根目录的映射 (例如, /hello),整个结构都能够被访问。
4. 使用wsdeploy工具创建可部署的WAR模块。Wsdeploy工具执行wscompile工具来生成stub、tie类、以及其他必要的类。
wsdeploy -keep tmpdir tempdir -o hello.war hello-portable.war
当wsdeploy命令被执行时,完成了以下任务:
读取hello-portable.war作为输入。
从hello-portable.war文件里的jaxrpc-ri.xml文件中获得信息。
为服务生成tie类。
生成名为HelloWorld.wsdl的WSDL文件。
组装tie类,HelloWorld.wsdl文件、和hello-portable.war文件的内容,形成一个可部署的WAR文件。
关于使用wsdeploy命令行工具的信息,请参见"wsdeploy工具",
5. 使用asadmin部署命令部署WAR模块。
例如,
asadmin> deploy --user admin --password admin --host localhost --port 4848 --type web --instance server1 /sun/appserver7/samples/webservices/jaxrpc/simple/Hello.war
关于使用asadmin命令行工具的更多信息,请参见Sun ONE应用服务器开发人员指南。