精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2010-04-02
Bboss aop 框 架中很好地集成了 apache cxf webservice 服务框架,原理如下图:
下面具体来介绍如果通过 bboss aop 框架来管理和发布基于 apache cxf webservice 服务框架的 webservice 服务。 1.1 Webservice 协议配置对应的配置文件为: /bbossaop/resources/org/frameworkset/spi/manager-rpc-webservices.xml 文件在 /bbossaop/resources/org/frameworkset/spi/manager-rpc-service.xml 中导入。 <!-- 导入 webservice 服务配置 --> < managerimport file = "org/frameworkset/spi/manager-rpc-webservices.xml" /> Webservice 协 议配置包含 ws rpc 协议配置、发布的 webservice 服务配置、 cxf webservice 客服端连接参数配置四部分。分别介绍如下。 1.2 发布 webservice 服务 servlet 配置rpc 服务器端还 需要在 web.xml 文件中配置发布 webservice 服务的 servlet : < servlet > < display-name > cxf </ display-name > < servlet-name > cxf </ servlet-name > < servlet-class > org.apache.cxf.transport.servlet.RPCCXFServlet </ servlet-class > < load-on-startup > 1 </ load-on-startup > </ servlet > < servlet-mapping > < servlet-name > cxf </ servlet-name > < url-pattern > /cxfservices/* </ url-pattern > </ servlet-mapping > 1.3 Cxf webservice 服务控制开 关< property name = "rpc.webservice.enable" value = "true" /> 标记是否启用 webservice 服务,为 false 时, 启动 cxf 的 serverlet 将不会加载和发布配置的 webservice 服务(这些 webservice 服务配置在 cxf.webservices.config 属性中 )。如果采用 webservice 协议作为远程服务调用的协议时, rpc.webservice.enable 开关必须配置为 true 。 1.4 webservice 服务配置< property name = "cxf.webservices.config" > < list > <!-- webservice RPC 服务 , 用来实现业务组件之间的远程服务调用 属性说明: name 服务的唯一标识名称 singleable 服务组件 的单列模式 servicePort 发布的服务端口 class 服务的实现类 mtom 服务是否 支持附件传输 true :支持, false :不支持 --> < property name = "rpc.webservice.RPCCall" singlable = "true" servicePort = "RPCCallServicePort" class = "org.frameworkset.spi.remote.webservice.RPCCall" /> </ list > </ property > 1.5 Cxf 客服端连接参数配置< property name = "cxf.client.config" enable = "true" > < map > < property label = "connectionTimeout " name = "connectionTimeout" value = "30000" class = "long" > < description > <![CDATA[ Specifies the amount of time, in milliseconds, that the client will attempt to establish a connection before it times out. The default is 30000 (30 seconds). 0 specifies that the client will continue to attempt to open a connection indefinitely. ]]></ description > </ property > < property label = "receiveTimeout" name = "receiveTimeout" value = "60000" class = "long" > < description > <![CDATA[ Specifies the amount of time, in milliseconds, that the client will wait for a response before it times out. The default is 60000. 0 specifies that the client will wait indefinitely. ]]></ description > </ property > < property label = "autoRedirect" name = "autoRedirect" value = "false" class = "boolean" > < description > <![CDATA[ Specifies if the client will automatically follow a server issued redirection. The default is false. ]]></ description > </ property > < property label = "maxRetransmits" name = "maxRetransmits" value = "-1" class = "int" > < description > <![CDATA[ Specifies the maximum number of times a client will retransmit a request to satisfy a redirect. The default is -1 which specifies that unlimited retransmissions are allowed. ]]></ description > </ property > < property label = "allowChunking" name = "allowChunking" value = "true" class = "boolean" > < description > <![CDATA[ Specifies whether the client will send requests using chunking. The default is true which specifies that the client will use chunking when sending requests. Chunking cannot be used used if either of the following are true: http-conf:basicAuthSupplier is configured to provide credentials preemptively. AutoRedirect is set to true. In both cases the value of AllowChunking is ignored and chunking is disallowed. See note about chunking below. ]]></ description > </ property > 1.6 客服端网络代理服务参数配置<!-- <property label="proxyServer" name="proxyServer"--> <!-- value="172.16.17.1" class="String">--> <!-- <description> <![CDATA[Specifies the URL of the proxy server through which requests are routed. ]]></description>--> <!-- </property>--> <!-- <property label="proxyServerPort" name="proxyServerPort"--> <!-- value="808" class="int ">--> <!-- <description> <![CDATA[Specifies the port number of the proxy server through which requests are routed. ]]></description>--> <!-- </property>--> <!-- <property label="proxyServerType" name="proxyServerType"--> <!-- value="SOCKS" >--> <!-- 指定属性注入时的属性编辑和转换器
--> <!-- <editor class="org.frameworkset.spi.remote.webservice.ProxyServerTypeEditor"/>--> <!-- <description> <![CDATA[Specifies the type of proxy server used to route requests. Valid values are: --> <!-- HTTP(default) --> <!-- SOCKS --> <!-- ]]></description>--> <!-- </property>--> </ map > </ property > 1.7 Ssl 参数配置 - 没有经过测试< property name = "ws.ssl.config" enable = "false" > < map > < property name = "keyManagers" keyPassword = "password" > < list > < property name = "keyStore1" type = "JKS" password = "password" file = "src/test/java/org/apache/cxf/systest/http/resources/Morpit.jks" /> </ list > </ property >
< property name = "trustManagers" keyPassword = "password" > < list > < property name = "keyStore1" type = "JKS" password = "password" file = "src/test/java/org/apache/cxf/systest/http/resources/Truststore.jks" /> </ list > </ property >
< property name = "cipherSuitesFilter" > < list > < property value = ".*_EXPORT1024_.*" /> < property value = ".*_WITH_DES_.*" /> < property value = ".*_WITH_NULL_.*" /> < property value = ".*_DH_anon_.*" /> </ list > </ property >
< property name = "userName" value = "Betty" />
< property name = "password" value = "password" /> <!-- <http:tlsClientParameters> margin: 0cm 0cm 0pt; text- 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2010-04-02
javaeye的编辑器是不是不能发布长篇文章,发超长文章老是被截断,不知道是我不会用还是怎么回事,如果不能得话可否改进一下。
|
|
返回顶楼 | |
浏览 2447 次