最近把一个二十年前用VFP开发的进销存管理软件的数据库升迁到了SqlServer中,唉!这是多年前就想做的事了,一直拖到现在才做。
        然后就想着怎么用手机连接到后台的SqlServer数据库,这样随时随地都能查看报表了。想来想去好像还是做个微信小程序最简单点,但是直连数据库端口好像太不安全,也太落后了,当然小程序如何直连SqlServer也不懂,也不知道行不行,简单不简单,现在也不去研究了。
        所以就先做了个.net的webservice接口,是用WCF做的,套在数据库前端,为此还用了EF6.2跟数据库连接,EF也是早就想研究的东西了,用起来确实是比较简单方便的。
        接下来就是研究小程序怎么接到这个webservice上的问题了,在网上查了些资料,说的都比较简单,也互不相同,试了下都不行,只能自己研究了。因为连接webservice是用的http协议,就想到了以前用过的http sniffer工具,先用c#做个测试客户端连到webservice上,调通后就下了个http sniffer安装,没想到win7下装不进,wincap太老了,操作系统不支持了。又换到XP环境安装,装好后试了下,却截获不了c#客户端的信息,普通上网都能截的,不知道是什么原因。
       又上网查别的截取工具,查到个Microsoft Network Monitor,是微软自己做的,win7下也能安装,就马上下了装上了,一下就截到了信息,根据截到的信息,放到微信小程序中再去测试,试了几次还是不行,又到网上查资料,查到一篇关于小程序发送SOAP信息连接java webservice的文章,结合在一起再进行修改测试,最后成功连接并获取了正确的返回结果。
       小程序中主要代码如下:


requestWebService: function () { 
  
 
  

    var that = this//注意这里必须缓存,不然无法在回调中获取数据后进行操作 
  
 
  

    //组装请求体 
  
 
  

    var httpBody = '<s:Envelope xmlns:s=" 
   http://schemas.xmlsoap.org/soap/envelope/">'; 
  
 
  

    httpBody += '<s:Body>'; 
  
 
  

    httpBody += '<GetTestData xmlns=" 
   http://tempuri.org/"/>'; 
  
 
  

    httpBody += '</s:Body>'; 
  
 
  

    httpBody += '</s:Envelope>'; 
  
 
  

    wx.request({ 
  
 
  

    url: ' 
   http://xxx.com.cn/xxxx.test.Service/xxxxtestservice.svc', 
  
 
  

    data: httpBody, //请求体 
  
 
  

    method: 'POST', // OPTIONS, GET, HEAD, POST, PUT, DELETE, TRACE, CONNECT 
  
 
  

    header: { 
  
 
  

    //'content-type': 'application/json' // 默认值 
  
 
  

    //'content-type': 'application/x-www-form-urlencoded' 
  
 
  

    'content-type': 'text/xml; charset=utf-8', 
  
 
  

    'SOAPAction': ' 
   http://tempuri.org/IxxxxtestService/GetTestData' 
  
 
  

    }, // 设置请求的 header 
  
 
  

    success: function (res) { 
  
 
  

    // success 
  
 
  

    var Parser = require('../../lib/xmldom/dom-parser.js'); 
  
 
  

    var XMLParser = new Parser.DOMParser(); 
  
 
  

    var doc = XMLParser.parseFromString(res.data); 
  
 
  

    var result = doc.getElementsByTagName('GetTestDataResult')[0]; 
  
 
  

    console.log(result.firstChild.nodeValue); 
  
 
  

    that.setData({ motto: result.firstChild.nodeValue })//这里是that不是this 
  
 
  

    console.log('submit success'); 
  
 
  

    }, 
  
 
  

    fail: function () { 
  
 
  

    // fail 
  
 
  

    console.log('submit fail'); 
  
 
  

    }, 
  
 
  

    complete: function () { 
  
 
  

    // complete 
  
 
  

    console.log('submit complete'); 
  
 
  

    } 
  
 
  

    }) 
  
 
  

    }

这里关键是发送了一个http协议的request的头信息和一个SOAP协议的data数据请求体信息。


因为返回的是XML格式的信息,为了获得其中需要的信息,又查资料用到了一个xmldom的第三方库来解析XML格式信息。


这个问题终于解决了,因为是测试,所以返回结果是一段字符串,比较简单,如果返回一个包含具体数据的对象,还要对XML数据进一步进行加工提取。


还有关于request发送的网址要加入小程序的合法域名的问题,要在开发工具中点“测试号”,在微信平台上设置添加一下的。


最后就是发布小程序的问题,好像还挺麻烦的,以后再说吧。