公众号经常有需要用到一些临时性的多媒体素材的场景,例如在使用接口特别是发送消息时,对多媒体文件、多媒体消息的获取和调用等操作,是通过MediaID来进行的。譬如实现“图”尚往来中,粉丝给公众号发送图片消息,便产生一临时素材。

因为永久素材有数量的限制,但是公众号又需要临时性使用一些素材,因而产生了临时素材。这类素材不在微信公众平台后台长期存储,所以在公众平台官网的素材管理中查询不到,但是可以通过接口对其操作。

接口操作:

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

Type: 媒体文件类型,分别有图片(image)、语音(voice)、视频(video)和缩略图(thumb)

代码:获取token的代码,请参考上一篇

# -*- coding: utf-8 -*-
# filename: media.py
from basic import Basic
import urllib.request
import requests
import json
import os
class Media(object):
    def upload(self, accessToken, filePath, mediaType):
        openFile = open(filePath, "rb")
        param = {'media': openFile}
        postUrl = "https://api.weixin.qq.com/cgi-bin/media/upload?access_token=%s&type=%s" % (accessToken, mediaType)
        r = requests.post(postUrl, files=param)
        print(r.json())
        return  r.json() # 在python中竟然直接类型是dict
     #命令行方式
# cmd='curl -F media=@%s "https://api.weixin.qq.com/cgi-bin/media/upload?access_token=%s&type=%s"' %( # filtPath,accessToken,mediaType # ) # print(os.system(cmd))
#filePath: 是自己电脑上,真实的临时素材位置.

返回的值为:可以直接拿到 media_id的值

01-20 07:33