当前位置:文档之家› axis2发布webservice总结wangxz

axis2发布webservice总结wangxz

axis2发布webservice总结wangxz
axis2发布webservice总结wangxz

Axis2发布webservice总结详细例子demo

本人测试用的了tomcat 下面能够正常使用在was和WebLogic下面应该是版本不兼容的问题,一直启动失败

在was直接部署axis2.war包错误信息

用到的jar包

axis2-1.5.4-war.zip axis2-1.5.4-bin.zip

编写webservice首先下载jar包上面已经有了

解压缩bin包目录如下写接口的时候可以一个jar包不需要

客户端调用的时候需要用的lib目录下面的所有jar包

解压缩war包

将axis2.war导入到Eclipse里面找到axis2.xml并修改下面配置

修改

wangxz

123456

这两个配置是axis2后台管理员的账号和密码用于部署和更新webservice true

true

这里个配置是热部署和热更新的意思设置为true

~ https://www.doczj.com/doc/0a9958531.html,/licenses/LICENSE-2.0

~

~ Unless required by applicable law or agreed to in writing,

~ software distributed under the License is distributed on an

~ "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY

~ KIND, either express or implied. See the License for the

~ specific language governing permissions and limitations

~ under the License.

-->

true

true

false

false

false

milliseconds-->

30000

name="sendStacktraceDetailsWithFaults">false

name="DrillDownToRootCauseForFaultReason">false

wangxz

123456

false

false

class="org.apache.axis2.jaxws.framework.JAXWSDeployer"/>

class="org.apache.axis2.deployment.TransportDeployer"/>

false

listId="JAXWS-ThreadContextMigrator-List"

class="org.apache.axis2.jaxws.addressing.migrator.EndpointContextMapM igrator"/>

class="org.apache.axis2.receivers.RawXMLINOnlyMessageReceiver"/>

class="org.apache.axis2.receivers.RawXMLINOutMessageReceiver"/>

class="org.apache.axis2.receivers.RawXMLINOnlyMessageReceiver"/>

class="org.apache.axis2.receivers.RawXMLINOutMessageReceiver"/>

class="org.apache.axis2.receivers.RawXMLINOnlyMessageReceiver"/>

class="org.apache.axis2.receivers.RawXMLINOutMessageReceiver"/>

contentType="application/x-www-form-urlencoded"

class="org.apache.axis2.transport.http.XFormURLEncodedFormatter"/>

class="org.apache.axis2.transport.http.MultipartFormDataFormatter"/>

class="org.apache.axis2.transport.http.ApplicationXMLFormatter"/>

class="org.apache.axis2.transport.http.SOAPMessageFormatter"/>

class="org.apache.axis2.transport.http.SOAPMessageFormatter"/>

support for different message -->

class="org.apache.axis2.builder.ApplicationXMLBuilder"/>

class="org.apache.axis2.builder.XFormURLEncodedBuilder"/>

class="org.apache.axis2.builder.MultipartFormDataBuilder"/>

class="org.apache.axis2.transport.http.AxisServletListener"/>

>

class="org.apache.axis2.transport.local.LocalTransportSender"/>

class="https://www.doczj.com/doc/0a9958531.html,monsHTTPTransportSender"> HTTP/1.1

chunked

class="https://www.doczj.com/doc/0a9958531.html,monsHTTPTransportSender"> HTTP/1.1

chunked

class="org.apache.axis2.clustering.tribes.TribesClusteringAgent"

enable="false">

true

nodes will notify the others in the group. When a member leaves the cluster or

is deemed to have left the cluster, it will be detected by the Group Membership

Service (GMS) using a TCP ping mechanism.

-->

multicast

wso2.carbon.domain

true

10

228.0.0.4

45564

500

3000

127.0.0.1

127.0.0.1

4000

true

true

127.0.0.1

4000

127.0.0.1

4001

description="Axis2 group"

agent="org.apache.axis2.clustering.management.DefaultGroupManagementA gent"/>

class="org.apache.axis2.clustering.management.DefaultNodeManager"

enable="true"/>

class="org.apache.axis2.clustering.state.DefaultStateManager"

enable="true">

class="org.apache.axis2.context.ConfigurationContext">

class="org.apache.axis2.context.ServiceGroupContext">

class="org.apache.axis2.context.ServiceContext">

class="org.apache.axis2.dispatchers.RequestURIBasedDispatcher">

class="org.apache.axis2.dispatchers.SOAPActionBasedDispatcher">

class="org.apache.axis2.dispatchers.AddressingBasedDispatcher">

class="org.apache.axis2.dispatchers.RequestURIBasedDispatcher"/>

class="org.apache.axis2.dispatchers.SOAPActionBasedDispatcher"/>

class="org.apache.axis2.dispatchers.RequestURIOperationDispatcher"/>

