上一篇文章:nodejs微信公众号开发——4.自动回复各种消息,我们实现了被动回复文字和图文,回复图片失败,因为需要先获取通过素材管理接口上传多媒体文件而得到的MediaId,这一节们就来实现素材管理的接口。可参看:公众平台开发者文档
1. 新增临时素材
临时素材顾名思义是临时的,上传后一定时间就被清理掉,适用于一些有时效性的图文链接。关于临时素材需要注意的点:
- 对于临时素材,每个素材(media_id)会在开发者上传或粉丝发送到微信服务器3天后自动删除(所以用户发送给开发者的素材,若开发者需要,应尽快下载到本地),以节省服务器资源。
- media_id是可复用的。
- 素材的格式大小等要求与公众平台官网一致。具体是,图片大小不超过2M,支持bmp/png/jpeg/jpg/gif格式,语音大小不超过5M,长度不超过60秒,支持mp3/wma/wav/amr格式
- 需使用https调用本接口。
请求地址:https://api.weixin.qq.com/cgi-bin/media/upload"htmlcode">
Wechat.prototype.uploadTempMaterial = function(type,filepath){ var that = this; var form = { //构造表单 media:fs.createReadStream(filepath) } return new Promise(function(resolve,reject){ that.fetchAccessToken().then(function(data){ 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); }); }); }); }
代码中的fetchAccessToken
用以获取access_token
,修改回复数字2
的代码:
else if(content === '2'){ var data = yield wechatApi.uploadTempMaterial('image',__dirname+'/public/king.jpg'); reply = { type:'image', mediaId:data.media_id } }
先将本地的一张图片上传到临时素材接口,获取media_id,封装到回复消息里面去。同样的方法适用于语音,视频等:
2. 新增永久素材
永久素材回永远存储在微信后台服务器上,永不失效。关于永久素材有一下几个特点:
- 新增的永久素材也可以在公众平台官网素材管理模块中看到
- 永久素材的数量是有上限的,请谨慎新增。图文消息素材和图片素材的上限为5000,其他类型为1000
- 素材的格式大小等要求与公众平台官网一致。具体是,图片大小不超过2M,支持bmp/png/jpeg/jpg/gif格式,语音大小不超过5M,长度不超过60秒,支持mp3/wma/wav/amr格式
- 调用该接口需https协议
新增永久图文素材请求地址:https://api.weixin.qq.com/cgi-bin/material/add_news"htmlcode">
Wechat.prototype.uploadPermMaterial = function(type,material){ var that = this; var form = {} var uploadUrl = ''; if(type === 'pic') uploadUrl = api.uploadPermPics; if(type === 'other') uploadUrl = api.uploadPermOther; if(type === 'news'){ uploadUrl = api.uploadPermNews; form = material }else{ form.media = fs.createReadStream(material); } return new Promise(function(resolve,reject){ that.fetchAccessToken().then(function(data){ var url = uploadUrl + 'access_token=' + data.access_token; var opts = { method:'POST', url:url, json:true } (type == 'news') "htmlcode">Wechat.prototype.getMaterial = function(mediaId,permanent){ var that = this; var getUrl = permanent "htmlcode">Wechat.prototype.delMaterial = function(mediaId){ var that = this; return new Promise(function(resolve,reject){ that.fetchAccessToken().then(function(data){ var url = api.delPermMaterial + 'access_token=' + data.access_token; var form = {media_id:mediaId} request({url:url,method:'POST',formData:form,json:true}).then(function(response){ var _data = response.body; if(_data.errcode === '0'){ resolve(); }else{ throw new Error('delete permanent material failed!'); } }).catch(function(err){ reject(err); }); }); }); }5.其他
还有
修改永久图文素材
、获取素材总数
、获取素材列表
功能由于本项目中不会用到,就不一一实现了。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“详解nodejs微信公众号开发——5.素材管理接口”评论...
更新动态
2024年11月15日
2024年11月15日
- 群星-时尚慢摇DJ舞曲《发烧车载中文天碟-调情》非卖品[WAV]
- 潘美辰.2008-全新重声大碟(出道20年精选纪念版)【倍特音乐】【WAV+CUE】
- 罗时丰.2002-唱歌的人(2011再生版)【贝特音乐】【WAV+CUE】
- 罗时丰.2003-唱歌的人台语精选+新歌【贝特音乐】【WAV+CUE】
- 999PUNKSTA《情绪数码故障》[Hi-Res][24bit 48kHz][FLAC/分轨][301.83MB]
- HOYO-MiX《原神-珍珠之歌4 游戏音乐》[320K/MP3][289.48MB]
- 陈崎凡《CHEN》[320K/MP3][81.13MB]
- skt都在哪一年夺冠 英雄联盟skt夺冠赛季介绍
- 炉石传说抢先体验乱斗什么时候结束 深暗领域体验乱斗结束时间
- 炉石传说抢先乱斗卡组有什么 深暗领域抢先体验乱斗卡组推荐
- 荣耀手机腕上最佳搭档 荣耀手表5首销开启
- 雷克沙ARES 6000 C28战神之翼 AMD 9800X3D超强搭档
- 咪咕快游感恩同游,超值回馈尽在咪咕咪粉节!
- 陈崎凡《CHEN》[FLAC/分轨][326.32MB]
- 群星《我们的歌第六季 第2期》[320K/MP3][74.05MB]