pb调用webservice

pb调用webservice
pb调用webservice

webservice服务器端会提供wsdl接口文档,pb里面用web service proxy wizard从wsdl 生成对象,再调用即可(注意把c:\program files\sybase\shared\powerbuilder下面的pbsoapclient90.pbd加入target),代码样例:

SoapConnection lsc_conn

soapservice lproxy_obj

String ls_proxy_name = "soapservice "//生成的代理对象名称

String ls_url = "http://localhost:8080/axis/services/SoapService "//web service url

//

lsc_conn = Create SoapConnection

lsc_conn.SetOptions( "SoapLog=~ "soaplog.txt~ " ")

int li_ret, i

li_ret = lsc_conn.Createinstance( lproxy_obj, ls_proxy_name, ls_url)

If li_ret <> 0 Then

MessageBox( "错误", "调用失败,错误号码:" + String(li_ret))

Return

End If

tns1__requestcontent lst_request

lst_request.arg1 = 5

lst_request.arg2 = "test "

tns1__returnresult lst_result

lst_result = lproxy_obj.GetResult(lst_request)

MessageBox(String(lst_result.result), "code: " + lst_result.reason.code + "~nmessage: " + &

lst_result.reason.message + "~ndesc: " + lst_result.reason.desc )

注意pb调用webservice只能返回简单的int string类型,复杂的结构会出错

怎么样在pb9里面调用WebService

pb9也出来了,速度够快的,大概看了一下,与pb8比较,增加的功能不多,主要是WebService,Xml和Ejb.我就感受了一下pb9的WebService功能,与大家共享。

我们用一个实例来说明:

新建应用,这些步骤与pb8一致的。然后建立一个WebService Proxy Wizard,下一步会提示你输入WSDL文件,点击浏览选择,假设是C:\inetpub\wwwroot\的service1.wsdl文件。点击下一步,会自动出现WSDL文件中的Service.点击下一步,系统默认选择ServiceSoap,紧接着输入proxy name(代理对象名),输入test_ws.后面的几项按默认即可。

完成后是编译代理对象的界面。会出现:

Web Service Generator Project Status

Deployment PBL: E:\program\pb\webservice\w_app.pbl

Clear PBL on build: No

Confirm overwrites: No

WSDL Location: file://E:\program\pb\webservice\service1.wsdl

Services selected :

Service Service1:

Service1Soap

可以在属性中设置,也可以不用去管。点击编译的绿色图标,好了,一个代理对象生成了。在左边的treeview中可以看到如:test_wsservice1soap的东西。

点击加号的图标,在function中可以看到里面的我们定义的show(string yourname) returns string.

好了最重要的一步已经完成了,我们来测试一下:

建一个windows,添加一个文本框和按钮控件。

在cb_1.click事件写入:

SoapConnection conn

Test_wsservice1soap test_ws

long rVal

//string str_endpoint

//str_endpoint = "http://localhost/webserver/service1.asmx?WSDL"

conn = create SoapConnection

rVal = Conn.CreateInstance(test_ws, "test_wsservice1soap")

sle_1.text = test_ws.show("你的参与是我们最大的支持")

destroy conn

好了,保存,会提示SoapConnection未定义。

增加PBSoapClient90.pbd到库列表中。PBSoapClient90.pbd在pb安装目录下Shared\PowerBuilder。增加后左边treeview会出现soapconnection,SOAP server soapexception 两个对象.

运行,点击按钮,文本框中出现https://www.360docs.net/doc/f611895827.html,欢迎你的参与是我们最大的支持

注意的是:Service1.asmx文件在服务器上是可以运行的,否则不会出现东西的。

添加PBSoapClient90.pbd和引用webservice

作者:feique123 2009-10-10 15:06 星期六晴

1、PBSoapClient90.pbd在pb安装目录下Shared\PowerBuilder。在pb的tree中的target 属性中添加。增加后左边treeview会出现soapconnection,SOAP server soapexception 两个对象.。

2、在一个按钮的click事件中写的如下例子。

