百度云插件+APIKey

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

As of 2015-11-18. See the latest version.

You will need to install an extension such as Tampermonkey, Greasemonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey or Userscripts to install this script.

You will need to install an extension such as Tampermonkey to install this script.

You will need to install a user script manager extension to install this script.

(I already have a user script manager, let me install it!)

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

(I already have a user style manager, let me install it!)

// ==UserScript==
// @name       百度云插件+APIKey
// @namespace  
// @version    4.4.4.0 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.4.0';

    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 '#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('Bing'); //to use original google, please replace parameter with 'Google';