位置:绿色联盟 > 下载中心源码模版插件辅助→ 微博相册图片地址批量获取工具.user微博相册图片地址批量获取工具脚本下载

微博相册图片地址批量获取工具.user微博相册图片地址批量获取工具脚本

  • 运行环境:PC-windows操作系统
  • 软件语言:简体中文|授权方式:
  • 软件类型:国产软件 - 源码模版 - 插件辅助
  • 软件大小:5.00 KB
  • 下载星级:
  • 软件官网:暂无
  • 更新时间:2018/4/22 19:15:23
软件简介
本站提供的 微博相册图片地址批量获取工具.user微博相册图片地址批量获取工具脚本 软件免费下载。

【软件截图】

微博相册图片地址批量获取工具.user微博相册图片地址批量获取工具脚本

【基本介绍】

一款由作者枫谷剑仙分享的一个浏览器扩展插件(应用程序接口程序)。 可以通过脚本用户可以能够批量获取微博, 即微博客(MicroBlog)相册图片PHOTO地址,有有请求需要的用户欢迎下载使用体验!

脚本描述

支持获取 微博相册 - 单个相册、微博相册 - 全部、微博首页上传 的图片地址。

微博相册图片地址批量获取工具.user微博相册图片地址批量获取工具脚本特别说明:
// ==UserScript==
// @name        WeiboPhotoUrlBatchGet
// @name:zh-CN  微博相册图片地址批量获取工具
// @namespace   http://www.mapaler.com/
// @description BatchGetWeiboPhotoURL
// @description:zh-CN 批量获取微博相册图片地址
// @include     *://weibo.com/*home*
// @include     *://weibo.com/*friends*
// @include     *://weibo.com/*mygroups*
// @include     *://photo.weibo.com/*albums/detail/album_id/*
// @include     *://photo.weibo.com/*talbum/index*
// @include     *://photo.weibo.com/*photos*
// @version     2.0.2
// @grant       none
// @copyright   2016+, Mapaler <mapaler@163.com>
// @icon        
// ==/UserScript==

