什么是微博图床?
微博图床,指把图片上传到新浪微博的图库,然后用这个图片外链达到节约本地服务器空间及加快图片加载速度的目的。
相比于其它的图床,利用微博当图床具有加载速度快、不限流量、不限容量等优点。网上有许多浏览器插件或在线工具能够实现。直接利用第三方的工具如果只是上传一两张图片倒也方便,如果要大批量上传并获取外链就得自己写一个了。
微博图床实现方法探究
目前已知有两个方法能实现,其一是利用微博官方的开放平台的发微博 API 实现。这种方法也是我最先考虑的方法,因为毕竟是官方渠道,应该靠谱些。
然而经过一番折腾后,我发现这一方法根本不可行。因为微博限制了这一 API 的调用频次,在连续上传时立即就会被封堵。
方法二是利用微博的 MINI 发布框(http://weibo.com/minipublish)的图片上传功能。
正是这个发布框暴露了微博的一个图片上传接口
网上的这些微博图床大都也是利用这个接口实现的。
利用这一接口的优点是可以实现快速连续上传图片而不被封。缺点是必须要带着微博登录的 Cookie 才能访问。
PHP代码
说了这么多,现在贴一下相关php代码:
-
/**
- 上传图片到微博图床
- @author mengkun http://mkblog.cn
- @param $file 图片文件/图片url
- @param $multipart 是否采用multipart方式上传
- @return 返回的json数据
-
*/
-
function upload(
multipart = true) {
-
$cookie = ''; // 微博cookie
-
$url = 'http://picupload.service.weibo.com/interface/pic_upload.php'
-
.'?mime=image%2Fjpeg&data=base64&url=0&markpos=1&logo=&nick=0&marks=1&app=miniblog';
-
if($multipart) {
-
$url .= '&cb=http://weibo.com/aj/static/upimgback.html?wv=5&callback=STK_ijax'.time();
-
if (class_exists('CURLFile')) { // php 5.5
-
file));
-
} else {
-
file);
-
}
-
} else {
-
file));
-
}
-
// Curl提交
-
url);
-
curl_setopt_array($ch, array(
-
CURLOPT_POST => true,
-
CURLOPT_VERBOSE => true,
-
CURLOPT_RETURNTRANSFER => true,
-
CURLOPT_HTTPHEADER => array("Cookie: $cookie"),
-
CURLOPT_POSTFIELDS => $post,
-
));
-
ch);
-
curl_close($ch);
-
// 正则表达式提取返回结果中的json数据
-
preg_match('/({.*)/i',
match);
-
if(!isset($match[1])) return '';
-
return $match[1];
-
}
如你所见,代码中包含两种上传方式,一种是 multipart 方式上传,通过这种方式上传效率较高,局限性是只能上传服务器的本地图片。

)
- upload('mypic.jpg', true); // multipart方式上传
- upload('http://www.mysite.cn/mypic.jpg', false); // 非multipart方式(base64)上传
无论通过以上哪种方式,返回的都会是一段如下所示的json数据。
- {"code":"A20001","data":{"count":2,"data":"eyJ1aWQiOjIyODczOTc1NzUsImFwcCI6Im1pbmlibG9nIiwiY291bnQiOjIsInRpbWUiOjE0OTM3ODE0NzQuMzQ5LCJwaWNzIjp7InBpY18yIjp7InJldCI6LTIsIm5hbWUiOiJwaWNfMiJ9LCJwaWNfMSI6eyJ3aWR0aCI6MzAwLCJzaXplIjo4Njk5LCJyZXQiOjEsImhlaWdodCI6MzAwLCJuYW1lIjoicGljXzEiLCJwaWQiOiI4ODU2ZWFjN2d5MWZmODA4NGhtanpqMjA4YzA4YzN5ZSJ9fX0=","pics":{"pic_2":{"ret":-2,"name":"pic_2"},"pic_1":{"width":300,"size":8699,"ret":1,"height":300,"name":"pic_1","pid":"8856eac7gy1ff8084hmjzj208c08c3ye"}}}}

如图所示,pid码就是忙活了这么久之后最终要用到的。
http://ww2.sinaimg.cn/large/ + 获取到的pid 就能组合成图片的外链。
比如上面示范的那段数据中包含的图片外链地址就是
http://ww2.sinaimg.cn/large/8856eac7gy1ff8084hmjzj208c08c3ye
其实 pid 中还包含了更多“秘密”,这里提供一下 pid 的终极解码算法
:
- /**
- 获取图片链接(本函数修改自 https://github.com/consatan/weibo_image_uploader)
- @param string $pid 微博图床pid,或者微博图床链接。传递的是链接的话,
仅是将链接的尺寸更改为目标尺寸而已。
- @param string $size 图片尺寸
- @param bool $https (true) 是否使用 https 协议
- @return string 图片链接
- 当 $pid 既不是 pid 也不是合法的微博图床链接时返回空值
- */
- function getImageUrl(
size = 0, $https = true)
- {
- $sizeArr = array('large', 'mw1024', 'mw690', 'bmiddle', 'small', 'thumb180', 'thumbnail', 'square');
-
pid);
-
sizeArr[$size];
- // 传递 pid
- if (preg_match('/^[a-zA-Z0-9]{32}
pid) === 1) {
- return (
https ? 'ws' : 'ww')
- . ((crc32(
size
- . "/
pid[21] === 'g' ? 'gif' : 'jpg');
- }
- // 传递 url
-
pid;
- $imgUrl = preg_replace_callback('/^(https?://[a-z]{2}\d.sinaimg.cn/)'
- . '(large|bmiddle|mw1024|mw690|small|square|thumb180|thumbnail)'
- . '(/[a-z0-9]{32}.(jpg|gif))
match) use ($size) {
- return
size . $match[3];
- },
count);
- if ($count === 0) {
- return '';
- }
- return $imgUrl;
- }
附:微博Cookie获取方法
首先登录微博,然后按F12打开控制台 Network,然后再刷新页面就可以在 Headers 中看到cookie。


原文:https://mkblog.cn/854/#title-2
相关:
https://github.com/178146582/Fantasy-field
发现一个微博图床API和图片上传代码
Weibo-Picture-Store: 又一款新浪微博图床 Chrome 插件,支持自定义尺寸
已知的自定义裁剪格式:
large -> 原始图片
mw690 -> 最大 690 像素宽度裁剪
thumbnail -> 缩略图
small -> 小图
square -> 80 像素正方形裁剪
thumb150 -> 150 像素正方形裁剪
thumb180 -> 180 像素正方形裁剪
thumb300 -> 300 像素正方形裁剪
orj180 -> 180 像素宽度原比例缩放
orj360 -> 360 像素宽度原比例缩放
crop.x.y.x1.y1.w -> 自定义矩形裁剪,其中 x, y 表示左上角坐标,x1, y1 表示右下角坐标,w 是宽度
网友评论