文学起点网
当前位置: 首页 文学百科

微信公众号原创分享样式(微信公众号开发之新增临时素材)

时间:2023-06-14 作者: 小编 阅读量: 1 栏目名: 文学百科

微信公众号开发之新增临时素材一、新增临时素材公众号经常有需要用到一些临时性的多媒体素材的场景,例如在使用接口特别是发送消息时,对多媒体文件、多媒体消息的获取和调用等操作,是通过media_id来进行的素材管理接口对所有认证的订阅。

一、新增临时素材

公众号经常有需要用到一些临时性的多媒体素材的场景,例如在使用接口特别是发送消息时,对多媒体文件、多媒体消息的获取和调用等操作,是通过media_id来进行的。素材管理接口对所有认证的订阅号和服务号开放。通过本接口,公众号可以新增临时素材(即上传临时多媒体文件)。

注意点:

1、临时素材media_id是可复用的。

2、媒体文件在微信后台保存时间为3天,即3天后media_id失效。

3、上传临时素材的格式、大小限制与公众平台官网一致。

图片(image): 2M,支持PNG\JPEG\JPG\GIF格式

语音(voice):2M,播放长度不超过60s,支持AMR\MP3格式

视频(video):10MB,支持MP4格式

缩略图(thumb):64KB,支持JPG格式

4、需使用https调用本接口。

接口调用请求说明

http请求方式:POST/FORM,使用https https://api.weixin.qq.com/cgi-bin/media/upload?access_token=ACCESS_TOKEN&type=TYPE 调用示例(使用curl命令,用FORM表单方式上传一个多媒体文件): curl -F media=@test.jpg "https://api.weixin.qq.com/cgi-bin/media/upload?access_token=ACCESS_TOKEN&type=TYPE"

参数说明

参数是否必须说明access_token是调用接口凭证type是媒体文件类型,分别有图片(image)、语音(voice)、视频(video)和缩略图(thumb)media是form-data中媒体文件标识,有filename、filelength、content-type等信息

返回说明

正确情况下的返回JSON数据包结果如下:

{"type":"TYPE","media_id":"MEDIA_ID","created_at":123456789}

参数描述type媒体文件类型,分别有图片(image)、语音(voice)、视频(video)和缩略图(thumb,主要用于视频与音乐格式的缩略图)media_id媒体文件上传后,获取标识created_at媒体文件上传时间戳

错误情况下的返回JSON数据包示例如下(示例为无效媒体类型错误):

{"errcode":40004,"errmsg":"invalid media type"}

根据上面的接口,我们定义了一个上传临时素材的方法,包含文件目录和文件类型这两个参数,我们这里依然采用RestTemplate工具类进行文件上传

