摘要:有时我们需要在WCF中做一些复杂数据处理和逻辑判断等,这时候就需要在NodeJS中调用WCF服务获取数据,这篇文件介绍如何在Node中调用WCF服务获取数据。

Node项目中调用WCF服务获取数据,通常需要将获取到的table或list类型数据转为json格式,来调用回调函数向前台显示数据。以下代码显示如何调用wcf服务及如何将数据转为json类型。
wcf服务发布后的地址如:http://localhost:3721/service/IsAuth

需要添加的引用如下:

var xpath = require('xpath.js');
var dom = require('xmldom').DOMParser;

声明代理及拼接要发送的数据:

var BasicHttpBinding = require('wcf.js').BasicHttpBinding,
Proxy = require('wcf.js').Proxy,
binding = new BasicHttpBinding(),
proxy = new Proxy(binding, 'http://localhost:3721/service'),
message = "<Envelope xmlns='http://schemas.xmlsoap.org/soap/envelope/'>" +
"<Header />" +
"<Body>" +
"<LoginVer xmlns='http://tempuri.org/'>" +
"<name>admin</name><pwd>123456</pwd>"+//成对的参数
"</LoginVer>" +
"</Body>" +
"</Envelope>";

发送数据,并根据不同的返回类型转换数据为json:

proxy.send(message, "http://tempuri.org/service/IsAuth", function (response, ctx) {
if (ctx && ctx.error) {
callback(ctx.error, '');
return;
} if(response.indexOf('s:Envelope')>0) {
if (response.indexOf('xs:schema') > 0) {
//返回数据为Table
var start = response.indexOf('<DocumentElement');
var end = response.indexOf('</DocumentElement>');
if(start == -1){
callback(null,{table:[]});
}else{
var datas = response.slice(start, end + 18);
converttabletojson(datas, function (err, data) {
callback(err, data);
});
}
}
else{
//返回数据为List
var start = response.indexOf('<' + method + 'Result');
var end = response.indexOf('</' + method + 'Response');
if(end == -1){
callback(null,{list:[]});
}else{
var datas = response.slice(start, end);
convertlisttojson(datas, method + 'Result', function (err, data) {
callback(err, data);
});
}
}
}
else{
callback(new Error('404,Not Found Page'));
} });

返回数据为Table时,将Table转为json方法:

function converttabletojson(table, callback) {
try {
var doc = new dom().parseFromString(table), jsonr = [];
var nodes = xpath(doc, '/DocumentElement/*');
nodes.forEach(function (item) {
var row = {};
var childs = item.childNodes;
for (var key in childs) {
if (childs[key].localName) {
var name = childs[key].localName;
var value = childs[key].firstChild != null ? childs[key].firstChild.data : ' ';
row[name] = value;
}
};
jsonr.push(row);
});
doc = null;
nodes = null;
callback(null, {table: jsonr});
} catch (err) {
doc = null;
nodes = null;
callback(err);
}
};

返回数据为List时,将List转为json方法:

function convertlisttojson(lists,root, callback) {
try {
var doc = new dom().parseFromString(lists), jsonr = {};
var childdoc = doc.childNodes[0].childNodes;
for(var i =0;i<childdoc.length;i++){
var rows = [];
if(!childdoc[i].firstChild){
if(typeof childdoc[i].data === 'string'){
jsonr['mydata'] = jsonr['mydata'] || [];
jsonr['mydata'].push(childdoc[i].data);
}
continue;
}else if(typeof childdoc[i].firstChild.data === 'string'){
jsonr['mydata'] = jsonr['mydata'] || [];
jsonr['mydata'].push(childdoc[i].firstChild.data );
continue;
}
var lsttagname = childdoc[i].firstChild.tagName,
lstname = lsttagname.substr(lsttagname.indexOf(':')+1);
if(lstname){
var lsts = childdoc[i].getElementsByTagName(lsttagname);
for(var j =0;j<lsts.length;j++){
var item = lsts[j];
var childs = item.childNodes, row={};
for(var key in childs){
if(childs[key].localName) {
var name = childs[key].localName;
var value = childs[key].firstChild.data;
row[name] = value;
}
};
rows.push(row);
}
jsonr[lstname] = rows;
}
}
doc = null;nodes =null;
callback(null,{list:[jsonr]});
}catch(err){
doc = null;nodes =null;
callback(err);
}
};

以上两个方法是根据wcf返回不同的数据类型做相应的判断。以下是返回两种类型的数据的示例:

List:

<s:Envelope xmlns:s="http://schemas.xmlsoap.org/soap/envelope/">
<s:Body>
<IsAuthResponse xmlns="http://tempuri.org/">
<IsAuthResult>yes</IsAuthResult>
</IsAuthResponse>
</s:Body>
</s:Envelope>

Table:

<s:Envelope xmlns:s="http://schemas.xmlsoap.org/soap/envelope/">
<s:Body>
<GetDataResponse xmlns="http://tempuri.org/">
<GetDataResult xmlns:a="http://schemas.datacontract.org/2004/07/Model" xmlns:i="http://www.w3.org/2001/XMLSchema-instance">
<a:scoreValue>
<a:ScoreValue><a:name>语文</a:name> <a:value>90</a:value> </a:ScoreValue>
<a:ScoreValue><a:name>数学</a:name><a:value>92</a:value></a:ScoreValue>
<a:ScoreValue><a:name>英语</a:name><a:value>83</a:value></a:ScoreValue>
</a:scoreValue>
</GetDataResult>
</GetDataResponse>
</s:Body>
</s:Envelope>

