详解nodejs微信公众号开发——5.素材管理接口
上一篇文章:,我们实现了被动回复文字和图文,回复图片失败,因为需要先获取通过素材管理接口上传多媒体文件而得到的MediaId,这一节们就来实现素材管理的接口。可参看:公众平台开发者文档 1. 新增临时素材临时素材顾名思义是临时的,上传后一定时间就被清理掉,适用于一些有时效性的图文链接。关于临时素材需要注意的点:
请求地址:https://api.weixin.qq.com/cgi-bin/media/upload?access_token=ACCESS_TOKEN&type=TYPE 1.1 实现uploadTempMaterial方法
var url = api.uploadMaterial + 'access_token=' + data.access_token + '&type=' + type;
request({url:url,method:'POST',formData:form,json:true}).then(function(response){
var _data = response.body;
if(_data){
resolve(_data)
}else{
throw new Error('upload material failed!');
}
}).catch(function(err){
reject(err);
});
});
}); 代码中的 先将本地的一张图片上传到临时素材接口,获取media_id,封装到回复消息里面去。同样的方法适用于语音,视频等: 2. 新增永久素材永久素材回永远存储在微信后台服务器上,永不失效。关于永久素材有一下几个特点:
新增永久图文素材请求地址:https://api.weixin.qq.com/cgi-bin/material/add_news?access_token=ACCESS_TOKEN 新增永久图片请求地址:https://api.weixin.qq.com/cgi-bin/media/uploadimg?access_token=ACCESS_TOKEN 新增其他类型永久素材请求地址:https://api.weixin.qq.com/cgi-bin/material/add_material?access_token=ACCESS_TOKEN 2.1 实现uploadPermMaterial方法
3. 获取素材链接由于获取临时素材和获取永久素材的差异性不大,直接放在一个函数里完成。 4. 删除永久素材(编辑:ASP站长网) |