在 Node.js 上调用 WCF Web 服务
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 服务的更多相关文章
- WCF:为 SharePoint 2010 Business Connectivity Services 构建 WCF Web 服务(第 1 部分,共 4 部分)
转:http://msdn.microsoft.com/zh-cn/library/gg318615.aspx 摘要:通过此系列文章(共四部分)了解如何在 Microsoft SharePoint F ...
- JAVA与.NET的相互调用——通过Web服务实现相互调用
JAVA与.NET是现今世界竞争激烈的两大开发媒体,两者语言有很多相似的地方.而在很多大型的开发项目里面,往往需要使用两种语言进行集成开发.而很多的开发人员都会偏向于其中一种语言,在使用集成开发的时候 ...
- node.js之十大Web框架
之前接触过Node.js是因为好奇大前端越来越能干了,连我后台的饭碗都要抢了,太嚣张了,于是我想打压打压它,然后就这样接触它了.再到后来是因为Settings-Sync插件二次开发,我需要用node. ...
- 风尘浪子 只要肯努力,梦想总有一天会实现 WF工作流与Web服务的相互调用 —— 通过Web服务调用Workflow工作流(开发持久化工作流) _转
如果你曾经负责开发企业ERP系统或者OA系统,工作流对你来说一定并不陌生.工作流(Workflow)是对工作流程及其各操作步骤之间业务规则 的抽象.概括.描述.工作流要解决的主要问题是:为实现某个业务 ...
- Koa--基于Node.js平台的下一代web开发框架的安装
koa 是由 Express 原班人马打造的,致力于成为一个更小.更富有表现力.更健壮的 Web 框架. 使用 koa 编写 web 应用,通过组合不同的 generator,可以免除重复繁琐的回调函 ...
- Node.js 从零开发 web server博客项目[express重构博客项目]
web server博客项目 Node.js 从零开发 web server博客项目[项目介绍] Node.js 从零开发 web server博客项目[接口] Node.js 从零开发 web se ...
- node.js中ws模块创建服务端和客户端,网页WebSocket客户端
首先下载websocket模块,命令行输入 npm install ws 1.node.js中ws模块创建服务端 // 加载node上websocket模块 ws; var ws = require( ...
- Node.js结合Selenium做Web自动化测试
发现腾讯课堂上有个node.js结合Selenium做Web自动化测试的教学视频, 听来感觉不错,一来老师讲的还不错,二来node.js这门语言会越来越热,学会总没什么坏处,三来发现CukeTest这 ...
- node创建一个简单的web服务
本文将如何用node创建一个简单的web服务,过程也很简单呢~ 开始之前要先安装node.js 1.创建一个最简单的服务 // server.js const http = require('http ...
随机推荐
- PHP 常用函数库和一些实用小技巧
PHP 常用函数库和一些实用小技巧 作者: 字体:[增加 减小] 类型:转载 包括文件读取函式,文件写入函式,静态页面生成函式,目录删除函式等 文件读取函式 //文件读取函式 function ...
- RT-Thread的CPU使用率计算
CPU 的使用率一般是我们比较关心的问题,在这里我们就用空闲线程的钩子函数去统计 CPU 的使用率,并通过串口打印出来.首先我们在初始化线程中设置好钩子函数,并在 LED 线程中给系统人为的加入很多“ ...
- TeamViewer“试用期已到期”解决方法
今天打开TeamViewer,显示试用期已到期,不能远程至其它电脑上.软件重装也没用,因为它与你的机器及网卡做了绑定. 查看网上资料,发现需要删除注册信息等操作才能继续使用,步骤如下: 说明:操作前, ...
- jquery()的三种$()
jQuery中的$以及选择器总结 $号是jQuery”类”的一个别称,$()构造了一个jQuery对象.所以,”$()”可以看作jQuery的”构造函数”(个人观点). 一.$符号 1.$()可以是$ ...
- android studio 编程中用到的快捷键
1.Ctrl+Alt+T可以把代码包在一块内,例如try/catch Version:0.9 StartHTML:-1 EndHTML:-1 StartFragment:0000000111 EndF ...
- [Virtualization][SDN] 讲的很好的SDN软件定义网络视频课程
51CTO的免费课程,开始以为是扯蛋的,后来看了一下,讲的很好.注册一下,免费的. 只看了导论,挺好的. http://edu.51cto.com/course/course_id-4466.html
- ubuntu下安装与卸载qt的方法
http://blog.csdn.net/huyisu/article/details/24014407 ubuntu下安装与卸载qt的方法 分类: linux 2014-04-18 14:20 18 ...
- 前端 JSer 装逼手册
阅读 8143收藏 2352016-7-18 SegmentFault 分享:吉祥物 @ SegmentFault 在装逼成本越来越高的 JS 圈,是时候充值一下了 -- 题记. 作者:kenberk ...
- WGZX:javaScript 学习心得--2
转贴javascript心得(二) 标签: javascriptajaxweb开发htmlfirefox框架 2008-09-11 10:56 636人阅读 评论(0) 收藏 举报 分类: UI(2 ...
- JS 去字符串空格 总结
str为要去除空格的字符串: 去除所有空格: str = str.replace(/\s+/g,""); 去除两头空格: str = str.replace(/^\s+|\s+$/ ...