node 开发微信公众号(三.最简单的自动回复)

推荐微信开发入门教程: https://cnodejs.org/topic/59294bff9e32cc84569a746a

先说一些微信开发的特点:
1.post请求
2.数据包是xml格式的
3.你给微信返回的数据也是xml格式的

coding吧

var parseString = require('xml2js').parseString;//引入xml2js包
/**
 * 处理微信post消息请求
 */
router.post('/', function (req, res) {
    try{
        var buffer = [];
        //监听 data 事件 用于接收数据
        req.on('data', function (data) {
            buffer.push(data);
        });
        //监听 end 事件 用于处理接收完成的数据
        req.on('end', function () {
            //输出接收完成的数据
            parseString(Buffer.concat(buffer).toString('utf-8'),{explicitArray : false},function(err,result){
                if(err){
                    //打印错误信息
                    console.log(err);
                }else{
                    //打印解析结果
                    console.log(result);
                    result = result.xml;
                    var toUser = result.ToUserName; //接收方微信
                    var fromUser = result.FromUserName;//发送仿微信
                    if(result.Event==='subscribe'){
                        //回复消息
                        var xml=this.returntext(fromUser,toUser,'欢迎关注公众号,hahhh');
                        console.log(xml)
                        res.send(xml)
                    }else{
                        var xml=this.returntext(fromUser,toUser,'您好');
                        console.log(xml)
                        res.send(xml)
                    }

                }
            })
        });
    }catch(err){
console.log(err)
    }
})
//回复文本消息
function returntext(toUser, fromUser, content){
var xmlContent =  "<xml><ToUserName><![CDATA["+ toUser +"]]></ToUserName>";
    xmlContent += "<FromUserName><![CDATA["+ fromUser +"]]></FromUserName>";
    xmlContent += "<CreateTime>"+ new Date().getTime() +"</CreateTime>";
    xmlContent += "<MsgType><![CDATA[text]]></MsgType>";
    xmlContent += "<Content><![CDATA["+ content +"]]></Content></xml>";
    return xmlContent;
}

微信开发其实就是后台开发,只是多了一些微信制定的条条框框,文档都有说明的。感觉微信开发跟写前台js一样,事件驱动。

多看文档,微信开发多看文档

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容