微博图床php上传,php利用微博当图床
目前已知有两个方法能实现,其一是利用微博官方的开放平台的发微博 API 实现。这种方法也是我最先考虑的方法,因为毕竟是官方渠道,应该靠谱些。
然而经过一番折腾后,我发现这一方法根本不可行。因为微博限制了这一 API 的调用频次,在连续上传时立即就会被封堵。
方法二是利用微博的 MINI 发布框(http://weibo.com/minipublish)的图片上传功能。
正是这个发布框暴露了微博的一个图片上传接口
http://picupload.service.weibo.com/interface/pic_upload.php
网上的这些微博图床大都也是利用这个接口实现的。
利用这一接口的优点是可以实现快速连续上传图片而不被封。缺点是必须要带着微博登录的 Cookie 才能访问。
说了这么多,现在贴一下相关php代码:/**
* 上传图片到微博图床
* @author mengkun http://mkblog.cn
* @param $file 图片文件/图片url
* @param $multipart 是否采用multipart方式上传
* @return 返回的json数据
*/
function upload($file, $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
$post['pic1'] = new CURLFile(realpath($file));
} else {
$post['pic1'] = '@'.realpath($file);
}
} else {
$post['b64_data'] = base64_encode(file_get_contents($file));
}
// Curl提交
$ch = curl_init($url);
curl_setopt_array($ch, array(
CURLOPT_POST => true,
CURLOPT_VERBOSE => true,
CURLOPT_RETURNTRANSFER => true,
CURLOPT_HTTPHEADER => array("Cookie: $cookie"),
CURLOPT_POSTFIELDS => $post,
));
$output = curl_exec($ch);
curl_close($ch);
// 正则表达式提取返回结果中的json数据
preg_match('/({.*)/i', $output, $match);
if(!isset($match[1])) return '';
return $match[1];
}
如你所见,代码中包含两种上传方式,一种是 multipart 方式上传,通过这种方式上传效率较高,局限性是只能上传服务器的本地图片。
另一种方式是base64方式,可以上传远程图片。(文字的表述可能不清楚,用代码就明白了 )
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"}}}}
其它的不用管,我们只需要 pic_1 这个子节点中的数据
如图所示,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($pid, $size = 0, $https = true)
{
$sizeArr = array('large', 'mw1024', 'mw690', 'bmiddle', 'small', 'thumb180', 'thumbnail', 'square');
$pid = trim($pid);
$size = $sizeArr[$size];
// 传递 pid
if (preg_match('/^[a-zA-Z0-9]{32}$/', $pid) === 1) {
return ($https ? 'https' : 'http') . '://' . ($https ? 'ws' : 'ww')
. ((crc32($pid) & 3) + 1) . ".sinaimg.cn/" . $size
. "/$pid." . ($pid[21] === 'g' ? 'gif' : 'jpg');
}
// 传递 url
$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))$/i', function ($match) use ($size) {
return $match[1] . $size . $match[3];
}, $url, -1, $count);
if ($count === 0) {
return '';
}
return $imgUrl;
}
微博图床php上传,php利用微博当图床相关推荐
- 微博图床php上传,使用新浪微博图床
首先感谢新浪微博提供的免费图床(对外链无限制),以及吊炸天的cdn图片加速服务,从此妈妈再也不用担心我的图床不能用了. 图床原理: 访问http://weibo.com/minipublish 使用新 ...
- linux禁止客户端上传文件_图片/文件上传如此简单|macOS 图床客户端 uPic
前言 相信很多人在写作(特别是需要多平台发布)的时候都会因为插图而增加工作量: 平台图片外链不允许在网站外部访问. 使用云图床服务上传流程复杂. 那么这些问题有没有办法解决呢,答案肯定是"有 ...
- Typora搭建图床解决上传md文档图片无法加载的问题
Typora搭建图床||解决上传md文档图片无法加载的问题 写在前面 写下这篇文章的时候,据说好像是gitee官方禁止了图床上传方面的功能,我做了尝试是报了403错误,只能说错不在我咯,哈哈.所以说这 ...
- 常见文件上传漏洞利用
常见文件上传漏洞利用 一.常见文件上传绕过方法 1.前端javascript校验文件名 2.MIME类型检测绕过 3.大小写绕过 4.双写.点.空格绕过 5.特殊后缀名绕过 6.文件内容检测 7.使用 ...
- 『原创』ewebeditor 2.1.6 上传漏洞利用工具
朋友说原来的ewebeditor 2.1.6 HTML版用着太麻烦,每次还得输入地址,叫我帮忙写一个...- -||| ewebeditor 2.1.6 上传漏洞利用工具 ewebeditor在网上用 ...
- 文件上传漏洞利用介绍
目录 文件上传漏洞利用介绍 1.绕过js验证 2.绕过MIME-TYPE验证 3.绕过基于黑名单验证 基于文件后缀名验证介绍 基于文件后缀名验证方式的分类 基于黑名单验证代码分析 利用apache配置 ...
- 【《编辑器篇》kindeditor 文件上传漏洞利用】
<编辑器篇>kindeditor 文件上传漏洞利用 一.漏洞描述 KindEditor是一套开源的HTML可视化编辑器,其采用的开发语言支持asp.aspx.php ...
- PHPCMS V9手机移动端(支持单图和多图)图片上传,(PHPCMS V9前台使用layui的上传组件代替默认的SWFupload上传图片)
默认phpcms的上传 图片使用的是swfupload,导致手机移动端上传图片无法使用.这里我们使用layui的上传组件来使其支持手机移动端(支持单图和多图)图片上传,效果图如下: 实现步骤: 一 ...
- mui开发app之多图压缩与上传(仿qq空间说说发表)
应广大读者建议,已经将该项目源码提交到地址: https://github.com/devilyouwei/dashen 与本博客相关的多图压缩上传代码在dashen/service/ask.html ...
最新文章
- 红牛开发板模拟器简要说明_V1.0
- 图解谷歌大脑丶城市大脑丶全球脑与互联网大脑的关系
- Facebook大牛、HipHop作者赵海平加入阿里巴巴
- 月薪多少才算80后中的人生赢家?他们的经济、婚姻、生活方式是怎样的
- 谁的代码注释我都不服,就服你的!
- 开源 | 近期遥感航空影像的检索、检测、跟踪、计数、分类相关工作
- Meteor——以NodeJS为基础环境,MongoDB为数据环境的全栈开发平台!
- golang mysql加锁_使用golang实现类InnoDB数据行锁效果
- iPhone 11跌至4439元?网友:虽是二手但用着很香
- python--(pickle)文件读写
- 星座是按阴历还是阳历
- 成都理工计算机考研很难吗,成都理工大学考研难吗?一般要什么水平才可以进入?...
- 巴菲特投资赚钱的赚钱宝典和赢家暗语
- 故障树手册(Fault Tree handbook)(5)
- JAVA:实现线性丢番图方程求解器算法(附完整源码)
- Linux为什么不怕病毒
- 计算机考研资料库!近五十所高校计算机考研资料分享!持续更新中!
- okio篇 1.Buffer
- 【Android】Android中如何取消调转界面后EditText默认获取聚焦问题
- 学习typescript已然迫在眉睫!!!