/*** 上传临时素菜* 1、临时素材media_id是可复用的。* 2、媒体文件在微信后台保存时间为3天,即3天后media_id失效。* 3、上传临时素材的格式、大小限制与公众平台官网一致。* @param filePath* @param type* @return*/public String uploadFile(String filePath,String type) {String accessToken = accessTokenUtil.getAccessToken();if (accessToken != null) {String url = URIConstant.MEDIA_UPLOAD_URL.replace("ACCESS_TOKEN", accessToken).replace("TYPE", type);log.info("MEDIA_UPLOAD_URL:{}",url);//设置请求体,注意是LinkedMultiValueMapMultiValueMap<String, Object> form = new LinkedMultiValueMap<>();FileSystemResource fileSystemResource = new FileSystemResource(filePath);form.add("media", fileSystemResource);//设置请求头HttpHeaders headers = new HttpHeaders();headers.setContentType(MediaType.MULTIPART_FORM_DATA);//用HttpEntity封装整个请求报文HttpEntity<MultiValueMap<String, Object>> data = new HttpEntity<>(form, headers);try{//这里RestTemplate请求返回的字符串直接转换成JSONObject会报异常,后续深入找一下原因String resultString = restTemplate.postForObject(url, data, String.class);log.info("上传返回的信息是:{}",resultString);if(!StringUtils.isEmpty(resultString)){JSONObject jsonObject = JSONObject.parseObject(resultString);return jsonObject.getString("media_id");}}catch (Exception e){log.error(e.getMessage());}}return null;}

我们在swagger中新建一个Controller用以提交我们的上传请求,并测试我们的代码是否正确

@ApiOperation(value = "上传临时素材")@RequestMapping(value = "/uploadFile", method = RequestMethod.POST)@ApiImplicitParams({@ApiImplicitParam(name="filePath",value="文件位置", paramType="query",dataType="String"),@ApiImplicitParam(name="type",value="媒体文件类型,分别有图片(image)、语音(voice)、视频(video)和缩略图(thumb)", paramType="query",dataType="String"),})public Object upload(String filePath, String type) throws Exception{String result = uploadUtil.uploadFile(filePath,type);return result;}

启动我们的项目,在swagger中输入一个有效的文件路径(这里假如是图片类型),type设置为image

可以看到,我们成功上传了临时文件,并获取到了该文件的media_id(这个后续很重要!!!)

二、获取临时素材

临时素材主要分为三类(图片、音频,视频),图片和音频文件支持下载到本地,视频文件支持获取视频的URL地址

(1)获取临时图片

/*** 公众号可以使用本接口获取临时素材(即下载临时的多媒体文件)* 1、如果是图片,则下载图片*/public ResponseEntity<byte[]> getImage(String mediaId){String accessToken = accessTokenUtil.getAccessToken();if(accessToken != null) {String url = URIConstant.MEDIA_GET_URL.replace("ACCESS_TOKEN", accessToken).replace("MEDIA_ID", mediaId);log.info("MEDIA_GET_URL:{}", url);String fileName = mediaId".jpg";HttpHeaders headers = new HttpHeaders();try {fileName = new String(fileName.getBytes("GBK"), "ISO-8859-1");} catch (UnsupportedEncodingException e) {e.printStackTrace();}headers.setContentDispositionFormData("attachment", fileName);// 文件名称ResponseEntity<byte[]> responseEntity = restTemplate.exchange(url, HttpMethod.GET, new HttpEntity<>(headers), byte[].class);return responseEntity;}return null;}

(2)获取临时音频

/*** 公众号可以使用本接口获取临时素材(即下载临时的多媒体文件)* 1、如果是声音,则下载声音*/public ResponseEntity<byte[]> getVoice(String mediaId){String accessToken = accessTokenUtil.getAccessToken();if(accessToken != null) {String url = URIConstant.MEDIA_GET_URL.replace("ACCESS_TOKEN", accessToken).replace("MEDIA_ID", mediaId);log.info("MEDIA_GET_URL:{}", url);String fileName = mediaId".speex";HttpHeaders headers = new HttpHeaders();try {fileName = new String(fileName.getBytes("GBK"), "ISO-8859-1");} catch (UnsupportedEncodingException e) {e.printStackTrace();}headers.setContentDispositionFormData("attachment", fileName);// 文件名称ResponseEntity<byte[]> responseEntity = restTemplate.exchange(url, HttpMethod.GET, new HttpEntity<>(headers), byte[].class);return responseEntity;}return null;}

(3)获取视频素材地址

/*** 公众号可以使用本接口获取临时素材(即下载临时的多媒体文件)* 2、如果是视频,则返回视频的地址*/public String getVedio(String mediaId){String accessToken = accessTokenUtil.getAccessToken();if(accessToken != null) {String url = URIConstant.MEDIA_GET_URL.replace("ACCESS_TOKEN", accessToken).replace("MEDIA_ID", mediaId);log.info("MEDIA_GET_URL:{}", url);String responseString = restTemplate.getForObject(url,String.class);return responseString;}return null;}

三、测试

这里我们仅以上传临时图片素材并下载临时图片素材为例,我们在我们的Controller中新增一个根据media_id获取临时图片类型素材的方法

我们把我们刚才上传临时素材成功返回的media_id传给我们的方法

可以看到我们的swagger返回带有Download file的超级链接,点击即可下载我们的图片,当然我们可以直接在浏览器直接输入我们的完整请求地址

package com.xu.wemall.components.weixin;import com.alibaba.fastjson.JSONObject;import com.xu.wemall.commons.constants.URIConstant;import lombok.extern.slf4j.Slf4j;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.core.io.FileSystemResource;import org.springframework.http.*;import org.springframework.stereotype.Component;import org.springframework.util.LinkedMultiValueMap;import org.springframework.util.MultiValueMap;import org.springframework.util.StringUtils;import org.springframework.web.client.RestTemplate;import java.io.UnsupportedEncodingException;/** * 功能:临时素材工具类 */@Slf4j@Componentpublic class UploadUtil {@Autowiredprivate RestTemplate restTemplate;@Autowiredprivate AccessTokenUtil accessTokenUtil;/*** 上传临时素菜* 1、临时素材media_id是可复用的。* 2、媒体文件在微信后台保存时间为3天,即3天后media_id失效。* 3、上传临时素材的格式、大小限制与公众平台官网一致。* @param filePath* @param type* @return*/public String uploadFile(String filePath,String type) {String accessToken = accessTokenUtil.getAccessToken();if (accessToken != null) {String url = URIConstant.MEDIA_UPLOAD_URL.replace("ACCESS_TOKEN", accessToken).replace("TYPE", type);log.info("MEDIA_UPLOAD_URL:{}",url);//设置请求体,注意是LinkedMultiValueMapMultiValueMap<String, Object> form = new LinkedMultiValueMap<>();FileSystemResource fileSystemResource = new FileSystemResource(filePath);form.add("media", fileSystemResource);//设置请求头HttpHeaders headers = new HttpHeaders();headers.setContentType(MediaType.MULTIPART_FORM_DATA);//用HttpEntity封装整个请求报文HttpEntity<MultiValueMap<String, Object>> data = new HttpEntity<>(form, headers);try{//这里RestTemplate请求返回的字符串直接转换成JSONObject会报异常,后续深入找一下原因String resultString = restTemplate.postForObject(url, data, String.class);log.info("上传返回的信息是:{}",resultString);if(!StringUtils.isEmpty(resultString)){JSONObject jsonObject = JSONObject.parseObject(resultString);return jsonObject.getString("media_id");}}catch (Exception e){log.error(e.getMessage());}}return null;}/*** 公众号可以使用本接口获取临时素材(即下载临时的多媒体文件)* 1、如果是图片,则下载图片*/public ResponseEntity<byte[]> getImage(String mediaId){String accessToken = accessTokenUtil.getAccessToken();if(accessToken != null) {String url = URIConstant.MEDIA_GET_URL.replace("ACCESS_TOKEN", accessToken).replace("MEDIA_ID", mediaId);log.info("MEDIA_GET_URL:{}", url);String fileName = mediaId".jpg";HttpHeaders headers = new HttpHeaders();try {fileName = new String(fileName.getBytes("GBK"), "ISO-8859-1");} catch (UnsupportedEncodingException e) {e.printStackTrace();}headers.setContentDispositionFormData("attachment", fileName);// 文件名称ResponseEntity<byte[]> responseEntity = restTemplate.exchange(url, HttpMethod.GET, new HttpEntity<>(headers), byte[].class);return responseEntity;}return null;}/*** 公众号可以使用本接口获取临时素材(即下载临时的多媒体文件)* 1、如果是声音,则下载声音*/public ResponseEntity<byte[]> getVoice(String mediaId){String accessToken = accessTokenUtil.getAccessToken();if(accessToken != null) {String url = URIConstant.MEDIA_GET_URL.replace("ACCESS_TOKEN", accessToken).replace("MEDIA_ID", mediaId);log.info("MEDIA_GET_URL:{}", url);String fileName = mediaId".speex";HttpHeaders headers = new HttpHeaders();try {fileName = new String(fileName.getBytes("GBK"), "ISO-8859-1");} catch (UnsupportedEncodingException e) {e.printStackTrace();}headers.setContentDispositionFormData("attachment", fileName);// 文件名称ResponseEntity<byte[]> responseEntity = restTemplate.exchange(url, HttpMethod.GET, new HttpEntity<>(headers), byte[].class);return responseEntity;}return null;}/*** 公众号可以使用本接口获取临时素材(即下载临时的多媒体文件)* 2、如果是视频,则返回视频的地址*/public String getVedio(String mediaId){String accessToken = accessTokenUtil.getAccessToken();if(accessToken != null) {String url = URIConstant.MEDIA_GET_URL.replace("ACCESS_TOKEN", accessToken).replace("MEDIA_ID", mediaId);log.info("MEDIA_GET_URL:{}", url);String responseString = restTemplate.getForObject(url,String.class);return responseString;}return null;}}

点击这个Download File,我们成功的下载到这个上传的临时图片

​ 试着打开这个文件,我们可以看到,这个确实是我们上传的图片

这里贴出完整的代码,自行修改以获得其他类型的临时文件,不做赘述

UploadUtil.java

package com.xu.wemall.components.weixin;import com.alibaba.fastjson.JSONObject;import com.xu.wemall.commons.constants.URIConstant;import lombok.extern.slf4j.Slf4j;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.core.io.FileSystemResource;import org.springframework.http.*;import org.springframework.stereotype.Component;import org.springframework.util.LinkedMultiValueMap;import org.springframework.util.MultiValueMap;import org.springframework.util.StringUtils;import org.springframework.web.client.RestTemplate;import java.io.UnsupportedEncodingException;/** * 功能:临时素材工具类 */@Slf4j@Componentpublic class UploadUtil {@Autowiredprivate RestTemplate restTemplate;@Autowiredprivate AccessTokenUtil accessTokenUtil;/*** 上传临时素菜* 1、临时素材media_id是可复用的。* 2、媒体文件在微信后台保存时间为3天,即3天后media_id失效。* 3、上传临时素材的格式、大小限制与公众平台官网一致。* @param filePath* @param type* @return*/public String uploadFile(String filePath,String type) {String accessToken = accessTokenUtil.getAccessToken();if (accessToken != null) {String url = URIConstant.MEDIA_UPLOAD_URL.replace("ACCESS_TOKEN", accessToken).replace("TYPE", type);log.info("MEDIA_UPLOAD_URL:{}",url);//设置请求体,注意是LinkedMultiValueMapMultiValueMap<String, Object> form = new LinkedMultiValueMap<>();FileSystemResource fileSystemResource = new FileSystemResource(filePath);form.add("media", fileSystemResource);//设置请求头HttpHeaders headers = new HttpHeaders();headers.setContentType(MediaType.MULTIPART_FORM_DATA);//用HttpEntity封装整个请求报文HttpEntity<MultiValueMap<String, Object>> data = new HttpEntity<>(form, headers);try{//这里RestTemplate请求返回的字符串直接转换成JSONObject会报异常,后续深入找一下原因String resultString = restTemplate.postForObject(url, data, String.class);log.info("上传返回的信息是:{}",resultString);if(!StringUtils.isEmpty(resultString)){JSONObject jsonObject = JSONObject.parseObject(resultString);return jsonObject.getString("media_id");}}catch (Exception e){log.error(e.getMessage());}}return null;}/*** 公众号可以使用本接口获取临时素材(即下载临时的多媒体文件)* 1、如果是图片,则下载图片*/public ResponseEntity<byte[]> getImage(String mediaId){String accessToken = accessTokenUtil.getAccessToken();if(accessToken != null) {String url = URIConstant.MEDIA_GET_URL.replace("ACCESS_TOKEN", accessToken).replace("MEDIA_ID", mediaId);log.info("MEDIA_GET_URL:{}", url);String fileName = mediaId".jpg";HttpHeaders headers = new HttpHeaders();try {fileName = new String(fileName.getBytes("GBK"), "ISO-8859-1");} catch (UnsupportedEncodingException e) {e.printStackTrace();}headers.setContentDispositionFormData("attachment", fileName);// 文件名称ResponseEntity<byte[]> responseEntity = restTemplate.exchange(url, HttpMethod.GET, new HttpEntity<>(headers), byte[].class);return responseEntity;}return null;}/*** 公众号可以使用本接口获取临时素材(即下载临时的多媒体文件)* 1、如果是声音,则下载声音*/public ResponseEntity<byte[]> getVoice(String mediaId){String accessToken = accessTokenUtil.getAccessToken();if(accessToken != null) {String url = URIConstant.MEDIA_GET_URL.replace("ACCESS_TOKEN", accessToken).replace("MEDIA_ID", mediaId);log.info("MEDIA_GET_URL:{}", url);String fileName = mediaId".speex";HttpHeaders headers = new HttpHeaders();try {fileName = new String(fileName.getBytes("GBK"), "ISO-8859-1");} catch (UnsupportedEncodingException e) {e.printStackTrace();}headers.setContentDispositionFormData("attachment", fileName);// 文件名称ResponseEntity<byte[]> responseEntity = restTemplate.exchange(url, HttpMethod.GET, new HttpEntity<>(headers), byte[].class);return responseEntity;}return null;}/*** 公众号可以使用本接口获取临时素材(即下载临时的多媒体文件)* 2、如果是视频,则返回视频的地址*/public String getVedio(String mediaId){String accessToken = accessTokenUtil.getAccessToken();if(accessToken != null) {String url = URIConstant.MEDIA_GET_URL.replace("ACCESS_TOKEN", accessToken).replace("MEDIA_ID", mediaId);log.info("MEDIA_GET_URL:{}", url);String responseString = restTemplate.getForObject(url,String.class);return responseString;}return null;}}

谢谢各位,我们下回继续再说!

    推荐阅读
  • 荷塘月色简笔画彩图(荷塘的场景图简笔画)

    今日份简笔画荷塘月色.感恩日记1.,我来为整理几张简单漂亮的荷塘月色简笔画彩图?以下简笔画图片总有一款是你喜欢的,希望对你有帮助来看看吧!荷塘月色简笔画彩图今日份简笔画荷塘月色.感恩日记1.荷塘月色好看的儿童画图片儿童简笔画大全荷塘月色简笔画儿童画

  • 直硬头发软化前后效果图(头发软化前后效果图)

    可以使头发变软,变柔顺,变贴服,且价格也很便宜,普通的美发沙龙价格为50到80元左右,软化比较自然。头发软化后几天可以洗刚做完软化2至3天不要洗头,刚做完软化不要用力拉头发,会有损发质和效果。软化也是伤头发的,不过比不停地做一次性夹头发而言小很多,如果是短发做软化还是不错的。如果想让头发蓬蓬的,最好不要全头做软化,甚至不建议做软化。具体情况,建议咨询理发师。用药水要用好一点的,对头发伤害才不会很大。

  • 赞美运动员的话(赞美运动员的话有什么)

    年轻的我们自信飞扬,青春的气息如同出生的朝阳,蓬勃的力量如同阳光的挥洒此时此刻,跑道便是我们精彩的舞台,声声加油便是我们最高的奖项论何成功,谈何荣辱,心中的信念只有一个:拼搏,我来为大家科普一下关于赞美运动员的话?赞美运动员的话年轻的我们自信飞扬,青春的气息如同出生的朝阳,蓬勃的力量如同阳光的挥洒。所有的努力都是为了迎接这一刹那,所有的拼搏都是为了这一声令下。

  • 长安uni-k车主反映这款车怎么样(新车长安UNI-K登场)

    据长安汽车最新消息,中大型SUVUNI-K官图曝光,这是长安UNI系列的第二款车型。新车将搭载蓝鲸系列2.0T发动机并匹配8AT变速箱,将于广州车展首发亮相。新车亮点1.采用了全新的“V”型面设计和无边界格栅。新车概况新车前脸依然采用无边界设计并融入了V型面概念,不同于UNI-T,UNI-K的大灯位置设计在了最上方。车尾方面采用了时下流行的贯穿式尾灯设计,与UNI-T的V型后导流造型不同,UNI-K采用了新的航天器式造型,立式尾灯十分显眼。

  • 渡劫经典语录(关于渡劫的语录精选)

    情到深处人孤独,爱至穷时尽沧桑堕落的天使啊,你无知的游走着。我将于茫茫人海中访我唯一灵魂之伴侣;得之,我幸;不得,我命。玲珑骰子安红豆,入骨相思君知否。于千万人之中遇见你所遇见的人,于千万年时间无涯的荒野里,没有早一步,也没有晚一步,刚巧赶上了。生命是一朵千瓣莲花,我拒绝了绽放的同时,我也拒绝了枯萎和零落。就算哭泣也要皱眉优雅,就算失败也要转身潇洒。之后我也学会了阳奉阴违,发生了什么与我再无所谓。

  • 孤城闭什么时候上映(谁是主演)

    以下内容大家不妨参考一二希望能帮到您!孤城闭什么时候上映《孤城闭》将于2020年起在湖南卫视上映播出。该剧主要由王凯、江疏影、任敏、杨玏、边程、叶祖新、喻恩泰、王楚然、刘钧、孙坚等主演。《孤城闭》改编自米兰lady同名小说,以北宋为背景,在风起云涌的朝堂之事与剪不断理还乱的儿女情长之间,还原了一个复杂而真实的宋仁宗。

  • 大众朗逸所有灯图解(认识汽车灯图解)

    大众朗逸所有灯图解作为新手,汽车灯光就是一道难题,下面我们一起通过图解来认识一下汽车各种灯光吧。双闪灯的作用是当车辆发生意外情况后,引起其他车辆警惕,防止发生追尾事故。当踩下制动踏板后,制动灯立即亮起,并发出红色灯光,提醒后方车辆。倒车灯是白色,作用是为了照亮车尾的路面,减少倒车时盲区,另外也是对后方的提醒。

  • 雪里红的腌制方法(做雪里红腌菜的步骤)

    下面更多详细答案一起来看看吧!雪里红的腌制方法雪里红摘干净,根部用刀劈开,正一层反一层放入盆中,取盐均匀地洒在雪里红上,腌制1-2天。烧开水放凉,加盐,搅拌均匀,盐水倒入雪里红中泡制一天。泡好的雪里红捆成一小捆放入密封罐,倒入泡雪里红的盐水,盖好密封罐,即吃即取。

  • 郑州婚纱照推荐哪家好(郑州拍婚纱照团购)

    中国红喜嫁秀爆朋友圈的婚纱照中式婚纱照新中式婚纱照婚纱照风格高级感婚纱照婚纱照秀禾服的中式嫁衣,是完美诠释了东方女性温婉古典美。让人完全移不开目光~每一个女孩子都应该拥有这样华丽的喜嫁风太精致完全属于中式婚纱照的浪漫感~

  • 胎梦最准的位置(从胎梦看看你腹中的孩子给你暗示了吗)

    估计生完孩子和正在孕期的妈妈都会经历过这种事情,就是我们会经常做梦,而且会梦见一些动物植物什么的,这在老人眼里属于“胎梦”。你梦见的什么会预示着即将出生的宝宝是男孩还是女孩。你的胎梦准不准,来看看一下别人的胎梦。哈哈,看来有些胎梦还是挺准的,或许都是巧合吧,总之,宝宝来了就是我们的命中注定。