你绝对在朋友群看到过类似这样的图片信息:
![13aaabad6b6be6e20efacfaddce32afc.png](https://i-blog.csdnimg.cn/blog_migrate/086076ae8ad6d6958854ba0dbae9401d.jpeg)
虽然大家都知道是假的,但就是爱玩,同时也给公众号引来了大量粉丝。
对于公众号,有时我们会需要返回图片,那么今天就说说怎么成功的返回图片呢?
主要流程
获取图片
图片处理,上传
返回图片
首先我们需要获取图片的信息,通过@robot.image获取用户图片信息
# 用户发送图片
@robot.image
def blog(message,session
print(dir(message))
print(message.__dict__)
print("msg", message.img)
得到对象如下信息:
['CreateTime', 'FromUserName', 'MediaId', 'MsgId', 'PicUrl', 'ToUserName', '__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__type__', '__weakref__', 'img', 'message_id', 'raw', 'source', 'target', 'time', 'type']
{
'ToUserName': 'gh_72f2cf8857a1',
'FromUserName': 'oEWaj1d4khbGJUBHYkfrsRTfbWqU',
'CreateTime': '1578290226',
'PicUrl': 'http://mmbiz.qpic.cn/mmbiz_jpg/CiaKibhL0RTDu7dt3bSBqvUMpBZMLpMBibmIO92Hib4WtFpKiaPglxG3hORsyvC8O77mvYpvkXGpGYZgIv9ytNgNbaQ/0',
'MsgId': '22595681571926635',
'MediaId': 'MyOlf_g36MPm7xRiMCiLLOXr3wcq0Iegbaq5S11PDx9R62Nug1G0lsZytAWw5D1b',
'raw': b '<xml><ToUserName><![CDATA[gh_72f2cf8857a1]]></ToUserName>n<FromUserName><![CDATA[oEWaj1d4khbGJUBHYkfrsRTfbWqU]]></FromUserName>n<CreateTime>1578290226</CreateTime>n<MsgType><![CDATA[image]]></MsgType>n<PicUrl><![CDATA[http://mmbiz.qpic.cn/mmbiz_jpg/CiaKibhL0RTDu7dt3bSBqvUMpBZMLpMBibmIO92Hib4WtFpKiaPglxG3hORsyvC8O77mvYpvkXGpGYZgIv9ytNgNbaQ/0]]></PicUrl>n<MsgId>22595681571926635</MsgId>n<MediaId><![CDATA[MyOlf_g36MPm7xRiMCiLLOXr3wcq0Iegbaq5S11PDx9R62Nug1G0lsZytAWw5D1b]]></MediaId>n</xml>',
'type': 'image'
}
msg http://mmbiz.qpic.cn/mmbiz_jpg/CiaKibhL0RTDu7dt3bSBqvUMpBZMLpMBibmIO92Hib4WtFpKiaPglxG3hORsyvC8O77mvYpvkXGpGYZgIv9ytNgNbaQ/0
可以知道发送者,接收者 发送内容的类型 创建时间、以及交互ID等
我们关心的是图片的下载路径:message.img
获取图片
通过图片路径下载图片:
def request_download(img_url, img_save_path):
import requests
r = requests.get(img_url)
with open(img_save_path, 'wb') as f:
f.write(r.content)
图片处理及上传
图片处理:这里自己想怎么处理就怎么处理吧,用Python给头像加上圣诞帽或圣诞老人小图标
图片上传:
上传临时素材接口,获取临时图片的media_id返回图片。
通过调用官方的上传临时素材接口(我这里图片只做临时返回处理,没必要永久保存)
![e8a22fd44b6cfaef09267802b65fdc2b.png](https://i-blog.csdnimg.cn/blog_migrate/0be97068e7a9a45af18e8d8a2090162b.jpeg)
token值是有时效性,官方建议不要每次使用都重新获取(后面会放缓存)
def get_access_token(appid, secret):
'''获取access_token,100分钟刷新一次'''
url = 'https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={}&secret={}'.format(appid, secret)
r = requests.get(url)
parse_json = json.loads(r.content.decode())
token = parse_json['access_token']
return token
def img_upload(mediaType, name):
token = get_access_token(app_id, secret)
url = "https://api.weixin.qq.com/cgi-bin/media/upload?access_token=%s&type=%s" % (token, mediaType)
files = {'media': open('{}'.format(name), 'rb')}
r = requests.post(url, files=files)
parse_json = json.loads(r.content.decode())
return parse_json['media_id']
返回图片
reply = ImageReply(media_id=media_id, message=message)
return reply
这样一个完整的图片获取,下载、处理、上传、返回就完成了。
# 用户发送图片
@robot.image
def blog(message,session):
changdu = str(len(session))
print("changdu", session)
# 保证图片名称唯一
uuid = create_uuid()
img_url = message.img
img_path = "./Christmas_Hat/Image/" + uuid + ".png"
img_outPath = "./Christmas_Hat/Image/out" + uuid + ".png"
# print("msg", message.img)
# print(dir(message)) # 获取对象所有属性
# print(message.__dict__)
# print("n"+message.MediaId)
# 下载图片
request_download(img_url, img_path)
# 图片处理
add_hat(img_path, img_outPath)
# 上传至服务器
media_id = img_upload("image", img_outPath)
# message.MediaId = media_id
# 返回信息
reply = ImageReply(media_id=media_id, message=message)
return reply
![07f2e5ec47552dd59a8441cbd85913d6.png](https://i-blog.csdnimg.cn/blog_migrate/75941c6cfad7df5dd11d4ec926251bba.jpeg)
精彩推荐
Python微信公众号后台开发教程<001>--搭建基础服务器
Python微信公众号后台开发<002>-被关注回复、关键词回复、收到消息回复
Python微信公众号后台开发<003>:自定义菜单
![5ef96757535c8bc21a9001a99e0677c9.png](https://i-blog.csdnimg.cn/blog_migrate/8a2c381051c088282f054934402da6e3.jpeg)