class="org.apache.axis2.dispatchers.SOAPMessageBodyBasedDispatcher"/>

class="org.apache.axis2.dispatchers.HTTPLocationBasedDispatcher"/>

class="org.apache.axis2.jaxws.dispatchers.GenericProviderDispatcher"/ >

class="org.apache.axis2.jaxws.dispatchers.MustUnderstandValidationDis patcher"/>

class="org.apache.axis2.jaxws.dispatchers.MustUnderstandChecker">

class="org.apache.axis2.dispatchers.AddressingBasedDispatcher">

class="org.apache.axis2.dispatchers.RequestURIBasedDispatcher"/>

class="org.apache.axis2.dispatchers.SOAPActionBasedDispatcher"/>

class="org.apache.axis2.dispatchers.RequestURIOperationDispatcher"/>

class="org.apache.axis2.dispatchers.SOAPMessageBodyBasedDispatcher"/>

class="org.apache.axis2.dispatchers.HTTPLocationBasedDispatcher"/>

class="org.apache.axis2.jaxws.dispatchers.GenericProviderDispatcher"/ >

class="org.apache.axis2.jaxws.dispatchers.MustUnderstandValidationDis patcher"/>

将axis2.war部署到tomcat中去访问它界面如下

点击services查看现有webservice 发现默认有一个webservice服务服务名是version

点击administration

输入用户名wangxz 密码123456 登陆

Pb调用Webservice

Pb调用Webservice 分类:PowerBuilder 2011-05-17 15:48 1436人阅读评论(0) 收藏举报webserviceprotocolsdocumentationsoapservicewizard 而现在WebService非常火,如果将两者结合起来呢,比如:用Net写好的WebService被Pb调用,而且还可以发布成接口形式,被其他公司所调用,合乐而不为呢? 先说一下开发环境:32位Win7旗舰版+PB11.5 其实在PB10.0出来时候,就已经支持调用WebService方式了。如下面步骤即可实现调用。 l 步骤1 在Net中创建一个WebService方法,用于被Pb调用,如图-1所示 图-1

l 步骤2 将此WebService发布,最好发布成IIS方式,如图-2所示。 图-2 这里有一点说明下,发布成IIS以后,是可以直接在浏览器里打开的,但它的后缀是asmx,而PB需要的是wsdl方式,就是说如何生成Wsdl文件?如下图-3所示,另存为即可并将这个文件存储起来。 图-3 好了,准备工作基本完成 l 步骤3 创建PB的解决方案文件,如图-4所示 图-4 这里面要必须引用一个pbwsclient11.pbd文件,不然,会调用不成功。这个文件在安装路径里就可以找到。 l 步骤4

从此步开始,我们按照创建对象创建一步一步操作即可,如下图列表所示 如图-5所示,选择Web Service Proxy Wizard图标

如图-6,这个选项勾不勾没有关系 如图-7,这个就要输入我们生成好的WSDL文件路径了(绝对路径) 如图-8所示,如果能到这里,就基本没有问题了

java调用WebService(客户端)

java调用WebService(客户端) 看下了网上大部分都是写java来编写WS服务端,小编这边就小写了下JAVA的调用端。WebService可以有Get、Post、Soap、Document四种方式调用,以下是四种方式的参照说明。 对于SOAP协议多写了个CXF的调用(对于CXF必须有以下包:) 以下是调用代码 import java.io.BufferedReader; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import java.io.OutputStream; import java.io.OutputStreamWriter; import https://www.doczj.com/doc/0a9958531.html,.URL; import https://www.doczj.com/doc/0a9958531.html,.URLConnection; import https://www.doczj.com/doc/0a9958531.html,.URLEncoder; import org.apache.cxf.endpoint.Client; import org.apache.cxf.jaxws.endpoint.dynamic.JaxWsDynamicClientFactory; /** * 功能描述:WebService调用 * */ public class ClientTest {

