// ==UserScript== // @name 花瓣网下载 // @namespace https://www.saintic.com/ // @version 0.6.0 // @description 花瓣网(huaban.com)用户画板图片批量下载到本地 // @author staugur // @match http*://huaban.com/* // @match http*://*.meiwu.co/* // @require https://cdn.bootcss.com/FileSaver.js/1.3.2/FileSaver.min.js // @grant GM_setClipboard // @grant GM_info // @icon  // @license MIT // @date 2018-05-25 // @modified 2019-01-27 // @github https://github.com/staugur/grab_huaban_board/blob/master/grab_huaban_board.js // @supportURL https://blog.saintic.com/blog/256.html // @downloadURL none // ==/UserScript== (function() { 'use strict'; //字符串是否包含子串 function isContains(str, substr) { //str是否包含substr return str.indexOf(substr) >= 0; } //数组是否包含某元素 function arrayContains(arr, obj) { var i = arr.length; while (i--) { if (arr[i] === obj) { return true; } } return false; } //判断页面中id是否存在 function hasId(id) { //有此id返回true,否则返回false var element = document.getElementById(id); if (element) { return true } else { return false } } //获取url查询参数 function getUrlQuery(key, acq) { /* 获取URL中?之后的查询参数,不包含锚部分,比如url为http://passport.saintic.com/user/message/?status=1&Action=getCount 若无查询的key,则返回整个查询参数对象,即返回{status: "1", Action: "getCount"}; 若有查询的key,则返回对象值,返回值可以指定默认值acq:如key=status, 返回1;key=test返回acq */ var str = location.search; var obj = {}; if (str) { str = str.substring(1, str.length); // 以&分隔字符串,获得类似name=xiaoli这样的元素数组 var arr = str.split("&"); //var obj = new Object(); // 将每一个数组元素以=分隔并赋给obj对象 for (var i = 0; i < arr.length; i++) { var tmp_arr = arr[i].split("="); obj[decodeURIComponent(tmp_arr[0])] = decodeURIComponent(tmp_arr[1]); } } return key ? obj[key] || acq : obj; } //保存图片 function saveImage(imgUrl, imgName) { /* imgUrl: 图片地址; imgName: 保存的文件名 注意,使用此函数请先在用户脚本中:@require https://cdn.bootcss.com/FileSaver.js/1.3.2/FileSaver.min.js */ try { const xhr = new XMLHttpRequest(); xhr.open('GET', imgUrl, true); xhr.responseType = 'blob'; xhr.onload = () => { if (xhr.status === 200) { //将图片文件用浏览器中下载 saveAs(xhr.response, imgName); } }; xhr.send(); } catch (e) { console.error(e); } } //计算百分比 function calculatePercentage(num, total) { //小数点后两位百分比 return (Math.round(num / total * 10000) / 100.00 + "%"); } //加载css文件 function addCSS(href) { var link = document.createElement('link'); link.type = 'text/css'; link.rel = 'stylesheet'; link.href = href; document.getElementsByTagName("head")[0].appendChild(link); } //加载js文件 function addJS(src, cb) { var script = document.createElement("script"); script.type = "text/javascript"; script.src = src; document.getElementsByTagName('head')[0].appendChild(script); script.onload = typeof cb === "function" ? cb : function() {}; } //获取可使用域名 function getEffectiveHost() { var host = window.location.host; if (!host) { host = document.domain; } if (!host) { host = "huaban.com"; } if (isContains(host, "meiwu.co")) { host = "login.meiwu.co"; } else { host = "huaban.com"; } return host; } //时间戳转化为日期格式 function formatUnixtimestamp(unixtimestamp) { var unixtimestamp = new Date(unixtimestamp * 1000); var year = 1900 + unixtimestamp.getYear(); var month = "0" + (unixtimestamp.getMonth() + 1); var date = "0" + unixtimestamp.getDate(); var hour = "0" + unixtimestamp.getHours(); var minute = "0" + unixtimestamp.getMinutes(); var second = "0" + unixtimestamp.getSeconds(); return year + "-" + month.substring(month.length - 2, month.length) + "-" + date.substring(date.length - 2, date.length) + " " + hour.substring(hour.length - 2, hour.length) + ":" + minute.substring(minute.length - 2, minute.length); } //封装localStorage var storage = (function storage() { var key = "grab_huaban_board"; var obj = window.localStorage; if (!obj) { console.error("浏览不支持localStorage"); return false; } //设置或跟新本地存储数据 function set(data) { if (data) { obj.setItem(key, JSON.stringify(data)); } } //获取本地存储数据 function get() { var data = [] try { data = JSON.parse(obj.getItem(key)); } catch (e) { } finally { return data; } } var clear = function() { //清除对象 obj.removeItem(key); }; return { set: set, get: get, clear: clear }; })(); //由于@require方式引入jquery时layer使用异常,故引用cdn中jquery v1.10.1;加载完成后引用又拍云中layer v3.1.1 addJS("https://cdn.bootcss.com/jquery/1.10.1/jquery.min.js", function() { addJS("https://static.saintic.com/cdn/layer/3.1.1/layer.js"); }); /* 下载用户画板接口 */ //交互确定画板下载方式 function interactiveBoard(board_id, pins, pin_number, user_id) { /* board_id int: 画板id pins list: 包含所有程序加载到的图片数据 pin_number int: 这个画板总共有多少图片 user_id str: 这个画板所属的用户 */ var downloadMethod = 0, msg = [ '
寻求帮助?请点击我!
请注意:用户存在多个画板时会弹出多个窗口,请移动或最小化当前窗口以显示其他窗口。
', '寻求帮助?请点击我!
@" + formatUnixtimestamp(notice.ctime) + " 【 " + notice.content + " 】
"; } }); storage.set(localIds); if (!html) { return false; } layer.open({ type: 1, title: '诏预开放平台公告', closeBtn: false, area: 'auto', shade: 0, id: 'grab_huaban_board' //设定一个id,防止重复弹出 , resize: true, maxmin: true, btn: ['我知道了'], btnAlign: 'c', moveType: 1 //拖拽模式,0或者1 , content: '