目前已知有两个方法能实现,其一是利用微博官方的开放平台的发微博 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利用微博当图床相关推荐

  1. 微博图床php上传,使用新浪微博图床

    首先感谢新浪微博提供的免费图床(对外链无限制),以及吊炸天的cdn图片加速服务,从此妈妈再也不用担心我的图床不能用了. 图床原理: 访问http://weibo.com/minipublish 使用新 ...

  2. linux禁止客户端上传文件_图片/文件上传如此简单|macOS 图床客户端 uPic

    前言 相信很多人在写作(特别是需要多平台发布)的时候都会因为插图而增加工作量: 平台图片外链不允许在网站外部访问. 使用云图床服务上传流程复杂. 那么这些问题有没有办法解决呢,答案肯定是"有 ...

  3. Typora搭建图床解决上传md文档图片无法加载的问题

    Typora搭建图床||解决上传md文档图片无法加载的问题 写在前面 写下这篇文章的时候,据说好像是gitee官方禁止了图床上传方面的功能,我做了尝试是报了403错误,只能说错不在我咯,哈哈.所以说这 ...

  4. 常见文件上传漏洞利用

    常见文件上传漏洞利用 一.常见文件上传绕过方法 1.前端javascript校验文件名 2.MIME类型检测绕过 3.大小写绕过 4.双写.点.空格绕过 5.特殊后缀名绕过 6.文件内容检测 7.使用 ...

  5. 『原创』ewebeditor 2.1.6 上传漏洞利用工具

    朋友说原来的ewebeditor 2.1.6 HTML版用着太麻烦,每次还得输入地址,叫我帮忙写一个...- -||| ewebeditor 2.1.6 上传漏洞利用工具 ewebeditor在网上用 ...

  6. 文件上传漏洞利用介绍

    目录 文件上传漏洞利用介绍 1.绕过js验证 2.绕过MIME-TYPE验证 3.绕过基于黑名单验证 基于文件后缀名验证介绍 基于文件后缀名验证方式的分类 基于黑名单验证代码分析 利用apache配置 ...

  7. 【《编辑器篇》kindeditor 文件上传漏洞利用】

    <编辑器篇>kindeditor 文件上传漏洞利用             一.漏洞描述 KindEditor是一套开源的HTML可视化编辑器,其采用的开发语言支持asp.aspx.php ...

  8. PHPCMS V9手机移动端(支持单图和多图)图片上传,(PHPCMS V9前台使用layui的上传组件代替默认的SWFupload上传图片)

    默认phpcms的上传 图片使用的是swfupload,导致手机移动端上传图片无法使用.这里我们使用layui的上传组件来使其支持手机移动端(支持单图和多图)图片上传,效果图如下:   实现步骤: 一 ...

  9. mui开发app之多图压缩与上传(仿qq空间说说发表)

    应广大读者建议,已经将该项目源码提交到地址: https://github.com/devilyouwei/dashen 与本博客相关的多图压缩上传代码在dashen/service/ask.html ...

最新文章

  1. 红牛开发板模拟器简要说明_V1.0
  2. 图解谷歌大脑丶城市大脑丶全球脑与互联网大脑的关系
  3. Facebook大牛、HipHop作者赵海平加入阿里巴巴
  4. 月薪多少才算80后中的人生赢家?他们的经济、婚姻、生活方式是怎样的
  5. 谁的代码注释我都不服,就服你的!
  6. 开源 | 近期遥感航空影像的检索、检测、跟踪、计数、分类相关工作
  7. Meteor——以NodeJS为基础环境,MongoDB为数据环境的全栈开发平台!
  8. golang mysql加锁_使用golang实现类InnoDB数据行锁效果
  9. iPhone 11跌至4439元?网友:虽是二手但用着很香
  10. python--(pickle)文件读写
  11. 星座是按阴历还是阳历
  12. 成都理工计算机考研很难吗,成都理工大学考研难吗?一般要什么水平才可以进入?...
  13. 巴菲特投资赚钱的赚钱宝典和赢家暗语
  14. 故障树手册(Fault Tree handbook)(5)
  15. JAVA:实现线性丢番图方程求解器算法(附完整源码)
  16. Linux为什么不怕病毒
  17. 计算机考研资料库!近五十所高校计算机考研资料分享!持续更新中!
  18. okio篇 1.Buffer
  19. 【Android】Android中如何取消调转界面后EditText默认获取聚焦问题
  20. 学习typescript已然迫在眉睫!!!

热门文章

  1. 2022年终工作总结PPT模板来了~
  2. 我对IT项目经理工作的理解
  3. k折交叉验证优缺点_都说K折交叉验证最常见,你会做吗?
  4. 关于长高问题 我的看法
  5. 不会汇报工作,还敢拼职场
  6. android手机拍摄视频格式,怎么用手机给自己拍摄的视频加上字幕?安卓手机视频编辑器给视频加字幕的方法...
  7. 什么都会,也许只是盲目跟风,和优秀无关
  8. macbook proa1708_MacBook Pro 2017 A1708自己更换电池
  9. docker 安装redis详细说明
  10. 那些中了500万的人过上想要的生活了吗