/** * 功能描述:HTTP-GET * */ public String get() { URL url; BufferedReader bin = null; StringBuilder result = new StringBuilder(); try { String urlTemp = "https://www.doczj.com/doc/0a9958531.html,//WebServices/WeatherWebService.asmx/getSupportCity?byProvin ceName=" + URLEncoder.encode("福建", "UTF-8");// URLEncoder用来参数编码url = new URL(urlTemp); InputStream in = url.openStream(); // 请求 bin = new BufferedReader(new InputStreamReader(in, "UTF-8")); String s = null; while ((s = bin.readLine()) != null) { result.append(s); } } catch (Exception e) { e.printStackTrace(); } finally { if (null != bin) { try { bin.close(); } catch (IOException e) { e.printStackTrace(); } } } return result.toString(); } /** * 功能描述:HTTP-POST * */ public String post() { OutputStreamWriter out = null; StringBuilder sTotalString = new StringBuilder(); try { URL urlTemp = new URL(

XMLWebService完全实例详细解析

XMLWebService完全实例详细解析 首先,我们必须了解什么是webservice.就概念上来说,可能比较复杂,不过我们可以有个宏观的了解:webservice就是个对外的接口,里面有函数可供外部客户调用(注意:里面同样有客户不可调用的函数).假若我们是服务端,我们写好了个webservice,然后把它给了客户(同时我们给了他们调用规则),客户就可以在从服务端获取信息时处于一个相对透明的状态.即是客户不了解(也不需要)其过程,他们只获取数据. webservice传递的数据只能是序列化的数据,典型的就是xml数据,这里我们也只讨论XML数据的传输. 有了一些对XML webservice的初步了解后,我们将切入正题,即是用一个具体的webservice事例的形式来讲解具体的webservice用法,用具体的事例来讲解一个概念我想怎么也要比单纯的说理能让人容易理解吧. 这里,我们将以一个简单的分布式课件搜索系统为例来讲解.使用VS2003为编译环境,C#为语言,SqlServcer2000为数据库.(这个例子来源于一位网上朋友的文章的启发,觉得很能代表webservice的特点,就按那个想法做了这么个系统来示例了) 首先,明确我们要做什么.我们需要一个对客户的接口,也就是个站点,我们把它称做ServiceGatherSite,它是何种形式都无所谓,甚至它本身并不需要数据库,它只是提供给用户一个查询的接口,真正的服务,普通用户是不接触到的.然后,这里我们还需要若干个提供服务的站点,我们可以称它们为资源站,这里为简单起见,假设有两个资源站,分别叫WebSiteA,WebSiteB,它们可以是不对外公布的,只是为了丰富查询数据而存在.最后,是我们最需要关注的东西---资源站提供给ServiceGatherSite的服务.两个资源站,就有两个服务,我们称为SiteAService和 SiteBService.两个服务间没有任何关系,内部提供的方法也完全没关联,只是需要把方法如何使用告诉ServiceGatherSite,意思是,服务只提供查询接口,返回的数据如何处理,服务本身并不管,全由使用服务的站点分配. 写了这么多,算是简要的介绍了下有关XML webservice的概念和我们这个例子的结构,下篇文章,我们将开始真正进入代码的设计阶段. 上篇文章介绍了些webservice的基本特性和我们例子的结构,这篇文章我们将开始具体的代码编写工作.

eclipse创建webservice的两种方法

在eclipse 中创建webservice项目 方法一:使用xfire支持 1.创建Dynamic Web Project 项目: 2.将编译路径改为项目/web-INF/classes; 3.将META-INF 文件夹移动到src下面,并在META-INF 中创建xfire文件夹,文件夹内放入services.xml文件; 4.添加xfire支持的jar包:

5.编写web.xml: 7.编写services.xml

可以存在多个service; 8.访问http://localhost:port/projectName/services/url-pattern?wsdl(蓝色字体均为相应的内容);方法二:使用Axis2支持 1.1Axis2发行包 Axis2以多个发行包发行。你需要哪个视你所需决定。 1.1.1标准二进制发行包 如果你正在开发服务和应用程序,你需要Axis2标准二进制发行包。这个发行包包括所有必要的*.jar文件,以及很多便于开发用的脚本。它具有以下结构。 Axis2标准二进制发行包目录的结构 bin axis2.bat axis2.sh axis2server.bat axis2server.sh java2wsdl.bat java2wsdl.sh wsdl2java.bat wsdl2java.sh setenv.sh lib activation-1.1.jar ... XmlSchema.jar repository modules modules.list addressing-1.1.mar ... services services.list version.aar ... samples ... webapp ... conf axis2.xml LICENSE.txt README.txt NOTICE.txt INSTALL.txt release-notes.html bin目录包括一些有用的脚本。它们包括axis2.bat(或者axis2.sh),这个文件可以让你在不手工添加Axis2 jar文件到类路径的情况下方便的执行Java命令;java2wsdl.bat(和.sh)和wsdl2java.bat(和.sh),它可以让你轻易的从一个WSDL文件生成Java代码,反之亦然;axis2server.bat(和sh),一个简易Web服务器,它可以让你早自己的应用程序中搭建Axis2

C#调用WebService实例和开发

C#调用WebService实例和开发 一、基本概念 Web Service也叫XML Web Service WebService是一种可以接收从Internet或者Intranet上的其它系统中传递过来的请求,轻量级的独立的通讯技术。是:通过SOAP在Web上提供的软件服务,使用WSDL文件进行说明,并通过UDDI进行注册。简单的理解就是:webservice就是放在服务器上的函数,所有人都可以调用,然后返回信息。比如google就有一个web service,你调用它就可以很容易的做一个搜索网站。就像调用函数一样,传入若干参数(比如关键字、字符编码等),然后就能返回google检索的内容(返回一个字符串)。其中, Soap:(Simple Object Access Protocol)简单对象存取协议。是XML Web Service 的通信协议。当用户通过UDDI找到你的WSDL描述文档后,他通过可以SOAP调用你建立的Web服务中的一个或多个操作。SOAP是XML文档形式的调用方法的规范,它可以支持不同的底层接口,像HTTP(S)或者SMTP。 WSDL:(Web Services Description Language)WSDL文件是一个XML文档,用于说明一组SOAP消息以及如何交换这些消息。大多数情况下由软件自动生成和使用。 UDDI(Universal Description,Discovery,and Integration)是一个主要针对Web服务供应商和使用者的新项目。在用户能够调用Web服务之前,必须确定这个服务内包含哪些商务方法,找到被调用的接口定义,还要在服务端来编制软件,UDDI是一种根据描述文档来引导系统查找相应服务的机制。UDDI利用SOAP 消息机制(标准的XML/HTTP)来发布,编辑,浏览以及查找注册信息。它采用XML格式来封装各种不同类型的数据,并且发送到注册中心或者由注册中心来返回需要的数据。 二、优点缺点 Web Service的主要目标是跨平台的可互操作性。为了实现这一目标,Web Service完全基于XML(可扩展标记语言)、XSD(XML Schema)等独立于平台、独立于软件供应商的标准,是创建可互操作的、分布式应用程序的新平台。因此使用Web Service有许多优点: 1、跨防火墙的通信 如果应用程序有成千上万的用户,而且分布在世界各地,那么客户端和服务器之间的通信将是一个棘手的问题。因为客户端和服务器之间通常会有防火墙或者代理服务器。传统的做法是,选择用浏览器作为客户端,写下一大堆ASP页面,把应用程序的中间层暴露给最终用户。这样做的结果是开发难度大,程序很难维护。要是客户端代码不再如此依赖于HTML表单,客户端的编程就简单多了。如果中间层组件换成Web Service的话,就可以从用户界面直接调用中间层组件,

NET调用WebService服务的方法详解!

本文实例讲述了https://www.doczj.com/doc/0a9958531.html,调用WebService服务的方法。分享给大家供大家参考,具体如下: 一、WebService:WebService是以独立于平台的方式,通过标准的Web协议,可以由程序访问的应用程序逻辑单元。 (1)应用程序逻辑单元:web服务包括一些应用程序逻辑单元或者代码。这些代码可以完成运算任务,可以完成数据库查询,可以完成计算机程序能够完成的任何工作。 (2)可由程序访问:当前大多是web站点都是通过浏览器由人工访问的,web服务可以由计算机程序来访问。 (3)标准的we协议:Web服务的所有协议都是基于一组标准的Web协议,如HTTP、XML、SOAP、WSDl、UDDI等 (4)平台独立性:web服务可以在任何平台上实现。因为标准协议不是由单个供应商专用的,它由大多数主要供应商支持。 SOAP(Simple Object Access Protocol,简单对象访问协议)协议:是用于交换XML编码信息的轻量级协议,SOAP协议是HTTP和XML协议的组合。 WSDL(Web Service Description Language,Web服务描述语言)是用XML文档来描述Web 服务的标准,是Web服务的接口定义语言。 二、创建https://www.doczj.com/doc/0a9958531.html, WEB服务 建立Web服务就是把一些信息或逻辑对其他计算机和客户公开,进一步说,就是从支持SOAP通信的类中建立一个或多个方法。 创建Web服务的步骤:(VS2008) 首先,新建一个网站。选择文件-------->新建--------->网站,打开“新建网站”对话框,选择“https://www.doczj.com/doc/0a9958531.html, web服务”模板。确定后,创建成功。 创建好后,会生成Service.asmx,其代码隐藏文件Servece.cs位于App_Code文件中。Web服务文件都使用扩展名.asmx。 发现在VS2010中,创建web服务是先新建一个网站,在选择添加新项,然后选择web 服务。 三、使用https://www.doczj.com/doc/0a9958531.html, Web服务 (1)添加Web引用 1、新建网站,右键单击网站根目录,选择“添加Web引用”项。 2、在“添加Web引用”对话框中,在URl列表框中选择或者填入Web服务的URL。(.asmx 文件路径)然后在“添加Web引用”文本框中填入希望在应用程序中使用的添加Web引用名。

Axis2从入门到精通--Webservice在eclipse下开发教程

Axis2 教程 文章分类:Java编程 Axis2是一套崭新的WebService引擎,该版本是对Axis1.x重新设计的产物。Axis2不仅支持SOAP1.1和SOAP1.2,还集成了非常流行的REST WebService,同时还支持Spring、JSON等技术。这些都将在后面的系列教程中讲解。在本文中主要介绍了如何使用Axis2开发一个不需要任何配置文件的WebService,并在客户端使用Java和C#调用这个WebService。 一、Axis2的下载和安装 读者可以从如下的网址下载Axis2的最新版本: https://www.doczj.com/doc/0a9958531.html,/axis2/ 在本文使用了目前Axis2的最新版本1.4.1。读者可以下载如下两个zip包: axis2-1.4.1-bin.zip axis2-1.4.1-war.zip 其中axis2-1.4.1-bin.zip文件中包含了Axis2中所有的jar文件, axis2-1.4.1-war.zip文件用于将WebService发布到Web容器中。 将axis2-1.4.1-war.zip文件解压到相应的目录,将目录中的axis2.war 文件放到\webapps目录中(本文使用的Tomcat的版本是 6.x),并启动Tomcat。 在浏览器地址栏中输入如下的URL: http://localhost:8080/axis2/ 如果在浏览器中显示出如图1所示的页面,则表示Axis2安装成功。 图1

二、编写和发布WebService 对于用Java实现的服务程序给人的印象就是需要进行大量的配置,不过这一点在Axis2中将被终结。在Axis2中不需要进行任何的配置,就可以直接将一个简单的POJO发布成WebService。其中POJO中所有的public方法将被发布成WebService方法。 下面我们来实现一个简单的POJO,代码如下: public class SimpleService { public String getGreeting(String name) { return "你好 " + name; } public int getPrice() { return new java.util.Random().nextInt(1000); } }

Delphi调用WebService的实例(非常经典)

Delphi 调用webservice 经典实例 Dispatch: 派遣,分派 Invoke: 调用 Invokable: 可调用接口 TReomtable: WebService中自定义类都是继承自该类 TSOAPAttachment: Attachment:附件,一种流类型,可以返回流数据 CGI:(EXE) ISAPI:(DLL) Base64编码: uses EncdDecd; s := EncodeString(s); //加 base64 编码 s := DecodeString( str ); //解码 UTF8: UTF8 是8位的UNICODE字符,而ASCII是7位 ,gb2312和unicode是2字节/字,utf8是3字节/字utf8类似以前的8位转7位的编码,是为了在网络间不同系统的通讯方便而作的转换。几乎所有用.Net写的WebService只支持DOC方式、Delphi写的只支持RPC方式;J2ME目前对Web Service的支持仅限于RFC172,而 RFC172要求必须为DOC方式(sun怎么偏袒MS?)! 为了在设计中减少障碍,下面还介绍几个概念。 1) SOAP:SOAP是一种简单有效的数据传输协议,用于分布式网络环境下数据信息交换,它以XML 作为数据传输的格式,搭配Internet上标准的传输协议HTTP、SMTP、TCP等来传送信息。从本质上看,SOAP事实上只是将Request和Response经由XML格式把数据打包,达到双方沟通的目的。 2) WSDL:WSDL(Web Service Description Language)是一种以XML格式描述的Web Service语言,当Web Service Provider 要对外公布提供的 Web Service,就需要通过WSDL来构建描述语言。在WSDL中有两个非常重要的要素::此WSDL文件所要描述的Web Service集合;每一个Port代表外界Client可以和此Service沟通的一个进入点,一个Port会指定一个Binding方式。 3):处理中文乱码的问题: 将HttpRio的 Converter 的 Options 的 soUTF8InHeader 设为 True 将生成soap消息的HTTPSoapDispatcher控件,添加encoding为gb2312 https://www.doczj.com/doc/0a9958531.html,eUTF8InHeader := True; 4)在Delphi中,能够传递的自定义类型的对象要继承TRemotable, 5:修正一个服务器端的一个Bug:将ISAPIThreadPool和ISAPIApp的次序变一下:ISAPIApp必须在 ISAPIThreadPool之前: uses ... ISAPIApp, ISAPIThreadPool 解决如下错误: Received content of invalid Content-Type setting:text/html -SOAP"expects"text/xml" 6:"XML document must have a top level element. Line: 0" 错误,我该如何解决??哈纳斯 (2002-08-05 17:26:00) 我也曾碰到同样的问题解决方法是:别设httprio的wsdllocation,设它的url 如http://localhost/mydir/project1.exe/wsdl/IFIRST mydir是你的可执行的虚拟目录,IFIRST是你定义的接口名 ********************************************************************* **************************

在VC中调用WebService

在VC中调用WebService 作者:叶小舟 下载源代码 一、什么是WebService ? WebService 其实就是一个基于网络的应用程序,它向外部程序提供一定的调 用接口。外部(远程)的程序,可以经由Web对其进行调用。 二、WebService 的特性: 1.由于WebService 经由web服务器发布,所以比DCOM而言,可以顺利穿过防火墙。这也是WebService 的优点之一,可以说,WebService ,为分布式应用的开发,提供了一个很好的平台。 2.对WebService 的调用,是通过SOAP协议进行的。简单对象访问协议(SOAP)提供了标准的远程过程调用(RPC)方法来调用Web service。而SOAP也是基于XML和XSD的,XML是SOAP的数据编码方式,因此,对WebService 的调用也可以是跨平台的。、 三、怎样调用WebService ? Visual https://www.doczj.com/doc/0a9958531.html, 内建提供了对WebService 的调用。在https://www.doczj.com/doc/0a9958531.html,中,调用WebService 只需要简单的几个步骤即可。只要找到WebService 的发布地址,将地址引入到VC工程中。这时,编译器会预先编译一次,自动生成和WebService 相关的头文件(也可以叫Web代理文件)WebService .h。在你的程序中,包含WebService .h然后生成相关的对象,就可以对远程的WebService 进行调用了。 为演示怎样调用WebService ,我们用网上一个已经发布的WebService ,名字叫TranslateService,其功能是对多种语言进行互相翻译。这个WebService 的地址如下:https://www.doczj.com/doc/0a9958531.html,/TranslateService.asmx 四、程序示例 1.基于控制台的托管程序示例

webservice接口开发

Eclipse 关于接口系统的开发 我们做接口服务端: 小知识: 接口分为:服务端与客户端 服务端:即提供者,是为调用者提供数据的一方; 客户端:即调用者,是调用接口的一方; <一> 服务端的创建 步骤1. 在eclipse新建一个普通工程,例如:新建一个web project 工程。 步骤2.创建完成后,在刚才新建的工程里面,加入我们需要实现的类,和接口。在实现类里面编写客户端传入参数后,需要的相关信息。 例如: Public String sayHello(String word) { Return word; } 步骤3. 进入服务端代码的自动生成阶段,我们选中刚才编写的实现类或是创建的工程,右键。选择,new→project…→other→,如下图,选择web service 服务端。点击next

步骤4.根据下图,通过选择实现类,点击完成。自动生成服务端了。

步骤5 .前4步骤已经完成了webservice的服务端,并已经自动启动好了,我们进行如下测试,访问下自动产生的wsdl文件是否能访问到: 例如:访问wsdl地址示例 http://10.1.159.28:8082/ICTS/services/GetWorkflowListDaoImp?wsdl 其中:GetWorkflowListDaoImp 为自己创建的实现类名称 <二>客户端的创建,测试我们完成的服务端接口:

步骤1. 创建一个普通的web project 工程 步骤2. 创建完成后,选中,我们创建的工程,右键→,new→other→,创建web service cliet 客户端,完成后,点击finish。完成 步骤3。我们通过客户端进行调用,测试一下服务端是否正常。通过如下示例地址:http://10.1.159.28:8082/test1/sampleGetWorkflowListDaoImpProxy/TestClient.jsp, 这是客户端为我们自动建立的测试页面,我们只需输入参数,就可以进行测试了。界面如下:

使用javascript调用webservice示例

使用javascript调用webservice示例 再javascript中使用soap调用webservice的示例代码 代码再IE6和FF测试通过,对于c#写的webservice和java(xfire)写的,都测试过,没有问题 此代码原型来源于https://www.doczj.com/doc/0a9958531.html,/的javascript soapclient 发现这个下载的js只能用于调用c#的webservice,所以利用mootools,重新封装,达到IE和火狐的兼容的同时,兼容java和c# (再例子中使用的mootools.v1.11.js 文件,做过修改) 客户端js调用代码如下 js 代码 1.function ajaxRequest() 2. { 3.var url = "http://localhost:88/webservicedemo.asmx"; 4. 5.//设置webService传入参数 6.// 7.//注意: 8.// 9.// 调用.Net 写的webservice(如例子中的 webservicedemo.asmx) 10. // HelloTo(String name) 针对name参数必须 写成 wqj,还有更多参数一样写,使用名称匹配 11. // 传入的参数数量可以不等于(多于或少于)方法 要求的参数 12. // 13. // 调用java(xfire) 发布的webService 14. // 传入的参数必须与调用方法的参数数量相等,且 按传入值的顺序进行匹配 15. // 16. 17. var para = "wqj"; 这里应该是一个标准的xml形式,源码贴出 来时被虑掉了,请参看附件源码 18. 19. var op = {

第一个webservice例子

第一个的webservice实例 超简单,才5步 1> 获取axis及关联的jar包 https://www.doczj.com/doc/0a9958531.html,/topics/download/6a76de1e-d506-35bc-a41b-508d4be04025 2> 新建一个模拟服务java类 package server; public class SayHello { public String getName(String name) { return "你好," + name; } } 3> 在web.xml 下新增一个servelt AxisServlet org.apache.axis.transport.http.AxisServlet AxisServlet /services/* 4> 在web项目的web.xml 同目录新建文件server-config.wsdd,自己改改

C# 调用webservice 传递实体对象

C# 调用webservice 传递实体对象 在webservice端公开一个实体类,然后实例化,赋值,然后再给到webservice,可以实现,但是,即使调用端和service端的实体类完全一致,你也要重新实例化service端的,重新赋值,将此传回service端。因为,C#是强类型的语言。 当然,你也可以通过下面的方法传递实体类,而不用太纠结于赋值了。 在调用端序列化实体对象(实体对象须是可序列化的类): public static byte[] SerializeObject(object pObj) { if (pObj == null) return null; System.IO.MemoryStream memoryStream = new System.IO.MemoryStream(); BinaryFormatter formatter = new BinaryFormatter(); formatter.Serialize(memoryStream, pObj); memoryStream.Position = 0; byte[] read = new byte[memoryStream.Length]; memoryStream.Read(read, 0, read.Length); memoryStream.Close(); return read; } 在service的调用方法中,接受一个byte[] 参数即可,然后反序列化: public object DeserializeObject(byte[] pBytes) { object newOjb = null; if (pBytes == null) { return newOjb; } System.IO.MemoryStream memoryStream = new System.IO.MemoryStream(pBytes); memoryStream.Position = 0; BinaryFormatter formatter = new BinaryFormatter(); newOjb = formatter.Deserialize(memoryStream); memoryStream.Close(); return newOjb; } 然后将object强制转换成相应的实体类型,就可以直接使用此对象了。 注:在调用端和service端都引用了同一版本的实体程序集.

学习CXF WebService入门实例一

最近开发开始学习Web Service,如果你是大神,请路过!谢谢!遵循前辈大神们的教导~~~,内事不决问度娘,外事不决问谷歌(现在谷歌已经不能用了),只能问度娘了!上网一百度,套用周董的一句歌词,霍,霍,霍,霍,这么多的套路(axis,axis2,XFire,CXF等),我到底选择哪一个?因为要和Spring进行对接,看了一下,CXF与Spring的耦合度最好,于是就选择了CXF。上官网下jar包,下了最新的apache-cxf-3.1.4.zip包。解压出来,看看里面的最简单的实例,apache-cxf-3.1.4\samples\java_first_jaxws,本着你快乐所以我快乐加上不要脸的原则,我抄抄抄,改了一下名字,开发环境jdk1.6, jdk1.5没试过,上眼呐! 新建工程mywbs,导入jar包 cxf-core-3.1.4.jar jetty-continuation-9.2.11.v20150529.jar jetty-http-9.2.11.v20150529.jar jetty-io-9.2.11.v20150529.jar jetty-server-9.2.11.v20150529.jar jetty-util-9.2.11.v20150529.jar wsdl4j-1.6.3.jar xmlschema-core-2.2.1.jar 一、接口类IHelloWorld.java package com.ws.hello; import java.util.List; import javax.jws.WebService; import https://www.doczj.com/doc/0a9958531.html,ers; @WebService public interface IHelloWorld { public String sayHello(String name); public String getUserName(Users user); public List getListUser(); } 二、实现类(说明endpointInterface = "com.ws.hello.IHelloWorld",IHelloWorld 类加上路径,此处注意)HelloWorldImpl.java package com.ws.hello; import java.util.ArrayList; import java.util.List; import javax.jws.WebService; import https://www.doczj.com/doc/0a9958531.html,ers; @WebService(endpointInterface = "com.ws.hello.IHelloWorld",serviceName = "IHelloWorld", portName="IHelloWorldPort") public class HelloWorldImpl implements IHelloWorld { @Override public String sayHello(String name) { return name + ": 您好啊!";

JAVA 利用axis2或cxf调用ABAP发布的Webservice

JA V A 利用axis2或cxf调用ABAP发布的Webservice 1.调用过程中存在问题及解决办法 1.1无法利用AXIS2, CXF标准工具解析ECC发布的地址。 解决:利用IE访问Webservice地址,然后将其另存为*.xml文件 利用CXF工具,编译该*.xml 文件,生成JAVA类。 输入:wsdl2java -d src - client http://Webservice。。。。。。。 附加:wsdl2java用法: wsdl2java -p com -d src -all aa.wsdl -p 指定其wsdl的命名空间,也就是要生成代码的包名: -d 指定要产生代码所在目录 -client 生成客户端测试web service的代码 将文件拷贝到程序中。 注意问题:1. 类文件中的包名需要修改,部分定义的-包.类-格式中的包也需要修改. 2. 工具生成类的过程中,如果出现重名的情况(例如某类:TEST,但是有其他类 应该是test,大小写不区分),一般只会保存一个类,需要手工添加缺少的类(可从其他代码的报错信息看出)。 1.2访问权限问题: 访问的权限体现在http的体系中 不同的调用方式,拥有不同的设置权限方法,以CXF为例: 需要在解析后的**client类中添加代码: Client client = ClientProxy.getClient(port); HTTPConduit http = (HTTPConduit) client.getConduit(); AuthorizationPolicy auth = new AuthorizationPolicy(); auth.setUserName("gang.xu"); auth.setPassword("654321"); h ttp.setAuthorization(auth); 1.3访问地址: ABAP会发布两种可以访问的WSDL地址; 第一种: https://www.doczj.com/doc/0a9958531.html,:8000/sap/bc/srt/rfc/sap/ytest_se rvice/300/ytest_service/ytest_service

创建WebService使用Axis2和CXF的区别

创建WebService使用Axis2和CXF的区别 J2EE中WebService的建立可以使用Axis2,也可以使用Apache CXF,两者的区别与优缺点如下: Web Services 框架如Axis2、CXF 都是由现有的项目中逐渐演化而来的,Axis2 是由Axis 1.x 系列演化过来,而Apache CXF 则是由Celtix 和XFire 项目整合而生,并且刚刚发布了2.0.2 的最新版本,不过仍是Apache 的一个孵化项目。 Axis2 是对Axis 进行了彻底的重写的一个新项目了,它使用了新的模块化架构,更方便于功能性的扩展等等。 Apache CXF 则是由XFire 和Celtix 两个现有的项目进行了重组。 先比较一下它们的不同之处: 1、Apache CXF 支持WS-Addressing、WS-Policy、WS-RM、WS-Security和WS-I BasicProfile 2、Axis2 支持WS-Addressing、WS-RM、WS-Security和WS-I BasicProfile,WS-Policy将在新版本里得到支持 3、Apache CXF 是根据Spring哲学来进行编写的,即可以无缝地与Spring进行整合 4、Axis2 不是 5、Axis2 支持更多的data bindings,包括XMLBeans、JiBX、JaxMe 和JaxBRI,以及它原生的data binding(ADB)。 6、Apache CXF 目前仅支持JAXB 和Aegis,并且默认是JAXB 2.0,与XFire 默认是支持Aegis 不同,XMLBeans、JiBX 和Castor 将在CXF 2.1 版本中得到支持,目前版本是2.0.2 7、Axis2 支持多种语言,它有C/C++ 版本。 8、Apache CXF 提供方便的Spring整合方法,可以通过注解、Spring标签式配置来暴露Web Services和消费Web Services 如何抉择: 1、如果应用程序需要多语言的支持,Axis2 应当是首选了; 2、如果应用程序是遵循Spring 哲学路线的话,Apache CXF 是一种更好的选择,特别对嵌入式的Web Services 来说; 3、如果应用程序没有新的特性需要的话,就仍是用原来项目所用的框架,比如Axis1,XFire,Celtrix 或BEA 等等厂家自己的Web Services 实现,就别劳民伤财了 因为CXF可以和Spring无缝的进行结合,而我的项目用到了spring ,所以我选的是CXF。

在ASPNET中调用WebService接口

一、在https://www.doczj.com/doc/0a9958531.html,中调用基于HTTP基本认证的WebService接口 在https://www.doczj.com/doc/0a9958531.html,中调用基于HTTP基本认证的WebService接口的方法: 1、先用WSDL.EXE工具生成接口的代理类。 2、在代理类中重载GetWebRequest方法 protected override https://www.doczj.com/doc/0a9958531.html,.WebRequest GetWebRequest(Uri uri) { HttpWebRequest request= (HttpWebRequest)base.GetWebRequest(uri); if (PreAuthenticate) { NetworkCredential networkCredentials = Credentials.GetCredential(uri, "Basic"); if (networkCredentials != null) { byte[] credentialBuffer = new UTF8Encoding().GetBytes( https://www.doczj.com/doc/0a9958531.html,erName + ":" + networkCredentials.Password); request.Headers["Authorization"] = "Basic " + Convert.ToBase64String(credentialBuffer);//将验证信息添加到HTTP头} else { throw new ApplicationException("No network credentials"); } } return request; } 3、在客户端使用以下方式进行调用: WebService service = new WebService();//代理类 NetworkCredential netCredential = new NetworkCredential("test", "test");//创建网络标识,此处填写用户名和密码Uri uri = new Uri(service.Url); ICredentials credentials = netCredential.GetCredential(uri, "Basic"); service.Credentials = credentials; service.PreAuthenticate = true; service.Method();

相关主题
文本预览
相关文档 最新文档