在 Node.js 上调用 WCF Web 服务的更多相关文章

  1. WCF:为 SharePoint 2010 Business Connectivity Services 构建 WCF Web 服务(第 1 部分,共 4 部分)

    转:http://msdn.microsoft.com/zh-cn/library/gg318615.aspx 摘要:通过此系列文章(共四部分)了解如何在 Microsoft SharePoint F ...

  2. JAVA与.NET的相互调用——通过Web服务实现相互调用

    JAVA与.NET是现今世界竞争激烈的两大开发媒体,两者语言有很多相似的地方.而在很多大型的开发项目里面,往往需要使用两种语言进行集成开发.而很多的开发人员都会偏向于其中一种语言,在使用集成开发的时候 ...

  3. node.js之十大Web框架

    之前接触过Node.js是因为好奇大前端越来越能干了,连我后台的饭碗都要抢了,太嚣张了,于是我想打压打压它,然后就这样接触它了.再到后来是因为Settings-Sync插件二次开发,我需要用node. ...

  4. 风尘浪子 只要肯努力,梦想总有一天会实现 WF工作流与Web服务的相互调用 —— 通过Web服务调用Workflow工作流(开发持久化工作流) _转

    如果你曾经负责开发企业ERP系统或者OA系统,工作流对你来说一定并不陌生.工作流(Workflow)是对工作流程及其各操作步骤之间业务规则 的抽象.概括.描述.工作流要解决的主要问题是:为实现某个业务 ...

  5. Koa--基于Node.js平台的下一代web开发框架的安装

    koa 是由 Express 原班人马打造的,致力于成为一个更小.更富有表现力.更健壮的 Web 框架. 使用 koa 编写 web 应用,通过组合不同的 generator,可以免除重复繁琐的回调函 ...

  6. Node.js 从零开发 web server博客项目[express重构博客项目]

    web server博客项目 Node.js 从零开发 web server博客项目[项目介绍] Node.js 从零开发 web server博客项目[接口] Node.js 从零开发 web se ...

  7. node.js中ws模块创建服务端和客户端,网页WebSocket客户端

    首先下载websocket模块,命令行输入 npm install ws 1.node.js中ws模块创建服务端 // 加载node上websocket模块 ws; var ws = require( ...

  8. Node.js结合Selenium做Web自动化测试

    发现腾讯课堂上有个node.js结合Selenium做Web自动化测试的教学视频, 听来感觉不错,一来老师讲的还不错,二来node.js这门语言会越来越热,学会总没什么坏处,三来发现CukeTest这 ...

  9. node创建一个简单的web服务

    本文将如何用node创建一个简单的web服务,过程也很简单呢~ 开始之前要先安装node.js 1.创建一个最简单的服务 // server.js const http = require('http ...

随机推荐

  1. 【IOS笔记】About Events in iOS

    About Events in iOS Users manipulate their iOS devices in a number of ways, such as touching the scr ...

  2. overloading

    Computer Science An Overview _J. Glenn Brookshear _11th Edition_C Many programming languages allow t ...

  3. ASP.NET WebForm与ASP.NET MVC的不同点

    ASP.NET WebForm ASP.NET MVC ASP.NET Web Form 遵循传统的事件驱动开发模型 ASP.NET MVC是轻量级的遵循MVC模式的请求处理响应的基本开发模型 ASP ...

  4. 【Android测试】【随笔】搜狗、腾讯技术交流会心得

    ◆版权声明:本文出自胖喵~的博客,转载必须注明出处. 转载请注明出处:http://www.cnblogs.com/by-dream/p/5048525.html 今天没上班,一大早就起来赶去搜狐网络 ...

  5. TP自带的缓存机制

    原文章出处: http://blog.163.com/liwei1987821@126/blog/static/172664928201422133218356/ 动态缓存  Cache缓存类 vie ...

  6. 新的开始--Python

    第一周——python基础 1.Python简介 1.1Python简史 1.2安装Python 1.3“hello world” 在运行第一个程序“hello world”之前,先来看看运行Pyth ...

  7. [Stanford 2011] MVC introduction

    以下是课程笔记,仅供以后复习之便. 1.什么是MVC? (1) Model:如飞机激战的游戏中,太空中的飞船,什么机型,每个飞船有多少机枪,多少护甲,这些硬件组成是model. (2)Controll ...

  8. Codeforces Round #367 (Div. 2)---水题 | dp | 01字典树

    A.Beru-taxi 水题:有一个人站在(sx,sy)的位置,有n辆出租车,正向这个人匀速赶来,每个出租车的位置是(xi, yi) 速度是 Vi;求人最少需要等的时间: 单间循环即可: #inclu ...

  9. 【转】Java魔法堂:String.format详解

    Java魔法堂:String.format详解     目录     一.前言    二.重载方法     三.占位符     四.对字符.字符串进行格式化     五.对整数进行格式化     六. ...

  10. python 递归

    学习python,正好用一个例子练习一下递归. 参考文档: http://www.runoob.com/python/python-exercise-example18.html 题目:求s=a+aa ...