cxf实现webservice

本文介绍如何使用Apache CXF发布WebService,包括所需依赖、配置文件设置、接口定义及实现类编写,并提供客户端调用示例。


1.所需的依赖的包:

                            commons-logging-1.1.jar
                            geronimo-activation_1.1_spec-1.0-M1.jar (or Sun's Activation jar)
                            geronimo-annotation_1.0_spec-1.1.jar (JSR 250)
                            geronimo-javamail_1.4_spec-1.0-M1.jar (or Sun's JavaMail jar)
                            geronimo-servlet_2.5_spec-1.1-M1.jar (or Sun's Servlet jar)
                            geronimo-ws-metadata_2.0_spec-1.1.1.jar (JSR 181)
                            jaxb-api-2.1.jar
                            jaxb-impl-2.1.6.jar
                            jaxws-api-2.1.jar
                            jetty-6.1.5.jar
                            jetty-util-6.1.5.jar
                            neethi-2.0.jar
                            saaj-api-1.3.jar
                            saaj-impl-1.3.jar
                            stax-api-1.0.1.jar
                            wsdl4j-1.6.1.jar
                            wstx-asl-3.2.1.jar
                            XmlSchema-1.2.jar
                            xml-resolver-1.2.jar     

 

                  spring jar 包, 用来支持xml配置:

                            aopalliance-1.0.jar
                            spring-core-2.0.4.jar
                            spring-beans-2.0.4.jar
                            spring-context-2.0.4.jar
                            spring-web-2.0.4.jar

                  

                   CXF jar包:

                            cxf-2.1.jar

   

         以上jar 包 可从apache官方网站下载 apache-cxf-2.1.2.zip, 然后从apache-cxf-2.1.2/lib 目录中获得


2.   web.xml中配置:

<!--hyt 20170720 -->
<servlet>
<servlet-name>CXFServlet</servlet-name>
<servlet-class>org.apache.cxf.transport.servlet.CXFServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>CXFServlet</servlet-name>
<url-pattern>/webservice/*</url-pattern>
</servlet-mapping>

3.使用的applicationContext-shiro-nocas.xml中暴露setvlet

<bean id="chainDefinitionSectionMetaSource" class="ins.policy.**.ChainDefinitionSectionMetaSource">  
<property name="filterChainDefinitions">
<value>
<!-- 静态资源区 -->
/devjs/** = anon
/js/** = anon
/dist/** = anon
                /css/** = anon
                /img/** = anon
                /plugins/** = anon
                /favicon.ico = anon
                /verification/** = anon
                /webservice/** = anon
                /**/app/** = anon
                /logout=logout 
/** =user
</value>
</property>
    </bean> 

在applicationContext-cxf.xml下配置

<jaxws:server id="pacgServiceSoap"
serviceClass="ins.com.application.*.*.service.facade.PacgService"
address="/pacgService">
<jaxws:serviceBean>
 <!-- 要暴露的 bean 的引用 -->
<!-- <ref bean="pacgService" /> -->
<bean class="ins.com.application.
*.*.service.impl.PacgServiceImpl"></bean>
</jaxws:serviceBean>
<jaxws:inInterceptors>
<ref bean="inMessageInterceptor" />
</jaxws:inInterceptors>
<jaxws:outInterceptors>
<ref bean="outLoggingInterceptor" />
</jaxws:outInterceptors>
</jaxws:server>

4.新建接口:如下

package ins.com.application.*.*.service.facade;


import javax.jws.WebMethod;
import javax.jws.WebParam;
import javax.jws.WebService;



@WebService(targetNamespace="http://localhost:8080/webservice/pacgService")  
public interface PacgService {

@WebMethod()
public String newService(@WebParam(name="xml") String xml);


}


实现类如下:


@SOAPBinding(style = SOAPBinding.Style.RPC)

public class PacgServiceImpl implements PacgService {

public String newService( String xml) {

System.out.println("1");

}

}


5.发布成功,查看

http://localhost:8080/webservice 



6.客户端调用

  Service service = new Service();
Call call = (Call) service.createCall();
call.setTargetEndpointAddress(wsdlmed);

//new javax.xml.namespace.QName

//第一个参数:发布的wsdl里的targetNamespace里的url

//第二个参数:方法名
call.setOperationName(new javax.xml.namespace.QName("http://localhost:8080/webservice/pacgService",
"newService"));

call.setSOAPActionURI(soapuri);
call.setEncodingStyle(null);
/
/addParameter :@WebParam(name="xml")  参数名

call.addParameter("xml",org.apache.axis.encoding.XMLType.XSD_DATE,javax.xml.rpc.ParameterMode.IN) ; 
call.setReturnType(org.apache.axis.encoding.XMLType.XSD_STRING);
call.setTimeout(300000);

String xml="123";

String result = (String) call.invoke(new Object[] { xml });

根据原作 https://pan.quark.cn/s/0ed355622f0f 的源码改编 野火IM解决方案 野火IM是专业级即时通讯和实时音视频整体解决方案,由北京野火无限网络科技有限公司维护和支持。 主要特性有:私有部署安全可靠,性能强大,功能齐全,全平台支持,开源率高,部署运维简单,二次开发友好,方便与第三方系统对接或者嵌入现有系统中。 详细情况请参考在线文档。 主要包括一下项目: 野火IM Vue Electron Demo,演示如何将野火IM的能力集成到Vue Electron项目。 前置说明 本项目所使用的是需要付费的,价格请参考费用详情 支持试用,具体请看试用说明 本项目默认只能连接到官方服务,购买或申请试用之后,替换,即可连到自行部署的服务 分支说明 :基于开发,是未来的开发重心 :基于开发,进入维护模式,不再开发新功能,鉴于已经终止支持且不再维护,建议客户升级到版本 环境依赖 mac系统 最新版本的Xcode nodejs v18.19.0 npm v10.2.3 python 2.7.x git npm install -g node-gyp@8.3.0 windows系统 nodejs v18.19.0 python 2.7.x git npm 6.14.15 npm install --global --vs2019 --production windows-build-tools 本步安装windows开发环境的安装内容较多,如果网络情况不好可能需要等较长时间,选择早上网络较好时安装是个好的选择 或参考手动安装 windows-build-tools进行安装 npm install -g node-gyp@8.3.0 linux系统 nodej...
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值