(function() {
var scriptName = typeof(GM_info)!="undefined" ? (GM_info.script.localizedName ? GM_info.script.localizedName : GM_info.script.name) : "WeiboPhotoUrlBatchGet"; //本程序的名称
var scriptVersion = typeof(GM_info)!="undefined" ? GM_info.script.version : "LocalDebug"; //本程序的版本
var imgs = { img: [] , count:0};
function imgObj()
{
 var obj = {
  addFormUrl: function (url)
  {
   var regSrc = /(https?:\/\/[^\/]+)\/.+\/([\d\w]+)\.([\d\w]+)/ig;
   var result = regSrc.exec(url);
   if (result == null) return this;
   this.host = result;
   this.pid = result[2];
   this.extention = result[3];
   return this;
  },
  add: function (host, pid, extention)
  {
   if (extention == undefined) extention = "jpg";
   this.host = host;
   this.pid = pid;
   this.extention = extention;
   return this;
  },
  get: function (size)
  {
   if (size == undefined) size = "large";
   var src = [
    this.host,
    "/",
    size,
    "/",
    this.pid,
    ".",
    this.extention
   ];
   return src.join("");
  },
  host: "",
  pid: "",
  extention: "",
  //width: 0,
  //height: 0,
  //large: "", mw690: "", mw600: "", bmiddle: "", small: "", square: "", sq612: "", orj480: "", smsq612all: "", thumb300: "", thumb180: "", thumb150: "", 
 }
 return obj;
}

//访GM_xmlhttpRequest函数v1.2
if(typeof(GM_xmlhttpRequest) == "undefined")
{
 var GM_xmlhttpRequest = function(GM_param){

  var xhr = new XMLHttpRequest(); //创建XMLHttpRequest对象
  if(GM_param.responseType) xhr.responseType = GM_param.responseType;
  xhr.onreadystatechange = function()  //设置回调函数
  {
   if (xhr.readyState == 4 && xhr.status == 200 && GM_param.onload)
    GM_param.onload(xhr);
   if (xhr.readyState == 4 && xhr.status != 200 && GM_param.onerror)
    GM_param.onerror(xhr);
  }
  xhr.open(GM_param.method, GM_param.url, true);

  for (var header in GM_param.headers){
   xhr.setRequestHeader(header, GM_param.headers[header]);
  }

  xhr.send(GM_param.data ? GM_param.data : null);
 }
}

var win = document.createElement('div');
win.id = "WeiboPhotoUrlBatchGet"
win.className = "WPUBG_win"

var style = document.createElement("style");
win.appendChild(style);
style.type = "text/css";
style.innerHTML +=
 [
  ".WPUBG_win" + "{\r\n" + [
            'box-shadow:0 0 10px #333',
            'position:fixed',
            'top:0',
            'right:0',
            'z-index:1000000',
            'font-family:arial,sans-serif',
            'padding:5px',
            'margin:0',
            'border-radius: 0 0 0 5px',
            'background:#F5F8FA',
  ].join(';\r\n') + "\r\n}",
  ".WPUBG_box" + "{\r\n" + [
            'width:180px',
  ].join(';\r\n') + "\r\n}",
  ".WPUBG_tra" + "{\r\n" + [
            'width:180px',
            'height:180px',
  ].join(';\r\n') + "\r\n}",
  ".WPUBG_cls" + "{\r\n" + [
   'width:40px',
   'box-shadow:0 0 2px #333',
   'position:absolute',
   'top:0',
   'left:-40px',
   'line-height:25px',
   'padding:0',
   'margin:0',
   'border-radius:0',
   'border:none',
   'background:#515151',
   'z-index:99999',
   'text-align:center',
   'color:#aaa',
   'cursor:pointer',
  ].join(';\r\n') + "\r\n}",
  ".WPUBG_ipt" + "{\r\n" + [
            'width:100px',
  ].join(';\r\n') + "\r\n}",
  ".WPUBG_rate" + "{\r\n" + [
            'float:right',
  ].join(';\r\n') + "\r\n}",
 ].join('\r\n');

var box = document.createElement('div');
box.className = "WPUBG_box";
win.appendChild(box);

var title = document.createElement('div');
title.className = "WPUBG_title";
title.innerHTML = scriptName + " v" + scriptVersion;
box.appendChild(title);

var tra = document.createElement('textarea');
tra.className = "WPUBG_tra";
tra.wrap = "off";
tra.placeholder = "获取数据中...";
box.appendChild(tra);

var lbl = document.createElement('label');
lbl.className = "WPUBG_lbl";
lbl.innerHTML = "Size:";
lbl.title = "常见尺寸:\r\nlarge\r\nmw690\r\nmw600\r\nbmiddle\r\nsmall\r\nsquare\r\nsq612\r\norj480\r\nsmsq612all\r\nthumb300\r\nthumb180\r\nthumb150";
box.appendChild(lbl);

var ipt = document.createElement('input');
ipt.className = "WPUBG_ipt";
ipt.type = "text";
ipt.placeholder = "large";
ipt.name = "WPUBG_size";
ipt.title = "常见尺寸:\r\nlarge\r\nmw690\r\nmw600\r\nbmiddle\r\nsmall\r\nsquare\r\nsq612\r\norj480\r\nsmsq612all\r\nthumb300\r\nthumb180\r\nthumb150";
ipt.value = getConfig("WPUBG_size");
ipt.onblur = function ()
{
 setConfig("WPUBG_size", this.value);
 reCreatList();
}
lbl.appendChild(ipt);

var rate = document.createElement('span');
rate.className = "WPUBG_rate";
box.appendChild(rate);

var cls = document.createElement('div');
cls.className = "WPUBG_cls";
win.appendChild(cls);
cls.innerHTML = '关闭';//关闭
cls.onclick = function (){ win.parentNode.removeChild(win);}


 
if (document.location.host == "photo.weibo.com")
{
 var album = !(typeof($GLOBAL_DETAIL) == "undefined");
 if(!album)console.error("未发现 $GLOBAL_DETAIL ,不是专辑");
 var btnGetAll = document.createElement('button');
 btnGetAll.className = "M_btn_h";
 btnGetAll.innerHTML = "获取本专辑全部图片地址";
 btnGetAll.onclick = function () { getAll(album); }
 if (album)
  var insertPlace = document.getElementsByClassName("m_share_like")[0];
 else
  var insertPlace = document.getElementsByClassName("m_user_album")[0];
 insertPlace.insertBefore(btnGetAll, insertPlace.firstChild);
} else
{
 var insertPlace = document.getElementById("plc_top");
 var btnGetUp = document.createElement('button');
 btnGetUp.className = "W_btn_a";
 btnGetUp.innerHTML = "获得上传的图地址";
 btnGetUp.style.cssFloat = "left";
 btnGetUp.onclick = function () { getUp(); }
 insertPlace.appendChild(btnGetUp);
}

function getUp()
{
 if (win.parentNode || win.parentNode != document.body) document.body.appendChild(win);
 var drag_pic_list = document.getElementsByClassName("drag_pic_list")[0];
 var pics = drag_pic_list.getElementsByClassName("pic");
 for (var pi = 0, len=pics.length; pi < len; pi++)
 {
  var pdiv = pics[pi].getElementsByTagName("div")[0];
  var img = new imgObj;
  imgs.img.push(img.addFormUrl(pdiv.style.backgroundImage))
  tra.value += img.get() + "\r\n";
 }
}
function getAll(isAlbum)
{
 if (win.parentNode || win.parentNode != document.body) document.body.appendChild(win);
 if (imgs.img.length > 0)
  reCreatList();  //重新生成列表,不重复获取
 else
 {
  var type = (isAlbum && $GLOBAL_DETAIL.type == 3) ? 3 : 1 ; //当type为3时(访问他人相册),无法一次性获取所有图像,只能每次30个。

  GM_xmlhttpRequest({
   method: "GET",
   url: "http://photo.weibo.com/photos/get_all?uid="; + $CONFIG.owner_uid + (isAlbum?"&album_id=" + $GLOBAL_DETAIL.album_info.album_id:"") + "&count=1&type=" + type + "&__rnd=" + new Date().getTime(),
   onload: function(response) {
    dellFirstJSON(response, $CONFIG.owner_uid, (isAlbum?$GLOBAL_DETAIL.album_info.album_id:isAlbum), type)
   }
  });
 }
}

function dellFirstJSON(response, uid, aid, type)
{
 var info = JSON.parse(response.response);
 imgs.count = info.data.total; //添加图片总数
 
 //当前进度
 rate.innerHTML = imgs.img.length + "/" + imgs.count;
 if (imgs.count<1){alert("图片总数为0,可能没有图片。");return;}

 if(type == 3)
 {
  var imgCountInPage = 30;
  for(var pi=1, len=Math.ceil(imgs.count/imgCountInPage); pi<=len; pi++)
  {
   var thePi = pi;
   GM_xmlhttpRequest({
    method: "GET",
    url: "http://photo.weibo.com/photos/get_all?uid="; + uid + (aid?"&album_id=" + aid:"") + "&count=" + imgCountInPage + "&page=" + thePi + "&type=" + type + "&__rnd=" + new Date().getTime(),
    onload: function(response) {
     dellAllJSON(response, thePi);
    }
   });
  }
 }else
 {
  GM_xmlhttpRequest({
   method: "GET",
   url: "http://photo.weibo.com/photos/get_all?uid="; + uid + (aid?"&album_id=" + aid:"") + "&count=" + info.data.total + "&type=" + type + "&__rnd=" + new Date().getTime(),
   onload: function(response) {
    dellAllJSON(response);
   }
  });
 }
}

function dellAllJSON(response, pageIndex)
{
 var info = JSON.parse(response.response);
 plist = info.data.photo_list;
 if (plist.length<1){
  alert((pageIndex?pageIndex + "页" :"") + "没有获取到图片数据,可能是有些图被渣浪和谐了,也可能不支持本页面或API有变化需要更新脚本。");
  console.log(response)
  return;
 }
 for (pi = plist.length - 1; pi >= 0; pi--)
 {
  var img = new imgObj;
  var regFn = /([\d\w]+)\.([\d\w]+)/ig;
  var resultFn = regFn.exec(plist[pi].pic_name);
  img.add(plist[pi].pic_host, plist[pi].pic_pid, resultFn[2]);
  imgs.img.push(img);
 }
 reCreatList();
}

function reCreatList(size) //重新生成列表
{
 if (size == undefined) size = getConfig("WPUBG_size").length > 0 ? getConfig("WPUBG_size") : "large";

 //用了ES5的map,将当前所有图像生成链接写入
 var links = imgs.img.map(function (img) {return img.get(size);});
 tra.value = links.join("\r\n");

 //当前进度
 rate.innerHTML = imgs.img.length + "/" + imgs.count;
}

function getConfig(key) {
 if (window.localStorage) {
  return window.localStorage.getItem(key) || "";
 } else {
  return getCookie(key);
 }
};
function setConfig(key, value) {
 if (window.localStorage) {
  window.localStorage.setItem(key, value);
 } else {
  setGdCookie(key, value, 86400 * 365);
 }
};

})();

下载地址
软件说明
* 为了达到最快的下载速度,推荐使用迅雷下载
* 请一定升级到最新版WinRAR解压缩软件才能正常解压本站提供的软件!
* 站内提供的所有软件由网上搜集,若侵犯了你的版权利益,敬请来信通知我们!