微信公众平台开发:高级篇(利用公众平台模拟登录发送微信消息给指定用户)

看到微信公众平台,开始有点兴奋,能做个机器人玩玩,随后用Node.js写了一个,觉得其实这没什么意思,很快就觉得腻了,于是有了做发送微信接口的想法。首先要做的我们就要模拟公众平台的登陆。对于微信的这些lib,当然不能直接写在routes里面,那要怎么办呢?没错,就要封装起来,方便复用。

你可以打开控制台看到公众平台的登录请求,还有所需的参数,其中密码它是用它本身的md5进行加密的,那么我们需要做的只是将它copy过来放在一个 helpers/wx/md5.js文件里就可以直接用了,以下是微信公众平台解析后格式化的js提交代码:

  
  
  
  
  1. submit: function() { 
  2.       if (!n()) return
  3.         var e = d.getVal(); 
  4.          t.post("/cgi-bin/login?lang=zh_CN", { 
  5.             username: e.account, 
  6.             pwd1: t.md5(e.password.substr(0, 15)), 
  7.             pwd2: t.md5(e.password), 
  8.             imgcode: f.data("isHide") ? "": e.verify, 
  9.             register: e.isRegister, 
  10.             f: "json" 
  11.          }, 

我们要建立一个login的方法:

  
  
  
  
  1. request = require 'superagent' 
  2. require __basename + '/helpers/wx/md5' 
  3. config = require __basename + '/config/config' 
  4. module.exports =  
  5.   login: (fn) -> 
  6.     wx_usr = config.wx.user 
  7.     wx_pwd = md5 config.wx.pwd.substr(0, 16) 
  8.     request 
  9.       .post('http://mp.weixin.qq.com/cgi-bin/login?lang=zh_CN'
  10.       .type('form'
  11.       .send( 
  12.         username: wx_usr 
  13.         pwd: wx_pwd 
  14.         imgcode : '' 
  15.         f : 'json' 
  16.         register : 0 
  17.       ) 
  18.       .end (res) -> 
  19.           //在这里你已经成功获取cookie了 

但是经过分析我想你会发现,这里的cookie其实并非你想要的cookie,因为它包含一些没用的信息Path=,我们设置cookie的时候,事实上 是不能用直接设置这样的cookie,应该是一个cookie里面不应该有其他的东西,而分号后面的path应该将它去掉,这里是返回的结果:

  
  
  
  
  1. "mp_user=xxxxxx; Path=/"
  2. "mp_sid=NlJ2Tm5hb1NXRGxOU3V1MzF2a25tSFVWRHhTNkhwek1nMXlEOVZzMnZMUG1lZ29nSkdENGt3WlgwUjBJZnhydndYNkZSd0ZsaHRHdEozSHBIa3QwT3FWTmdXc3RxVFhYUDBCR3dnWkxIRWVvRlZObG15UC83SzU1aEZPZWpocU8=; Path=/" 

以下是完整的login代码:

  
  
  
  
  1. login: (fn) -> 
  2.     wx_usr = config.wx.user 
  3.     wx_pwd = md5 config.wx.pwd 
  4.     request 
  5.       .post('http://mp.weixin.qq.com/cgi-bin/login?lang=zh_CN'
  6.       .type('form'
  7.       .send( 
  8.         username: wx_usr 
  9.         pwd1: wx_pwd 
  10.         pwd2: wx_pwd 
  11.         imgcode : '' 
  12.         f : 'json' 
  13.       ) 
  14.       .end (res) -> 
  15.         cookie = '' 
  16.         for rs in res.header['set-cookie'
  17.           cookie += rs.replace(/Path=\//g, '') 
  18.         fn null, cookie 

在这里,我们已经完成登录的操作了,接下来,我们要做的是进行发送,在发送的时候,要把这个cookie设置在请求的地址中,接下来的代码比较简单:

  
  
  
  
  1. sender: (options, fn) -> 
  2.     msg = options.msg 
  3.     fakeid = options.fakeid 
  4.  
  5.     unless msg 
  6.       fn error: 'missing msg' 
  7.       return 
  8.  
  9.     unless fakeid 
  10.       fn error: 'missing fakeid' 
  11.       return 
  12.  
  13.     psotParams = 
  14.       type: 1 
  15.       content: msg 
  16.       error: false 
  17.       tofakeid : fakeid 
  18.       ajax : 1 
  19.  
  20.     request 
  21.       .post('http://mp.weixin.qq.com/cgi-bin/singlesend?t=ajax-response&lang=zh_CN'
  22.       .type('form'
  23.       .send(psotParams) 
  24.       .set('Cookie', options.cookie) 
  25.       .end (res) -> 
  26.         fn null, JSON.parse res.text 

这里,我们已经能完全发送了,因为返回的结果是一个json,所要最好先JSON.parse一下,里面的成功判断大家可以加上,返回的接口有个叫ret的参数,0为发送成功。

  
  
  
  
  1. ret: "0"
  2. msg: "ok" 

你可能感兴趣的:(微信平台开发指南)