SoapConnection conn

Test_wsservicesoap test_ws

long rVal

conn = create SoapConnection

rVal = Conn.CreateInstance(test_ws, "test_wsservicesoap")

sle_1.text =string(test_ws.jihe("select * from t_user", "t_user"))

destroy conn

注:test_ws为代理对象名

3、要想在pb中用webservice必须要建一个webservice,其引用的wsdl文件,应该是pb所在机器上访问到的wsdl文件,也就是所能访问的webservice服务。

PBDOM操作XML文档轻松入门(Easy XML with PowerBuilder Document Object Model) (作者:Terry Voth、JohnStrano)

(根据https://www.360docs.net/doc/f611895827.html,/sb_content/1027266/XML_PB_DOM.pdf 翻译整理)

本文对PBDOM技术进行相关介绍,但并不涉及XML的基础知识,建议阅读者对下述相关术语有一定了解:Document(文档), DTD(文档类型定义), schema(大纲),Element (元素), attribute(属性), processing instruction(处理命令), entity(实体)。

本文主要包括以下内容:

1、为什么要使用PBDOM以及怎样创建PBDOM

2、PBDOM主要用于那些地方

3、如何使用PBDOM编程

4、PBDOM和其他XML解析(parser)技术的比较

一、什么是DOM

◆文档对象模型(Document Object Model)

1、作为一项W3C规范,XML DOM存在目的是为不同类型的应用程序提供一个标准的编程接口,它被设计可以跨平台、跨语言使用。

2、我们可以利用XML DOM创建XML文档并操纵其结构,增加、修改、删除元素。

3、程序中调用XML解析器载入XML文档到内存中。当文档被载入后,可以通过进入DOM 检索和操作相关信息。

4、DOM 保存了XML文档树,文档(document)元素位于整棵树的最顶层。该元素可以有一到多个子节点来保存树的结构。

可以参阅以下网站:https://www.360docs.net/doc/f611895827.html,/dom/ 来了解更多的关于XML Document Object Model的内容。

二、什么时候应该使用DOM工具

◆当你需要做下列事情的时候,你应该想到XML DOM的

1、在一个或者多个XML文档之间移动元素

2、创建新的元素并且在XML文档的任意位置插入

3、操作元素并重新插入其到XML文档其他位置

4、导入内嵌数据结构

& . pb9中,数据窗口现在可以通过XML导出内嵌数据结构(nested data structures).

三、什么是PBDOM

◆PowerBuilder 文档结构模型(PowerBuilder Document Object Model)

1、PBDOM是通过PBNI扩展出来的,用于操作XML数据,并针对PowerScript作了优化

2、在程序中模型是通过DOM的抽象来表示XML数据。(A programming model to represent

XML data –an abstraction of DOM)

3、底层是对Apache Xerces/C++的封装。

四、PBDOM的设计目标

1、简单易用(Be straightforward for PowerBuilder programmers)

2、可以利用PowerScript的强大语言能力(如对象、方法重载、数据等)

3、在可能的情况下,隐藏了XML底层的复杂实现(Hide the complexities of XML wherever possible)

4、原有的DOM在pb下使用不够直观(DOM is unintuitive to a PowerBuilder programmer)

五、使用PBDOM初步

◆PBDOM设置

1、添加pbdom90.pbd(%SYBASE%\Shared\PowerBuilder)到工程的pbl列表中

2、%SYBASE%\Shared\PowerBuilder应该在系统路径或者应用程序的路径中(也就是pbdom 要使用此路径下的pbdom90.dll, pbxerces90.dll、xerces_2_1_0.dll文件,同样,当程序发布时候也需要)

六、PBDOM类的使用

◆如图所示,反映了PBDOM类的组成和继承关系,可以看到,几乎所有的PBDOM类都继承自PBDOM_Object(除了PBDOM_Builder和PBDOM_Exception)

1、PBDOM_Document

◆构建PBDOM举例

1.1 直接构建(XML documents can be created from scratch)

PBDOM_Document doc

PBDOM_Element rootdoc = CREATE PBDOM_Document

root = CREATE PBDOM_Element

root.SetName( "root" )

root.SetText( "this is the root" )

doc.AddContent( root )

1.2 从文件、字符串、DataStore中载入

PBDOM_Builder builder

doc = builder.BuildFromString( "bar" )

doc = builder.BuildFromFile( "c:\foo\bar.xml"

doc = builder.BuildFromDataStore( l_ds)

2、PBDOM_Element

2.1 遍历元素

PBDOM_Element root, children[], first

// Get the root element of the document

root = doc.GetRootElement()

// Get an array of all child elements

root.GetChildElements( children )

// Get only elements with a given name

root.GetChildElements( "name", children )

// Get the first element with a given name

first = root.GetChildElement( "name" )

注意:

上例中得到的元素数组是联动的!(The element array is live!)即:

◆修改数组中的元素,同样会作用到父文档

◆返回的数组是有界的(Once the array is returned, it is now bounded)

◆在数组中增加新元素时,需要一个SetContent()方法调用

2.2 移动元素

// PBDOM_Document docOne,docTwo

PBDOM_Element movable

movable = CREATE PBDOM_Element

Movable.SetName( "movable" )

docOne.AddContent( movable ) // add

movable.Detach() // remove

docTwo.addContent( movable ) // add again

注意:

1、只要是从PBDOM_Object继承的对象,都可以调用Detach()方法(如Comments、ProcessingInstructions、Elements (and their content)等等)

2、PBDOM元素对象不是永久的捆绑在它的父文档上的(PBDOM elements aren't permanently tied to their parent document)

2.3 符合规格(Always well-formed)

PBDOM_Element构造器以及setter方法会检查元素是否符合规格:

elem.SetName( "Spaces are illegal" )

AddContent()方法也会从以下几个方面进行检查:

◆结构---树中没有循环(Structure –no loops in any tree)

◆只有一个根节点元素(One and only one root element) ◆相容的命名空间(Consistent namespaces)

3、PBDOM_Attribute

3.1 操作元素属性

◆元素可以有多个属性

// Get an attribute

ls_width = table.GetAttributeValue( "width" ) // or

ls_width = table.GetAttribute ( "width" ).GetText()

// Attributes can be typed

li_border = table.GetAttribute( "width" ).GetIntValue()

// Set an attribute

table.SetAttribute( "cellspacing", "0" )

// Remove an attribute

table.RemoveAttribute( "cellspacing" )

// Remove all attributes

PBDOM_Attribute empty[]

table.SetAttributes( empty ) // the PowerScript way

4、PBDOM_Text

4.1 操作元素文本内容

cool demo

// the text is directly available –returns

// "~r~ncool demo~r~n"

ls_desc= elem.GetText()

// two convenience methods

ls_desc= elem.GetTextTrim()// returns "cool demo"

ls_desc = elem.GetTextNormalize()// returns "cool demo"

// text can be changed directly

elem.SetText( "a new description" )

5、PBDOM_Object

5.1 操作有混合内容的元素

cool demo

PBDOM_Object content[]

desc.GetContent( content )

FOR i = 1 TO UpperBound( content )

CHOOSE content[i].GetObjectClassString()

CASE "pbdom_comment"

// ...

CASE "pbdom_processinginstruction"

// ...

END CHOOSE

NEXT

6、PBDOM_ProcessingInstruction

6.1 使用处理命令(Processing instructions)

{------target------} {----------------data---------------}

// Get target (e.g., "xsl-stylesheet")

ls_target = pi.GetTarget()

// Get data (e.g., 'type="text/xsl"href="foo.xsl"')

ls_data = pi.GetText()

// Get individual values as attributes

String names[]

pi.GetNames( names )

FOR i = 1 TO UpperBound( names )

MessageBox( names[i], pi.GetValue( names[i] )

NEXT

7、PBDOM and 命名空间(Namespaces)

......

String ls_element

PBDOM_Element template

// get element name and namespace –return "xsl:template"

template = root.GetChildElement( "template" )

ls_element= template.GetNamespacePrefix() +":"+ template.Getname()

// get element by name and namespace

template = root.GetChildElement( "template", "xsl", "https://www.360docs.net/doc/f611895827.html,/1999/XSL/Transform")

七、PBDOM vs. the Competition

◆Apache Xerces/COM

Xerces 是现在PBDOM底层使用的XML解析器,但对PowerBuiler用户来说使用不直观。(Xerces is the [current] underlying XML parser for PBDOM, but is less intuitive)

◆MSXML

.无法在UNIX等操作系统上使用(No deployment to UNIX possible)

.同样对PowerBuiler用户来说使用不够直观(Less Intuitive)

.COM collections vs. PB arrays (pb用户当然会优先选择使用数组来处理数据)

◆Others

Expat–a C DLL (使用时需要声明外部函数…使用不够广泛)

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所示,如果能到这里,就基本没有问题了

Webservice接口开发

Webservice接口开发 Author:Geloin

目录 1 准备工作 (1) 2 服务器端 (1) 2.1 主程序 (1) 2.2 services.xml (2) 2.3 传值方式 (3) 2.4 打包 (4) 2.5 发布 (6) 3 客户端 (8) 3.1 导入包 (8) 3.2 示例代码 (8) 3.3 代码解析 (10) 3.3.1 设定服务器地址 (10) 3.3.2 设定action (10) 3.3.3 设定要调用的方法名 (11) 3.3.4 设定客户端控件 (11) 3.3.5 设定命名空间 (11) 3.3.6 设定需要传送的值 (11) 3.3.7 设定返回数据类型 (11) 3.3.8 获取返回结果 (12)

1准备工作 至https://www.360docs.net/doc/f611895827.html,/axis2/下载axis2的bin及war包,分别解压之,在环境变量中添加AXIS2_HOM,将axis2.war放置到tomcat/webapps目录下,启动tomcat,用浏览器打开http://localhost:8080/axis2,如下图所示: 2服务器端 2.1主程序 服务器端可以是任何一个程序,例如下面的例子: public class Test { // 此程序返回一个字符串 public String test1(String arg) { return arg + “测试”; } // 此程序返回一个一维数组 public String[] test2(String arg) { String[] result = new String[]{arg}; return result;

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.360docs.net/doc/f611895827.html,.URL; import https://www.360docs.net/doc/f611895827.html,.URLConnection; import https://www.360docs.net/doc/f611895827.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.360docs.net/doc/f611895827.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(

SAP开发webservice接口教程

SAP开发webservice接口教程 在client=100中进行开发: 1.创建RFC函数 SE80,在函数组下,右击->创建,创建函数模块,填写函数模块名称及描述。 2.函数属性标签页,选择“远程启用的模块”,其余默认不变。 3.函数导入标签页,需要添加调用时传入的参数(表),“传递值”需勾选。 表类型:ZSHR_EMPLOYEER_T (需要自己创建) 行类型:ZSHR_EMPLOYEER (需要自己创建)

4.函数导出标签页,需要添加调用返回的参数(表),“传递值”需勾选。 表类型:ZSHR_EMPLOYEER_OUT_T (需要自己创建) 行类型:ZSHR_EMPLOYEER_OUT (需要自己创建) 5.函数源代码标签页,需要写代码实现把传入的数据保存在透明表中。 至此,函数创建完成。 6.创建Web Services 右击包名创建企业服务,进入如下页面,选择“Service Provider”,因为我们是服务提供者,点击“继续”。

7.选择“Existing ABAP Object (Inside Out)”,点击“继续”。 8.给服务起名,并填写描述,点击“继续”

9.选择“Function Module”,点击“继续”。 10.填写我们第一步创建的函数,并勾选“Map Name”,点击“继续”。 11.SOAP Appl默认不变,Profie下拉框选择第四个选择,即不进行权限认证。点击“继续”。 12.填写对于的包和请求,点击“继续”。 下一步,直接点击“完成”。服务创建成功。

13.配置SOA 使用T-CODE:soamanager,进入web页面的SOA管理(client=100)。 14.点击“简化Web服务配置”,进入如下设置页面,点击“执行”,从列表中找到自己创建的 服务,勾选第一个checkbox,User Name/Password(basic),点击列表左上角的“保存”,之后页面右上角的“返回”按钮,返回首页。 这一步设置,代表我们只设置用户名/密码的调用认证方式。

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的话,就可以从用户界面直接调用中间层组件,

【WebService】接口的测试方法

【WebService】接口的测试方法 有以下多种方式: 一、通过WSCaller.jar工具进行测试: 前提:知道wsdl的url。 wsCaller可执行程序的发布方式为一个wsCaller.jar包,不包含Java运行环境。你可以把wsCaller.jar复制到任何安装了Java运行环境(要求安装JRE/JDK 1.3.1或更高版本)的计算机中,用以下命令运行wsCaller: java -jar wsCaller.jar 使用wsCaller软件的方法非常简单,下面是wsCaller的主界面: 首先在WSDL Location输入框中输入你想调用或想测试的Web Service的WSDL位置,如“https://www.360docs.net/doc/f611895827.html,/axis/services/StockQuoteService?wsdl”,然后点“Find”按钮。wsCaller就会检查你输入的URL地址,并获取Web Service的WSDL信息。如果信息获取成功,wsCaller会在Service和Operation下拉列表框中列出该位置提供的Web Service服务和服务中的所有可调用的方法。你可以在列表框中选择你要调用或测试的方法名称,选定后,wsCaller窗口中间的参数列表框就会列出该方法的所有参数,包括每个参数的名

称、类型和参数值的输入框(只对[IN]或[IN, OUT]型的参数提供输入框)。你可以输入每个参数的取值。如下图: 这时,如果你想调用该方法并查看其结果的话,只要点下面的“Invoke”按钮就可以了。如果你想测试该方法的执行时间,则可以在“Invoke Times”框中指定重复调用的次数,然后再按“Invoke”按钮。wsCaller会自动调用你指定的方法,如果调用成功,wsCaller会显示结果对话框,其中包括调用该方法所花的总时间,每次调用的平均时间和该方法的返回值(包括返回值和所有输出型的参数)。如下图:

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

本文实例讲述了https://www.360docs.net/doc/f611895827.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.360docs.net/doc/f611895827.html, WEB服务 建立Web服务就是把一些信息或逻辑对其他计算机和客户公开,进一步说,就是从支持SOAP通信的类中建立一个或多个方法。 创建Web服务的步骤:(VS2008) 首先,新建一个网站。选择文件-------->新建--------->网站,打开“新建网站”对话框,选择“https://www.360docs.net/doc/f611895827.html, web服务”模板。确定后,创建成功。 创建好后,会生成Service.asmx,其代码隐藏文件Servece.cs位于App_Code文件中。Web服务文件都使用扩展名.asmx。 发现在VS2010中,创建web服务是先新建一个网站,在选择添加新项,然后选择web 服务。 三、使用https://www.360docs.net/doc/f611895827.html, Web服务 (1)添加Web引用 1、新建网站,右键单击网站根目录,选择“添加Web引用”项。 2、在“添加Web引用”对话框中,在URl列表框中选择或者填入Web服务的URL。(.asmx 文件路径)然后在“添加Web引用”文本框中填入希望在应用程序中使用的添加Web引用名。

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.360docs.net/doc/f611895827.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是你定义的接口名 ********************************************************************* **************************

webservice四种发布方式及客户端调用

WebService 四种发布方式总结 Author:yczhang 1.CXF方式 CXF与spring搭建webservice是目前最流行的方式,但是传闻cxf与jdk1.5有些不兼容,我没有遇到过,我遇到的问题是cxf与was6.1.1不兼容,表现在cxf必须的jar包“wsdl4j-1.6.2.jar”报错,报的错为:https://www.360docs.net/doc/f611895827.html,ng.IncompatibleClassChangeError,明显的jar包不兼容问题,很是头痛,后来查找资料找到解决办法是,将上述jar包新建一个was共享库,可以解决,但是客户周经理不想用此种方式,因为需要修改was,于是改用了axis2方式,下文会介绍。该问题在此处做个记录,以后使用cxf与was的时候需要注意!!! 使用cxf+spring搭建WebService: 第一步,添加jar包。此处需要注意,不同环境(tomcat、was)jar也不一定相同,例如我本地cxf+spring只需要如下jar包: 而泰康的was环境则需要如下jar包:

明显的多了很多,原因应该是服务器jar包池的不同。根据错误提示缺什么补什么就可以了,注意jar包勿重复。 第二步,配置web.xml文件,如下(重要的地方已标记): contextConfigLocation classpath:/applicationContext.xml org.springframework.web.context.ContextLoaderListener encodingFilter org.springframework.web.filter.CharacterEncodingFil ter encoding UTF-8 encodingFilter /* CXFServlet org.apache.cxf.transport.servlet.CXFServlet 1 CXFServlet /webservice/* 上述标记的地方,第一处是spring配置文件路径;第二出是wsdl地址内容;

在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.360docs.net/doc/f611895827.html, 内建提供了对WebService 的调用。在https://www.360docs.net/doc/f611895827.html,中,调用WebService 只需要简单的几个步骤即可。只要找到WebService 的发布地址,将地址引入到VC工程中。这时,编译器会预先编译一次,自动生成和WebService 相关的头文件(也可以叫Web代理文件)WebService .h。在你的程序中,包含WebService .h然后生成相关的对象,就可以对远程的WebService 进行调用了。 为演示怎样调用WebService ,我们用网上一个已经发布的WebService ,名字叫TranslateService,其功能是对多种语言进行互相翻译。这个WebService 的地址如下:https://www.360docs.net/doc/f611895827.html,/TranslateService.asmx 四、程序示例 1.基于控制台的托管程序示例

ESB部署WebService接口(统一用户和待办)

1统一待办(WebService方式) 1.1概述 门户系统做为用户访问各集成应用系统的统一入口,用户访问企业内部信息资源时只需要登录到门户系统,就可使用门户系统集成的各个应用,而待办做为各系统中用户需要处理的工作,门户系统需要提供收集建投内部应用系统中产生的待办信息,并且进行统一展现的功能,即统一待办功能。 统一待办应用业务涉及到的系统其中包括本期门户系统建设过程中所需集成的OA、WCM、EAM系统。 为保证门户系统接入各应用系统待办信息的规范性,现就各应用系统接入实现做统一要求,以确保门户系统统一待办功能实现的规范性、重用性及安全性。不满足本技术方案提供的接入规则的相关应用系统,应参考本文档完成对应用系统改造后方可进行门户系统统一待办接入工作。 统一待办实现共分为以下部分: 系统待办信息获取 系统待办信息展示 系统待办信息处理 1.2待办信息获取 设计思路:应用系统通过门户系统提供的webservice接口向门户系统统一待办系统库写入代表信息,如下图

数据获取设计示意图 步骤如下: 1.应用系统需获得最新的待办信息。 2.应用系统通过门户接口,将获得的最新待办信息发送到门户系统。 3.统一待办系统将应用系统提供的待办信息展示给用户。 4.应用系统通过调用集成接口后获得信息,可以判断发送信息操作是否正常。 1.3待办信息展示 设计思路:应用系统将最新的待办信息发送到统一待办系统中,并最终展示到门户首页上的待办栏目上,如下图 用户 待办栏目页面 待办集中展示设计示意图 场景如下:

在所有的待办类标题前加上”请办理”,待阅类标题前加上”请审阅”。此外,如果信息是未办或者未阅,用红色表示 1.4待办信息处理 设计思路:用户点击门户系统上“待办栏目”里的一条待办时,弹出一个新页面,首先同应用系统实现SSO,然后跳转到应用系统的待办页面,完成待办处理后,由应用系统调用门户接口通知门户系统,并关闭弹出的待办处理页面,门户系统负责即时刷新门户待办页。如下图: 待办信息集中处理设计示意图

使用javascript调用webservice示例

使用javascript调用webservice示例 再javascript中使用soap调用webservice的示例代码 代码再IE6和FF测试通过,对于c#写的webservice和java(xfire)写的,都测试过,没有问题 此代码原型来源于https://www.360docs.net/doc/f611895827.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 = {

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端都引用了同一版本的实体程序集.

在ASPNET中调用WebService接口

一、在https://www.360docs.net/doc/f611895827.html,中调用基于HTTP基本认证的WebService接口 在https://www.360docs.net/doc/f611895827.html,中调用基于HTTP基本认证的WebService接口的方法: 1、先用WSDL.EXE工具生成接口的代理类。 2、在代理类中重载GetWebRequest方法 protected override https://www.360docs.net/doc/f611895827.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.360docs.net/doc/f611895827.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();

C# .NET 动态调用webservice的三种方式

动态调用webservice的三种方式 多数时候我们通过"添加Web 引用..." 创建客户端代理类的方式调用WebService,但在某些情况下我们可能需要在程序运行期间动态调用一个未知的服务。在.NET Framework 的System.Web.Services.Description 命名空间中有我们需要的东西。 具体步骤: 1. 从目标URL 下载WSDL 数据。 2. 使用ServiceDescription 创建和格式化WSDL 文档文件。 3. 使用ServiceDescriptionImporter 创建客户端代理类。 4. 使用CodeDom 动态创建客户端代理类程序集。 5. 利用反射调用相关WebService 方法。 上述步骤需要引用如下四个名称空间: using System.Web.Services.Description; //WS的描述 //以下几个用于根据描述动态生成代码并动态编译获取程序集 using System.CodeDom; using Microsoft.CSharp; using https://www.360docs.net/doc/f611895827.html,piler; 上述几个名称空间中包括如下几个重要的类: using System.Web.Services.Description下: ServiceDescription //WS描述 ServiceDescriptionImporter //通过描述生成客户端代理类,特别注意其中的Style 以下是MSDN对其的描述: XML Web services 的接口通常由Web 服务描述语言(WSDL) 文件来说明。例如,若要获取有关使用http://localhost/service.asmx 处公开的https://www.360docs.net/doc/f611895827.html, 的Web 服务的WSDL 说明,只需导航到http://localhost/service.asmx?WSDL。使用ServiceDescriptionImporter 类可以方便地将WSDL 说明中包含的信息导入到System.CodeDom.CodeCompileUnit 对象。通过调整Style 参数的值,可以指示ServiceDescriptionImporter 实例生成客户端代理类(通过透明调用该类可提供Web 服务的功能)或生成抽象类(该类封装Web 服务的功能而不实现该功能)。如果将Style 属性设置为Client,则ServiceDescriptionImporter 生成客户端代理类,通过调用这些类来提供说明的Web 服务的功能。如果将Style 属性设置为Server,则ServiceDescriptionImporter 实例生成抽象类,这些类表示所说明的XML Web services 的功能而不进行实现。然后,可以通过编写从这些抽象类继承的类来对其进行实现,并实现相关的方法。 using System.CodeDom下: CodedomUnit //它用于设定动态代码的名称空间,类名等,可以通过ServiceDescriptionImporter.Import()方法将WS的描述代码写入该类,以作动态编译用using https://www.360docs.net/doc/f611895827.html,piler下: CodedomProvider //用于创建和检索代码生成器和代码编译器的实例,我们主要用到其实现子类CShareCodeProvider 可以直接用CShareCodeProvider provider=new CShareCodeProvider()来生成,或者用

ESB部署WebService接口(统一用户和待办)

1 统一待办(WebService方式) 1.1 概述 门户系统做为用户访问各集成应用系统的统一入口,用户访问企业内部信息资源时只需要登录到门户系统,就可使用门户系统集成的各个应用,而待办做为各系统中用户需要处理的工作,门户系统需要提供收集建投内部应用系统中产生的待办信息,并且进行统一展现的功能,即统一待办功能。 统一待办应用业务涉及到的系统其中包括本期门户系统建设过程中所需集成的OA、WCM、EAM系统。 为保证门户系统接入各应用系统待办信息的规范性,现就各应用系统接入实现做统一要求,以确保门户系统统一待办功能实现的规范性、重用性及安全性。不满足本技术方案提供的接入规则的相关应用系统,应参考本文档完成对应用系统改造后方可进行门户系统统一待办接入工作。 统一待办实现共分为以下部分: 系统待办信息获取 系统待办信息展示 系统待办信息处理 1.2 待办信息获取 设计思路:应用系统通过门户系统提供的webservice接口向门户系统统一待办系统库写入代表信息,如下图

数据获取设计示意图 步骤如下: 1.应用系统需获得最新的待办信息。 2.应用系统通过门户接口,将获得的最新待办信息发送到门户系统。 3.统一待办系统将应用系统提供的待办信息展示给用户。 4.应用系统通过调用集成接口后获得信息,可以判断发送信息操作是否正常。 1.3 待办信息展示 设计思路:应用系统将最新的待办信息发送到统一待办系统中,并最终展示到门户首页上的待办栏目上,如下图 用户 待办栏目页面 待办集中展示设计示意图 场景如下:

在所有的待办类标题前加上”请办理”,待阅类标题前加上”请审阅”。此外,如果信息是未办或者未阅,用红色表示 1.4 待办信息处理 设计思路:用户点击门户系统上“待办栏目”里的一条待办时,弹出一个新页面,首先同应用系统实现SSO,然后跳转到应用系统的待办页面,完成待办处理后,由应用系统调用门户接口通知门户系统,并关闭弹出的待办处理页面,门户系统负责即时刷新门户待办页。如下图: 待办信息集中处理设计示意图

四种方式调用webservice

四种客户端调用WEBSERVICE 王凡 Woshiwangfan@https://www.360docs.net/doc/f611895827.html, Wf141732@https://www.360docs.net/doc/f611895827.html, 2009-08-22

目录 1.文档概述 (2) 1.1.相关文档 (2) 2.SERVER端 (3) 2.1.代码 (3) 2.2.SERVER端生成Wsdl (4) 2.3.服务端安全性设置 (6) 3.VB调用 (13) 3.1.准备 (13) https://www.360docs.net/doc/f611895827.html,调用 (16) 4.1.实现过程 (16) 5.Axis2调用 (17) 5.1.Axis2的安装 (17) 5.2.Axis2调用过程 (17) 6.Weblogic调用 (21) 6.1.Weblogic (21) 7.已解决及未解决的问题 ........................................................... 错误!未定义书签。 7.1.未解决的问题.................................................................... 错误!未定义书签。 7.2.已解决的问题.................................................................... 错误!未定义书签。

1.文档概述 1.1.相关文档 《Web Services开发教程.doc》

2.SERVER端 这个主要是用weblogic的workshop开发,用weblogic开发webservice具体可见沈辉的 《Web Services开发教程.doc》,这里主要是讲客户端调用,所以服务端只作罗列。 2.1.代码 在weblogic中构建webservice可以见《Web Services开发教程.doc》,用于本次测试的 Server代码如下: Model: package https://www.360docs.net/doc/f611895827.html,.tsingtao.logistics.model; import java.io.Serializable; public class test implements Serializable { private static final long serialVersionUID = 1L; private String NAME; private int AGE; public void setNAME(String name) { NAME=name; } public void setAGE(int age) { AGE=age; } public String getNAME() { return NAME; } public int getAGE() { return AGE; } } Service代码如下: public https://www.360docs.net/doc/f611895827.html,.tsingtao.logistics.model.test[] hello(String NAME,int AGE) { https://www.360docs.net/doc/f611895827.html,.tsingtao.logistics.model.test[] t=new https://www.360docs.net/doc/f611895827.html,.tsingtao.logistics.model.test[10];

相关文档
最新文档