Greasy Fork is available in English.

百度云插件+APIKey

在百度云网盘的页面添加一个搜索框,调用搜索API搜索所有公开分享文件// To add a search frame that calls some api for searching some public shared files in BaiduYun cloud netdisk.

От 12.12.2015. Виж последната версия.

// ==UserScript==
// @name       百度云插件+APIKey
// @namespace  
// @version    4.4.4.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 wang0xinzhe@gmail.com. 
// @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.4.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 'Bing': 
                url = 'http://cn.bing.com/search?q=';//http://cn.bing.com/search?q=rk3368+site:pan.baidu.com;ie=utf-8 
                url = url + keyword + '+site%3Apan.baidu.com' + '&first=' + startIndex;
                break;
            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 'Repigu':
                url = 'https://repigu.com/search?q=';
                url = url + keyword + '+site:pan.baidu.com'+'&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.sogou.com/web?query=';
                url = url + keyword + '+site%3Apan.baidu.com' + '&page=' + 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 'Bing': 
                        data = bingToData(response.responseText);
                        break;
                    case 'repigu':
                        data = mirrorToData(response.responseText);
                        break;
                    case 'Repigu':
                        data = repiguToData(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 bingToData(html) { 
    var data = { cursor: { estimatedResultCount: 0, resultCount: 0 }, results: [] };
    //其中一条结果:
    //<li class="b_algo"><h2>
    //<a href="http://pan.baidu.com/wap/link?uk=2923110658&amp;shareid=3468815834&amp;third=3" target="_blank" h="ID=SERP,5101.1">YFK-<strong>RK3368</strong>-8189-20150821.rar_免费高速下载|百度云 网盘 ...</a></h2>
    //<div class="b_caption"><p>文件名:YFK-<strong>RK3368</strong>-8189-20150821.rar 文件大小:497.55M 分享者:晨芯FAE 分享时间:2015-8-21 14:07 下载次数:5 ... 登录百度云客户端送2T空间 电脑版</p>
    //<div class="b_attribution" u="0|5058|4835271386991248|8OMhcGIIj8GW08I41R5UoSyJpl2_5Pny"><cite><strong>pan.baidu.com</strong>/wap/link?uk=2923110658&amp;shareid=3468815834&amp;...</cite><span class="c_tlbxTrg">
    //<span class="c_tlbxH" H="BASE:CACHEDPAGEDEFAULT" K="SERP,5102.1"></span></span></div></div></li>
    //http://www.jb51.net/article/49083.htm在JS中解析HTML字符串示例代码:
    var el = $( '<div></div>' ); 
    el.html(html); 
    var b_results = $("#b_results", el);
    var b_algo_Arry = $("li.b_algo", b_results);
    $.each(b_algo_Arry, function(index, val) {
        var tempResult = {
            unescapedUrl: "",
            titleNoFormatting: "",
            contentNoFormatting: ""
        };
        tempResult.unescapedUrl = $(val).find("h2 a").attr('href');
        tempResult.titleNoFormatting = $(val).find("h2 a").text();
        tempResult.contentNoFormatting = $(val).find('div.b_caption p').text();
        data.results.push(tempResult);
    });
    ////处理统计结果
    var rawResultCount=$('.sb_count',b_results).text();
    var matchLst=[];    
    matchLst=rawResultCount.match(/([0-9]{1,3}(,[0-9]{3})+)/g);
    if(matchLst!==null){//匹配100,000,111之类的情况
        data.cursor.resultCount=matchLst[0].replace(',','');
    }else{
        matchLst=rawResultCount.match(/\d+/g);
        if(matchLst!==null){//匹配10 个结果之类的情况,以及1-11,共11个的情况
        data.cursor.resultCount=matchLst.pop();
        }else{//匹配无的情况
        data.cursor.resultCount=0;
        }
    }
    data.cursor.resultCount = parseInt( data.cursor.resultCount.toString(),10);
    data.cursor.estimatedResultCount = data.cursor.resultCount;
    return data;
}
    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 repiguToData(html) {
        // var begin = html.search('<div id="res">'),
        //     end = html.search('<div id="foot">');
        var data = {
                cursor: {
                    estimatedResultCount: 0,
                    resultCount: 0
                },
                results: []
            },
            rbJquery = $(html).find('.g');
        
        data.cursor.resultCount = parseInt($(html).find('#resultStats').text().slice(4).replace(',', ''), 10);
        data.cursor.estimatedResultCount = data.cursor.resultCount;

        $.each(rbJquery, function(index, val) {


                var tempResult = {
                    unescapedUrl: "",
                    titleNoFormatting: "",
                    contentNoFormatting: ""
                };
                tempResult.unescapedUrl = "https://repigu.com"+$(val).find("h3 a").attr('href');
                tempResult.titleNoFormatting = $(val).find("h3 a").text();
                tempResult.contentNoFormatting = $(val).find('.st').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="Bing" class="li wxz-menu-option">\
                            <a >by Bing</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 '#ad-header-tips':
                $('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 ? '#ad-header-tips' : 'div.remaining');

//启动
SearchObject(jQuery, ele).init('Bing'); //to use original google, please replace parameter with 'Google';