[https://mp.weixin.qq.com/s?__biz=Mzg3NjgzOTQ0OA==&mid=2247483653&idx=1&sn=06a0ed970a29f7c4801b3617e3060130&chksm=cf2d5672f85adf64a04aae5bb0d14b57ab7cb03eb1ae44ddf47330b6fdb4c9d1cc88af1e744c&token=326147852&lang=zh_CN#rd](7个比较稳定的国内图床API 图片上传接口 (Python实战))
1.七个网站的Python实战代码
1.汽车之家
def t1():
#汽车之家
##请上传JPG、JPEG、BMP格式图片
import requests
from requests_toolbelt import MultipartEncoder
from bs4 import BeautifulSoup
cookie = '''
'''.replace("\r", "").replace("\n", "").replace(" ", "").encode('utf-8')
header = {
"Cookie": cookie,
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:103.0) Gecko/20100101 Firefox/103.0"
}
data = MultipartEncoder(fields={
"uploadFile": (
'图片名称.jpg', open(r'图片地址', 'rb'), "image/jpeg")})
header['Content-Type'] = data.content_type
print(BeautifulSoup(requests.post('https://i.autohome.com.cn/setting/face', headers=header, data=data).text,'lxml').select('#preview1'))
2.起点中文网
def t2():
#起点中文网
import requests
from requests_toolbelt import MultipartEncoder
from bs4 import BeautifulSoup
cookie = '''
'''.replace("\r", "").replace("\n", "").replace(" ", "").encode('utf-8')
header = {
"Cookie":cookie,
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:103.0) Gecko/20100101 Firefox/103.0"
}
data = MultipartEncoder(fields={
"_csrfToken": "y4z3yEFehOVEEMyDgrTQCuBKrxFhI7c41W8te9vp",
"image": (
'图片名称.png', open(r'图片地址', 'rb'), "image/png")})
header['Content-Type'] = data.content_type
return "https://" + BeautifulSoup(
requests.post("https://my.qidian.com/ajax/headimage/uploadimg", headers=header, data=data).text,'lxml').body.string.replace("\\", "").split("//")[1][:-3] + ".png"
3.喜马拉雅
def t3():
# 喜马拉雅
import time
import requests
from requests_toolbelt import MultipartEncoder
from bs4 import BeautifulSoup
import os
import hashlib
import datetime
from urllib import parse
# step 1
cookie = '''
'''.replace("\r", "").replace("\n", "").replace(" ", "").encode('utf-8')
header = {
"Cookie": cookie,
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:103.0) Gecko/20100101 Firefox/103.0"
}
name = '图片名称.jpg'
path = r"图片地址"
rsp1 = requests.post('https://cupload.ximalaya.com/clamper-token/token', data={"fileName": name,
"fileSize": str(
os.path.getsize(path)),
"uploadType": "picture",
"callerType": "ting"},
headers=header).json()['token']
print(rsp1)
# step 2
# Content-Type application/octet-stream 这里的文件上传方式我还不清楚,因为MD5那关没过去
header = {"Authorization": str(rsp1).encode('utf-8'),
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:103.0) Gecko/20100101 Firefox/103.0"}
time2 = str(datetime.datetime.now().strftime("%Y/%m/%d %H:%M:%S")).replace('/0', "/")
MD5 = str('') # 请原谅我太菜了,看不懂 JS代码,不明白这里离得 MD5加密方式, 可能是 token结合某个量吧,希望会的大神告诉咱怎么弄清楚这个
url={
"id":"WU_FILE_0",
"name":name,
"type":"image/png",
"lastModifiedDate":time2,
"size":str(os.path.getsize(path)),
"timeStart":str(int(time.time() * 1000)),
"chunks":"1",
"chunk":"0",
"multipartId":"",
"md5":MD5,
"uid":"0",}
ctx = str(requests.post(url='https://cupload.ximalaya.com/upload/file/blk?'+parse.urlencode(url) , headers=header, files={'files': open(path, 'rb')}).json()['data']['ctx']).encode('utf-8')
multipartId = str(requests.post(url='https://cupload.ximalaya.com/upload/file/blk?'+parse.urlencode(url), headers=header, files={'files': open(path, 'rb')}).json()['data']['multipartId']).encode('utf-8')
# step3
# 获取link
header = {"Authorization": str(rsp1).encode('utf-8'),
"Cookie": cookie,
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:103.0) Gecko/20100101 Firefox/103.0"}
data = {"uid": 0,
"uploadType": "picture",
"appkey": "ting",
"fileSize": str(os.path.getsize(path)),
"fileExtName": "jpg", # 如果是png图片那就是 png
"fileName": name,
"deviceType": "web",
"clientIp": "",
"ctxList": [ctx],
"multipartId": multipartId,
"codeOrNot": "1"}
print(requests.post('https://cupload.ximalaya.com/upload/merge/mkfile', headers=header, json=data)['data'][
'freeFileUrl'])
4.中关村在线
def t4():
# 中关村在线
# 仅支持jpg、png格式,且文件小于2M
import requests
from requests_toolbelt import MultipartEncoder
from bs4 import BeautifulSoup
cookie = '''
'''.replace("\r", "").replace("\n", "").replace(" ", "").encode('utf-8')
header = {
"Cookie": cookie,
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:103.0) Gecko/20100101 Firefox/103.0"
}
data = MultipartEncoder(fields={
"myPhoto": (
'图片名称.jpg', open(r'图片地址', 'rb'), "image/jpeg")})
header['Content-Type'] = data.content_type
print(requests.post('https://my.zol.com.cn/index.php?c=Ajax_User&a=uploadImg', headers=header, data=data).json()[
'url'])
5.失效:蘑菇街
6.失效:VIVO手机论坛
7.花瓣网
def t7():
# 花瓣网
import requests
from requests_toolbelt import MultipartEncoder
cookie = '''
'''.replace("\r", "").replace("\n", "").replace(" ", "").encode('utf-8')
header = {
"Cookie": cookie,
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:103.0) Gecko/20100101 Firefox/103.0"
}
data = MultipartEncoder(fields={
"file": (
'图片名称.jpg', open(r'图片地址', 'rb'), "image/jpeg")})
header['Content-Type'] = data.content_type
print(requests.post('https://api.huaban.com/upload', headers=header, data=data).json()[
'key']) # https://gd-hbimg.huaban.com/
2.总结
【multipart/form-data; boundary=】类型,没有验证手段的简单易行,有验证手段的需要参考JS判断加密方式,如上述“喜马拉雅”的实战,我没做出来,因为加密方式没弄懂,JavaScript代码经过加密之后,完全看不懂,也没用解密的手段。
3.参考文献
[1]: https://blog.csdn.net/xiaojianpitt/article/details/6856536 "Multipart/form-data POST文件上传详解"
[2]: https://zhuanlan.zhihu.com/p/106860812 "7个比较稳定的国内图床API 图片上传接口"
[3]: https://mp.weixin.qq.com/s?__biz=MzI5MTg1NjA4Nw==&mid=2247548954&idx=1&sn=cb11f2eb5bcfe6349d695acc3755c1aa&chksm=ec080ba2db7f82b4195276e3ff6892ca346d7abbde0dab4c2eb3fe46582b74d5113665592a18&scene=21#wechat_redirect "Python实现各种加密,接口加解密不再难"
[4]: https://blog.csdn.net/weixin_41646716/article/details/85070981 "options请求"
[5]: https://www.cnblogs.com/bainianminguo/p/12099532.html#5087066 "python通过http(multipart/form-data)上传文件的方法 "
本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:7个比较稳定的国内图床API 图片上传接口 (Python实战) - Python技术站