您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
在百度云网盘的页面添加一个搜索框,调用搜索API搜索所有公开分享文件// To add a search frame that calls some api for searching some public shared files in BaiduYun cloud netdisk.
当前为
// ==UserScript== // @name 百度云插件+APIKey // @namespace // @version 4.4.3.1 beta // @description 在百度云网盘的页面添加一个搜索框,调用搜索API搜索所有公开分享文件// To add a search frame that calls some api for searching some public shared files in BaiduYun cloud netdisk. // @require http://code.jquery.com/jquery-2.1.1.min.js // @description For more imformation,please email me at [email protected]. // @include http://pan.baidu.com/disk/* // @include https://pan.baidu.com/disk/* // @include https://yun.baidu.com/#from=share_yun_logo/ // @include http://yun.baidu.com/#from=share_yun_logo/ // @grant GM_xmlhttpRequest // @run-at document-end // @copyright 2014,04,20 __By Wang Hsin-che // ==/UserScript== ////////////////////////////////////////////////////////////////////// /////jQuery draggable plugin v0.2 by Wang Hsin-che @ 2014 08/////////////// /////usage: $(selector).draggable({handel:'handle',msg:{},callfunction:function(){}}); ////////////////////////////////////////////////////////////////////// (function($) { $.fn.draggable = function(options) { var settings = $.extend({ handle: undefined, msg: {}, callfunction: function() {} }, options); var _eleFunc = function() { var x0, y0, ele = $(this), handle; handle = (settings.handle === undefined ? ele : ele.find(settings.handle).eq(0) === undefined ? ele : ele.find(settings.handle).eq(0)); ele.css({ position: "absolute" }); //make sure that the "postion" is "absolute" handle.bind('mousedown', function(e0) { handle.css({ cursor: "move" }); //set the appearance of cursor x0 = ele.offset().left - e0.pageX; //*1 y0 = ele.offset().top - e0.pageY; //*1 $(document).bind('mousemove', function(e1) { //bind the mousemove event, caution:this event must be bind to "document" ele.css({ left: x0 + e1.pageX, top: y0 + e1.pageY }); //this expression and the expression of *1 equal to "ele.origin_offset+mouse.current_offset-mouse.origin_offset" }); $(document).one('mouseup', settings.msg, function(e) { //when the mouse up,unbind the mousemove event,bind only once settings.callfunction(e); //callback function $(document).unbind('mousemove'); handle.css({ cursor: "auto" }); }); }); // 從這裡開始 }; return this.each(_eleFunc); }; })(jQuery); ///////////////////////////////////////////////////////////////////////////////////////////////////////////// ////// /////定义 var SearchObject = function($, replaceEle) { var keyword = '', flag = '', info = 'Created by Wang Hsin-che @ 2014 04. The current version is 4.4.3.1'; function searchClear() { $('#wxz_myDiv').slideUp(); $('#wxz_input').val(''); keyword = ''; $('.wxz-content').empty(); //清空原来的内容 console.log('clear'); } function search(keyword, startIndex) { var url; if (keyword === '') { console.log('fail'); return 0; } console.log('search'); switch (flag) { case 'repigu': url = 'https://repigu.com/uds/GwebSearch?rsz=filtered_cse&hl=zh_CN&cx=018177143380893153305:yk0qpgydx_e&v=1.0&key=AIzaSyCVAXiUzRYsML1Pv6RwSG1gunmMikTzQqY&q='; url = url + keyword + '&start=' + startIndex; break; case 'Google': url = 'https://www.googleapis.com/customsearch/v1element?key=AIzaSyCVAXiUzRYsML1Pv6RwSG1gunmMikTzQqY&rsz=filtered_cse&num=10&hl=en&prettyPrint=true&source=gcsc&gss=.com&sig=ee93f9aae9c9e9dba5eea831d506e69a&cx=018177143380893153305:yk0qpgydx_e&q='; url = url + keyword + '&start=' + startIndex; break; case 'SOSO': url = 'http://www.soso.com/q?query='; url = url + keyword + '+site%3Apan.baidu.com' + '&pg=' + parseInt(startIndex / 10, 10) + 1; break; default: console.log('error'); return 0; } //显示loading条 $('.wxz-content').html('<img src="" />'); $('#wxz_myDiv').slideDown(); GM_xmlhttpRequest({ method: "GET", url: url, headers: { "User-Agent": "Mozilla/5.0", // If not specified, navigator.userAgent will be used. "Accept": "text/xml" // If not specified, browser defaults will be used. }, onload: function(response) { var data, showList, tempNode, totalPage = 1, totalResults; switch (flag) { case 'Google': data = JSON.parse(response.responseText); break; case 'repigu': data = mirrorToData(response.responseText); break; case 'SOSO': data = sosoToData(response.responseText); break; default: console.log('error'); return 0; } totalResults = parseInt(data.cursor.estimatedResultCount, 10); //把json数据转为html,存入缓存showlist if (parseInt(data.cursor.resultCount, 10) === 0) { $('.wxz-content').html('<div class="loading-tips" align="center">无搜索结果...换个关键词重新试试?</div>'); } //无结果时提示 else { totalPage = parseInt((totalResults - 1) / 10, 10) + 1 > 10 ? 10 : parseInt((totalResults - 1) / 10, 10) + 1; //坑比,google自定义搜索只提供最大10页(每页10条) showList = "<p align='right'>---- by " + flag + ".com Search </p><p white-space='normal' class='temp' >keyword is '" + keyword + "' found '" + data.cursor.resultCount + "' Results</p><p>--------------------------------------------------<p>"; $.each(data.results, function(index, element) { tempNode = '<a href="' + element.unescapedUrl + '"target="_blank">' + element.titleNoFormatting + '</a>'; showList += '<p><p class="myTitle">' + tempNode + '</p>'; showList += '<p class="mySnippet">' + element.contentNoFormatting + '</p>'; }); showList += '<p><p>-------------------------------------------------------------<p class="temp" margin-left="20px">"' + data.results.length + '" items have been load </p>'; $('.wxz-content').html(showList); //替换原来内容,之所以用了showlist作为缓存是为了提升速度 $('.wxz-content').scrollTop(0); //滚到顶端 } addAboutInfo(info); pageBar(parseInt(startIndex / 10, 10) + 1, totalPage); data = null; tempNode = null; totalPage = null; totalResults = null; showList = null; }, onerror: function() { $('.wxz-content').html('<div class="loading-tips" align="center">出错了......</div>'); console.log("error"); return 0; } }); } function addAboutInfo(info) { var temp = '<p align="right"><a href="javascript:alert(' + "'" + info + "'" + ')" ><font color="#333">About me</font></a></p>'; $('.wxz-content').append(temp); } function mirrorToData(text){ var tempData=JSON.parse(text).responseData; var data = { cursor: { estimatedResultCount: 0, resultCount: 0 }, results: [] }; data.cursor.resultCount = parseInt(tempData.cursor.resultCount.replace(',', ''), 10); data.cursor.estimatedResultCount = data.cursor.resultCount; $.each(tempData.results, function(index, val) { var tempResult = { unescapedUrl: "", titleNoFormatting: "", contentNoFormatting: "" }; tempResult.unescapedUrl = val.unescapedUrl; tempResult.titleNoFormatting = val.titleNoFormatting; tempResult.contentNoFormatting = val.content; data.results.push(tempResult); /* iterate through array or object */ }); return data; } function sosoToData(html) { var begin = html.search('<div id="main" class="main">'), end = html.search('<div class="hintBox">'); var data = { cursor: { estimatedResultCount: 0, resultCount: 0 }, results: [] }, rbJquery = $(html.slice(begin, end)).find('.rb'); $.each(rbJquery, function(index, val) { if (index === 0) { data.cursor.resultCount = parseInt($(val).find('em').text().replace(',', ''), 10); data.cursor.estimatedResultCount = data.cursor.resultCount; } else { var tempResult = { unescapedUrl: "", titleNoFormatting: "", contentNoFormatting: "" }; tempResult.unescapedUrl = $(val).find("h3 a").attr('href'); tempResult.titleNoFormatting = $(val).find("h3 a").text(); tempResult.contentNoFormatting = $(val).find('div.ft').text(); data.results.push(tempResult); } /* iterate through array or object */ }); return data; } function pageBar(page, totalPage) { var html = '\ <div class="pagese "id="wxz-pagese">\ <a href="javascript:void(0)" class="page-prev mou-evt">上一页</a>\ <span class="page-content"></span>\ <a href="javascript:void(0)" class="page-next mou-evt">下一页</a>\ </div>\ ', pageNodeHtml = '<span class="page-number"></span>', i, c, startPage = 10 * parseInt((page - 1) / 10, 10) + 1; $('#wxz-pagese').replaceWith(html); c = $('#wxz-pagese').find('.page-content').eq(0); for (i = 0; i < 10; i++) { if (i + startPage > totalPage) { break; } if (i + startPage === page) { $(pageNodeHtml).html(i + startPage).addClass('global-disabled').appendTo(c); } else { $(pageNodeHtml).html(i + startPage) .bind('click', { msg: i + startPage }, function(e) { search(keyword, (e.data.msg - 1) * 10); }) .appendTo(c); } } if (page <= 1) { $('#wxz-pagese').find('.page-prev').eq(0).addClass('global-disabled'); } else { $('#wxz-pagese').find('.page-prev').eq(0).bind('click', { msg: page - 1 }, function(event) { search(keyword, (event.data.msg - 1) * 10); }); } if (page >= totalPage) { $('#wxz-pagese').find('.page-next').eq(0).addClass('global-disabled'); } else { $('#wxz-pagese').find('.page-next').eq(0).bind('click', { msg: page + 1 }, function(event) { search(keyword, (event.data.msg - 1) * 10); }); } html = null; pageNodeHtml = null; i = null; c = null; startPage = null; } function setUI() { //根据屏幕设置div的大小位置 var html_1 = '<li node-type="click-ele pos-ele" data-key="none" class="info-i show-item">\ <div class="search-form" id="wxz_searchForm"><input class="search-query" placeholder=" 搜索公开分享文件" id="wxz_input">\ <input type="button" value="GO" class="search-button" id="wxz_searchButton"></div></li>', //显示页面的html html_2 = '\ <div class="b-panel b-dialog share-dialog" id="wxz_myDiv" style="z-index:99">\ <div class="dlg-hd b-rlv" id="wxz_myDiv_title">\ <div title="关闭" id="wxz_closeButton" class="dlg-cnr dlg-cnr-r"></div>\ <h3 >搜索</h3>\ </div>\ <div class="wxz-content">\ </div>\ <div class="offline-bottom">\ <div class="offline-pageing">\ <div class="pagese " id="wxz-pagese">\ </div>\ </div>\ </div>\ </div>\ ', html_4='<li node-type="menu-nav" data-key="searcher" class="wxz-menu info-i wxz-dropdown has-pulldown">\ <em class="f-icon pull-arrow"></em>\ <span node-type="username" class="name top-username" id="wxzMenuDisplay" style="width: auto;">'+flag+'</span>\ <div node-type="menu-list" class="wxz-menu-content pulldown user-info" style="display: none;">\ <em class="arrow"></em>\ <div class="content" style="height:auto">\ <!--span node-type="click-ele" data-key="repigu" class="li wxz-menu-option">\ <a >by repigu</a>\ </span-->\ <span node-type="click-ele" data-key="SOSO" class="li wxz-menu-option">\ <a >by SOSO</a>\ </span>\ <span node-type="click-ele" data-key="Google" class="li wxz-menu-option">\ <a >by Google</a>\ </span>\ </div>\ </div>\ </li>\ ', cssText = '\ <style type="text/css">\ #wxz_searchButton{background-image:none;cursor:pointer;background-color: rgb(155, 154, 154);color: #ffffff;}\ .wxz-content{line-height: 200%;text-align: left;white-space: normal;margin-left:20px;overflow:auto;}\ .wxz-close{margin-right:20px;important;height:20px;cursor:pointer}\ .wxz-next{margin-right:20px;float:right;height:20px;cursor:pointer}\ .wxz-front{margin-right:40px;float:right;height:20px;cursor:pointer}\ .wxz-content a{color:#0066FF!important;font: 14px/1.5 arial,sans-serif!important;}\ </style>\ '; switch (replaceEle) { case '#top_menu_other': $('div.info.clearfix ul').prepend(html_1);//切换按钮 $(replaceEle).remove(); //删除搜索栏了广告 // $('div.info.clearfix ul').prepend(html_1);//搜索按钮 break; case 'div.remaining': $(replaceEle).before(html_1); $('#wxz_searchForm').addClass('side-options'); $('#wxz_searchButton').css({ width: 40 }); break; } $('div.info.clearfix ul').prepend(html_4);//切换按钮 $('body').append(html_2); $('head:first').append(cssText); //插入css //应用大小和页面 $('.wxz-content').css({ height: window.innerHeight / 3 * 2 }); $('#wxz_myDiv').css({ top: window.innerHeight / 8, left: window.innerWidth / 4 }); //应用拖拽 $("#wxz_myDiv").draggable({ handle: "#wxz_myDiv_title" }); } function bind() { //绑定各种函数 $('#wxz_searchButton').click(function() { keyword = $('#wxz_input').val(); search(keyword, 0); }); $('#wxz_closeButton').click(function() { searchClear(); }); $('.li.wxz-menu-option').click(function(){ flag=$(this).attr('data-key'); $('#wxzMenuDisplay').text(flag); $('.wxz-menu-content').hide(); }); $('#wxz_input').keyup(function(event) { if (event.which == 13) { $('#wxz_searchButton').trigger('click'); } }); } return { init: function(option) { var t = window.setInterval(function() { //百度云把一些内容放到后面加载,因此我设置了一个延时循环,每隔100ms选择一下所需的元素,当所需的元素存在时,开始脚本,同时停止延时循环 if ($(replaceEle).length > 0) { window.clearInterval(t); flag = option; setUI(); bind(); } console.log('waiting'); }, 100); }, }; }; //根据屏幕分辨率选择替换的元素 var ele = (window.innerWidth > 1024 ? '#top_menu_other' : 'div.remaining'); //启动 SearchObject(jQuery, ele).init('SOSO'); //to use original google, please replace parameter with 'Google';
QingJ © 2025
镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址