Tampermonkey 是一款免费的浏览器扩展和最为流行的用户脚本管理器

Tampermonkey 是一款免费的浏览器扩展和最为流行的用户脚本管理器
1,360极速浏览器里的插件,输入:Tampermonkey
2,然后上搜索百度网盘(网址:https://tampermonkey.net/)。添加:百度网盘直接下载助手修改版
3,选中网盘中需要修改地址的视频或者资料

image.png

4,点击压缩链接-批量获取(http)


image.png

5,点击复制就可以复制到资料的压缩链接了。

这里值复制了链接,如果想复制资料名称的话那么就需要修改下脚本了,修改脚本为如下代码

// ==UserScript==
// @name 百度网盘直接下载助手修改版
// @version 2018.04.06
// @description 网盘内和分享页均显示[下载助手]按钮,支持获取直接下载链接+压缩下载链接;
// @description 大文件/单文件/多文件/文件夹,支持点击直接下载免强制调用百度网盘客户端;
// @author ivesjay、syhyz1990、网友们
// @supportURL https://github.com/syhyz1990/baiduyun
// @license MIT
// @date 2016-10-01
// @modified 2018-04-06
// @match ://pan.baidu.com/disk/home
// @match ://yun.baidu.com/disk/home
// @match ://pan.baidu.com/s/
// @match ://yun.baidu.com/s/
// @match ://pan.baidu.com/share/link
// @match ://yun.baidu.com/share/link
// @require https://cdn.bootcss.com/jquery/1.12.4/jquery.min.js
// @run-at document-end
// @grant unsafeWindow
// @grant GM_setClipboard
// @namespace undefined
// ==/UserScript==
(function () {
'use strict';

var $ = $ || window.$;
var log_count = 1;
var wordMapHttp = {
    'list-grid-switch': 'auiaQNyn',
    'list-switched-on': 'ksbXZm',
    'grid-switched-on': 'tch6W25',
    'list-switch': 'lrbo9a',
    'grid-switch': 'xh6poL',
    'checkbox': 'EOGexf',  //ok
    'chekbox-grid': 'cEefyz',
    'col-item': 'Qxyfvg',
    'check': 'fydGNC',
    'checked': 'EzubGg',
    'list-view': 'vdAfKMb',
    'item-active': 'xrmQgr8',
    'grid-view': 'JKvHJMb',
    'bar-search': 'OFaPaO',
    //'default-dom':'etr9DPv',
    //'bar':'ccjr9DVe',
    'list-tools': 'QDDOQB'
};
$(function () {
    wordMapHttp['default-dom'] = ($('.icon-upload').parent().parent().parent().parent().parent().attr('class'));
    wordMapHttp['bar'] = ($('.icon-upload').parent().parent().parent().parent().attr('class'));
});
var wordMapHttps = {
    'list-grid-switch': 'auiaQNyn',
    'list-switched-on': 'ewXm1e',
    'grid-switched-on': 'kxhkX2Em',
    'list-switch': 'rvpXm63',
    'grid-switch': 'mxgdJgwv',
    'checkbox': 'EOGexf',
    'col-item': 'Qxyfvg',
    'check': 'fydGNC',
    'checked': 'EzubGg',
    'chekbox-grid': 'cEefyz',
    'list-view': 'vdAfKMb',
    'item-active': 'xrmQgr8',
    'grid-view': 'JKvHJMb',
    'bar-search': 'OFaPaO',
    //'default-dom':'qkk3LED',
    //'bar':'cfj3L8W',
    'list-tools': 'QDDOQB'
};
var wordMap = location.protocol == 'http:' ? wordMapHttp : wordMapHttps;

//console.log(wordMap);

//替换网址为高级下载链接 默认不替换 http不用传
function replaceDownloadLink(link, http) {
    var http = http || false;
    //是否强制将https替换为http
    if (http) {
        return link.replace('https://d.pcs.baidu.com', 'http://yqall02.baidupcs.com');
    } else {
        return link.replace('d.pcs.baidu.com', 'yqall02.baidupcs.com');
    }
}

function slog(c1, c2, c3) {
    c1 = c1 ? c1 : '';
    c2 = c2 ? c2 : '';
    c3 = c3 ? c3 : '';
    console.log('#' + log_count++ + '-BaiDuNetdiskHelper-log:', c1, c2, c3);
}

$(function () {
    switch (detectPage()) {
        case 'disk':
            var panHelper = new PanHelper();
            panHelper.init();
            return;
        case 'share':
        case 's':
            var panShareHelper = new PanShareHelper();
            panShareHelper.init();
            return;
        default:
            return;
    }
});

//网盘页面的下载助手
function PanHelper() {
    var yunData, sign, timestamp, bdstoken, logid, fid_list;
    var fileList = [], selectFileList = [], batchLinkList = [], batchLinkListAll = [], linkList = [],
        list_grid_status = 'list';
    var observer, currentPage, currentPath, currentCategory, dialog, searchKey;
    var panAPIUrl = location.protocol + "//" + location.host + "/api/";
    var restAPIUrl = location.protocol + "//pcs.baidu.com/rest/2.0/pcs/";
    var clientAPIUrl = location.protocol + "//d.pcs.baidu.com/rest/2.0/pcs/";

    this.init = function () {
        yunData = unsafeWindow.yunData;
        slog('yunData:', yunData);
        if (yunData === undefined) {
            slog('页面未正常加载,或者百度已经更新!');
            return;
        }
        initParams();
        registerEventListener();
        createObserver();
        addButton();
        createIframe();
        dialog = new Dialog({addCopy: true});

        slog('网盘直接下载助手加载成功!');
    };

    function initParams() {
        sign = getSign();
        timestamp = getTimestamp();
        bdstoken = getBDStoken();
        logid = getLogID();
        currentPage = getCurrentPage();
        slog('Current display mode:', currentPage);

        if (currentPage == 'all')
            currentPath = getPath();

        if (currentPage == 'category')
            currentCategory = getCategory();

        if (currentPage == 'search')
            searchKey = getSearchKey();

        refreshListGridStatus();
        refreshFileList();
        refreshSelectList();
    }

    function refreshFileList() {
        if (currentPage == 'all') {
            fileList = getFileList();
        } else if (currentPage == 'category') {
            fileList = getCategoryFileList();
        } else if (currentPage == 'search') {
            fileList = getSearchFileList();
        }
    }

    function refreshSelectList() {
        selectFileList = [];
    }

    function refreshListGridStatus() {
        list_grid_status = getListGridStatus();
    }

    //获取当前的视图模式
    function getListGridStatus() {
        if ($('.grid-switched-on').length > 0) {
            return 'grid'
        } else {
            return 'list'
        }
    }

    function registerEventListener() {
        registerHashChange();
        registerListGridStatus();
        registerCheckbox();
        registerAllCheckbox();
        registerFileSelect();
    }

    //监视地址栏#标签的变化
    function registerHashChange() {
        window.addEventListener('hashchange', function (e) {
            refreshListGridStatus();

            if (getCurrentPage() == 'all') {
                if (currentPage == getCurrentPage()) {
                    if (currentPath == getPath()) {
                        return;
                    } else {
                        currentPath = getPath();
                        refreshFileList();
                        refreshSelectList();
                    }
                } else {
                    currentPage = getCurrentPage();
                    currentPath = getPath();
                    refreshFileList();
                    refreshSelectList();
                }
            } else if (getCurrentPage() == 'category') {
                if (currentPage == getCurrentPage()) {
                    if (currentCategory == getCategory()) {
                        return;
                    } else {
                        currentPage = getCurrentPage();
                        currentCategory = getCategory();
                        refreshFileList();
                        refreshSelectList();
                    }
                } else {
                    currentPage = getCurrentPage();
                    currentCategory = getCategory();
                    refreshFileList();
                    refreshSelectList();
                }
            } else if (getCurrentPage() == 'search') {
                if (currentPage == getCurrentPage()) {
                    if (searchKey == getSearchKey()) {
                        return;
                    } else {
                        currentPage = getCurrentPage();
                        searchKey = getSearchKey();
                        refreshFileList();
                        refreshSelectList();
                    }
                } else {
                    currentPage = getCurrentPage();
                    searchKey = getSearchKey();
                    refreshFileList();
                    refreshSelectList();
                }
            }
        });
    }

    //监视视图变化
    function registerListGridStatus() {
        var $a_list = $('a[data-type=list]');
        $a_list.click(function () {
            list_grid_status = 'list';
        });

        var $a_grid = $('a[data-type=grid]');
        $a_grid.click(function () {
            list_grid_status = 'grid';
        });
    }

    //文件选择框
    function registerCheckbox() {
        var $checkbox = $('span.' + wordMap['checkbox']);
        if (list_grid_status == 'grid') {
            $checkbox = $('.' + wordMap['chekbox-grid']);
        }

        //console.log($checkbox);
        $checkbox.each(function (index, element) {
            $(element).bind('click', function (e) {
                var $parent = $(this).parent();
                var filename;

                if (list_grid_status == 'list') {
                    filename = $('div.file-name div.text a', $parent).attr('title');
                } else if (list_grid_status == 'grid') {
                    filename = $('div.file-name a', $parent).attr('title');
                }
                //if($parent.hasClass('item-active')){
                //if($parent.hasClass('prWzXA')){
                //console.log(fileList);
                if ($parent.hasClass(wordMap['item-active'])) {
                    slog('取消选中文件:' + filename);
                    for (var i = 0; i < selectFileList.length; i++) {
                        if (selectFileList[i].filename == filename) {
                            selectFileList.splice(i, 1);
                        }
                    }
                } else {
                    slog('选中文件:' + filename);
                    //console.log(fileList);
                    $.each(fileList, function (index, element) {
                        if (element.server_filename == filename) {
                            var obj = {
                                filename: element.server_filename,
                                path: element.path,
                                fs_id: element.fs_id,
                                isdir: element.isdir
                            };
                            selectFileList.push(obj);
                        }
                    });
                }
            });
        });
    }

    function unregisterCheckbox() {
        //var $checkbox = $('span.checkbox');
        //var $checkbox = $('span.EOGexf');
        var $checkbox = $('span.' + wordMap['checkbox']);
        $checkbox.each(function (index, element) {
            $(element).unbind('click');
        });
    }

    //全选框
    function registerAllCheckbox() {
        //var $checkbox = $('div.col-item.check');
        //var $checkbox = $('div.Qxyfvg.fydGNC');
        var $checkbox = $('div.' + wordMap['col-item'] + '.' + wordMap['check']);
        $checkbox.each(function (index, element) {
            $(element).bind('click', function (e) {
                var $parent = $(this).parent();
                //if($parent.hasClass('checked')){
                //if($parent.hasClass('EzubGg')){
                if ($parent.hasClass(wordMap['checked'])) {
                    slog('取消全选');
                    selectFileList = [];
                } else {
                    slog('全部选中');
                    selectFileList = [];
                    $.each(fileList, function (index, element) {
                        var obj = {
                            filename: element.server_filename,
                            path: element.path,
                            fs_id: element.fs_id,
                            isdir: element.isdir
                        };
                        selectFileList.push(obj);
                    });
                }
            });
        });
    }

    function unregisterAllCheckbox() {
        //var $checkbox = $('div.col-item.check');
        //var $checkbox = $('div.Qxyfvg.fydGNC');
        var $checkbox = $('div.' + wordMap['col-item'] + '.' + wordMap['check']);
        $checkbox.each(function (index, element) {
            $(element).unbind('click');
        });
    }

    //单个文件选中,点击文件不是点击选中框,会只选中该文件
    function registerFileSelect() {
        //var $dd = $('div.list-view dd');
        //var $dd = $('div.vdAfKMb dd');
        var $dd = $('div.' + wordMap['list-view'] + ' dd');
        $dd.each(function (index, element) {
            $(element).bind('click', function (e) {
                var nodeName = e.target.nodeName.toLowerCase();
                if (nodeName != 'span' && nodeName != 'a' && nodeName != 'em') {
                    slog('shiftKey:' + e.shiftKey);
                    if (!e.shiftKey) {
                        selectFileList = [];
                        var filename = $('div.file-name div.text a', $(this)).attr('title');
                        slog('选中文件:' + filename);
                        $.each(fileList, function (index, element) {
                            if (element.server_filename == filename) {
                                var obj = {
                                    filename: element.server_filename,
                                    path: element.path,
                                    fs_id: element.fs_id,
                                    isdir: element.isdir
                                };
                                selectFileList.push(obj);
                            }
                        });
                    } else {
                        selectFileList = [];
                        //var $dd_select = $('div.list-view dd.item-active');
                        //var $dd_select = $('div.vdAfKMb dd.prWzXA');
                        var $dd_select = $('div.' + wordMap['list-view'] + ' dd.' + wordMap['item-active']);
                        $.each($dd_select, function (index, element) {
                            var filename = $('div.file-name div.text a', $(element)).attr('title');
                            slog('选中文件:' + filename);
                            $.each(fileList, function (index, element) {
                                if (element.server_filename == filename) {
                                    var obj = {
                                        filename: element.server_filename,
                                        path: element.path,
                                        fs_id: element.fs_id,
                                        isdir: element.isdir
                                    };
                                    selectFileList.push(obj);
                                }
                            });
                        });
                    }
                }
            });
        });
    }

    function unregisterFileSelect() {
        //var $dd = $('div.list-view dd');
        //var $dd = $('div.vdAfKMb dd');
        var $dd = $('div.' + wordMap['list-view'] + ' dd');
        $dd.each(function (index, element) {
            $(element).unbind('click');
        });
    }

    //监视文件列表显示变化
    function createObserver() {
        var MutationObserver = window.MutationObserver;
        var options = {
            'childList': true
        };
        observer = new MutationObserver(function (mutations) {
            unregisterCheckbox();
            unregisterAllCheckbox();
            unregisterFileSelect();
            registerCheckbox();
            registerAllCheckbox();
            registerFileSelect();
        });

        //var list_view = document.querySelector('.list-view');
        //var grid_view = document.querySelector('.grid-view');

        //var list_view = document.querySelector('.vdAfKMb');
        //var grid_view = document.querySelector('.JKvHJMb');

        var list_view = document.querySelector('.' + wordMap['list-view']);
        var grid_view = document.querySelector('.' + wordMap['grid-view']);

        //console.log(list_view);
        observer.observe(list_view, options);
        observer.observe(grid_view, options);
    }

    //添加助手按钮
    function addButton() {
        //$('div.bar-search').css('width','18%');//修改搜索框的宽度,避免遮挡
        //$('div.OFaPaO').css('width','18%');
        $('div.' + wordMap['bar-search']).css('width', '18%');
        var $dropdownbutton = $('<span class="g-dropdown-button"></span>');
        var $dropdownbutton_a = $('<a class="g-button" href="javascript:void(0);"><span class="g-button-right"><em class="icon icon-download" title="百度网盘下载助手"></em><span class="text" style="width: auto;">下载助手</span></span></a>');
        var $dropdownbutton_span = $('<span class="menu" style="width:96px"></span>');

        var $directbutton = $('<span class="g-button-menu" style="display:block"></span>');
        var $directbutton_span = $('<span class="g-dropdown-button g-dropdown-button-second" menulevel="2"></span>');
        var $directbutton_a = $('<a class="g-button" href="javascript:void(0);"><span class="g-button-right"><span class="text" style="width:auto">下载链接</span></span></a>');
        var $directbutton_menu = $('<span class="menu" style="width:120px;left:79px"></span>');
        var $directbutton_download_button = $('<a id="download-direct" class="g-button-menu" href="javascript:void(0);">点击直接下载</a>');
        var $directbutton_link_button = $('<a id="link-direct" class="g-button-menu" href="javascript:void(0);">获取下载链接</a>');
        var $directbutton_batchhttplink_button = $('<a id="batchhttplink-direct" class="g-button-menu" href="javascript:void(0);">批量获取(HTTP)</a>');
        var $directbutton_batchhttpslink_button = $('<a id="batchhttpslink-direct" class="g-button-menu" href="javascript:void(0);">批量获取(HTTPS)</a>');
        $directbutton_menu.append($directbutton_download_button).append($directbutton_link_button).append($directbutton_batchhttplink_button).append($directbutton_batchhttpslink_button);
        $directbutton.append($directbutton_span.append($directbutton_a).append($directbutton_menu));
        $directbutton.hover(function () {
            $directbutton_span.toggleClass('button-open');
        });
        $directbutton_download_button.click(downloadClick);
        $directbutton_link_button.click(linkClick);
        $directbutton_batchhttplink_button.click(batchClick);
        $directbutton_batchhttpslink_button.click(batchClick);

        var $apibutton = $('<span class="g-button-menu" style="display:block"></span>');
        var $apibutton_span = $('<span class="g-dropdown-button g-dropdown-button-second" menulevel="2"></span>');
        var $apibutton_a = $('<a class="g-button" href="javascript:void(0);"><span class="g-button-right"><span class="text" style="width:auto">压缩链接</span></span></a>');
        var $apibutton_menu = $('<span class="menu" style="width:120px;left:77px"></span>');
        var $apibutton_download_button = $('<a id="download-api" class="g-button-menu" href="javascript:void(0);">点击直接下载</a>');
        var $apibutton_link_button = $('<a id="httplink-api" class="g-button-menu" href="javascript:void(0);">获取压缩链接</a>');
        var $apibutton_batchhttplink_button = $('<a id="batchhttplink-api" class="g-button-menu" href="javascript:void(0);">批量获取(HTTP)</a>');
        var $apibutton_batchhttpslink_button = $('<a id="batchhttpslink-api" class="g-button-menu" href="javascript:void(0);">批量获取(HTTPS)</a>');
        $apibutton_menu.append($apibutton_download_button).append($apibutton_link_button).append($apibutton_batchhttplink_button).append($apibutton_batchhttpslink_button);
        $apibutton.append($apibutton_span.append($apibutton_a).append($apibutton_menu));
        $apibutton.hover(function () {
            $apibutton_span.toggleClass('button-open');
        });
        $apibutton_download_button.click(downloadClick);
        $apibutton_link_button.click(linkClick);
        $apibutton_batchhttplink_button.click(batchClick);
        $apibutton_batchhttpslink_button.click(batchClick);

        var $outerlinkbutton = $('<span class="g-button-menu" style="display:none"></span>');  //改为block显示外链下载
        var $outerlinkbutton_span = $('<span class="g-dropdown-button g-dropdown-button-second" menulevel="2"></span>');
        var $outerlinkbutton_a = $('<a class="g-button" href="javascript:void(0);"><span class="g-button-right"><span class="text" style="width:auto">外链下载</span></span></a>');
        var $outerlinkbutton_menu = $('<span class="menu" style="width:120px;left:79px"></span>');
        var $outerlinkbutton_download_button = $('<a id="download-outerlink" class="g-button-menu" href="javascript:void(0);">下载</a>');
        var $outerlinkbutton_link_button = $('<a id="link-outerlink" class="g-button-menu" href="javascript:void(0);">显示链接</a>');
        var $outerlinkbutton_batchlink_button = $('<a id="batchlink-outerlink" class="g-button-menu" href="javascript:void(0);">批量链接</a>');
        $outerlinkbutton_menu.append($outerlinkbutton_download_button).append($outerlinkbutton_link_button).append($outerlinkbutton_batchlink_button);
        $outerlinkbutton.append($outerlinkbutton_span.append($outerlinkbutton_a).append($outerlinkbutton_menu));
        $outerlinkbutton.hover(function () {
            $outerlinkbutton_span.toggleClass('button-open');
        });
        $outerlinkbutton_download_button.click(downloadClick);
        $outerlinkbutton_link_button.click(linkClick);
        $outerlinkbutton_batchlink_button.click(batchClick);

        $dropdownbutton_span.append($directbutton).append($apibutton).append($outerlinkbutton);
        $dropdownbutton.append($dropdownbutton_a).append($dropdownbutton_span);

        $dropdownbutton.hover(function () {
            $dropdownbutton.toggleClass('button-open');
        });

        $('div.' + wordMap['default-dom'] + ' div.' + wordMap['bar'] + ' div.' + wordMap['list-tools']).prepend($dropdownbutton);
        $('div.' + wordMap['list-tools']).prepend($dropdownbutton)
    }

    // 我的网盘选择文件下载下载
    function downloadClick(event) {
        //console.log('downloadClick');
        slog('选中文件列表:', selectFileList);
        var id = event.target.id;
        var downloadLink;

        if (id == 'download-direct') {
            var downloadType;
            if (selectFileList.length === 0) {
                alert("获取选中文件失败,请刷新重试!");
                return;
            } else if (selectFileList.length == 1) {
                if (selectFileList[0].isdir === 1)
                    downloadType = 'batch';
                else if (selectFileList[0].isdir === 0)
                    downloadType = 'dlink';
                //downloadType = selectFileList[0].isdir==1?'batch':(selectFileList[0].isdir===0?'dlink':'batch');
            } else if (selectFileList.length > 1) {
                downloadType = 'batch';
            }

            fid_list = getFidList(selectFileList);
            var result = getDownloadLinkWithPanAPI(downloadType);
            if (result.errno === 0) {
                if (downloadType == 'dlink')
                    downloadLink = result.dlink[0].dlink;
                else if (downloadType == 'batch') {
                    downloadLink = result.dlink;
                    if (selectFileList.length === 1)
                        downloadLink = downloadLink + '&zipname=' + encodeURIComponent(selectFileList[0].filename) + '.zip';
                }
                else {
                    alert("发生错误!");
                    return;
                }
            } else if (result.errno == -1) {
                alert('文件不存在或已被百度和谐,无法下载!');
                return;
            } else if (result.errno == 112) {
                alert("页面过期,请刷新重试!");
                return;
            } else {
                alert("发生错误!");
                return;
            }
        } else {
            if (selectFileList.length === 0) {
                alert("获取选中文件失败,请刷新重试!");
                return;
            } else if (selectFileList.length > 1) {
                alert("该方法不支持获取多文件下载链接!");
                return;
            } else {
                if (selectFileList[0].isdir == 1) {
                    alert("该方法不支持获取文件夹下载链接!");
                    return;
                }
            }
            if (id == 'download-api') {
                downloadLink = getDownloadLinkWithRESTAPIBaidu(selectFileList[0].path);
            } else if (id == 'download-outerlink') {
                var result = getDownloadLinkWithClientAPI(selectFileList[0].path);
                if (result.errno == 0) {
                    downloadLink = result.urls[0].url;
                } else if (result.errno == 1) {
                    alert('文件不存在!');
                    return;
                } else if (result.errno == 2) {
                    alert('文件不存在或者已被百度和谐,无法下载!');
                    return;
                } else {
                    alert('发生错误!');
                    return;
                }
            }
        }
        execDownload(downloadLink);
    }

    //我的网盘 - 获取下载链接
    function linkClick(event) {
        //console.log('linkClick');
        slog('选中文件列表:', selectFileList);
        var id = event.target.id;
        var linkList, tip;

        if (id.indexOf('direct') != -1) {
            var downloadType;
            var downloadLink;
            if (selectFileList.length === 0) {
                alert("获取选中文件失败,请刷新重试!");
                return;
            } else if (selectFileList.length == 1) {
                if (selectFileList[0].isdir === 1)
                    downloadType = 'batch';
                else if (selectFileList[0].isdir === 0)
                    downloadType = 'dlink';
            } else if (selectFileList.length > 1) {
                downloadType = 'batch';
            }
            fid_list = getFidList(selectFileList);
            var result = getDownloadLinkWithPanAPI(downloadType);
            if (result.errno === 0) {
                if (downloadType == 'dlink')
                    downloadLink = result.dlink[0].dlink;
                else if (downloadType == 'batch') {
                    slog(selectFileList);
                    downloadLink = result.dlink;
                    if (selectFileList.length === 1)
                        downloadLink = downloadLink + '&zipname=' + encodeURIComponent(selectFileList[0].filename) + '.zip';
                }
                else {
                    alert("发生错误!");
                    return;
                }
            } else if (result.errno == -1) {
                alert('文件不存在或已被百度和谐,无法下载!');
                return;
            } else if (result.errno == 112) {
                alert("页面过期,请刷新重试!");
                return;
            } else {
                alert("发生错误!");
                return;
            }
            var httplink = downloadLink.replace(/^([A-Za-z]+):/, 'http:');
            //httplink = replaceDownloadLink(httplink);
            var httpslink = downloadLink.replace(/^([A-Za-z]+):/, 'https:');
            //httpslink = replaceDownloadLink(httpslink);
            var filename = '';
            $.each(selectFileList, function (index, element) {
                if (selectFileList.length == 1)
                    filename = element.filename;
                else {
                    if (index == 0)
                        filename = element.filename;
                    else
                        filename = filename + ',' + element.filename;
                }
            });
            linkList = {
                filename: filename,
                urls: [
                    {url: httplink, rank: 1},
                    {url: httpslink, rank: 2}
                ]
            };
            tip = '提示:单文件获取的是没有压缩的下载直链,多文件和文件夹获取的是打包压缩的下载直链。//压缩的下载直链可用下载工具下载超级加速!';
            dialog.open({title: '下载链接', type: 'link', list: linkList, tip: tip});
        } else {
            if (selectFileList.length === 0) {
                alert("获取选中文件失败,请刷新重试!");
                return;
            } else if (selectFileList.length > 1) {
                alert("该方法不支持多文件下载!");
                return;
            } else {
                if (selectFileList[0].isdir == 1) {
                    alert("该方法不支持目录下载!");
                    return;
                }
            }
            if (id.indexOf('api') != -1) {
                var downloadLink = getDownloadLinkWithRESTAPIBaidu(selectFileList[0].path);
                var httplink = downloadLink.replace(/^([A-Za-z]+):/, 'http:');
                var httpslink = downloadLink.replace(/^([A-Za-z]+):/, 'https:');
                linkList = {
                    filename: selectFileList[0].filename,
                    urls: [
                        {url: httplink, rank: 1},
                        {url: httpslink, rank: 2}
                    ]
                };
                httplink = httplink.replace('250528', '266719');
                httpslink = httpslink.replace('250528', '266719');
                linkList.urls.push({url: httplink, rank: 3});
                linkList.urls.push({url: httpslink, rank: 4});
                tip = '注意:不支持多文件/文件夹获取打包压缩链接!压缩直链可以用下载工具超级加速,复制到下载工具需传递Cookie。';
                dialog.open({title: '压缩下载链接', type: 'link', list: linkList, tip: tip});
            } else if (id.indexOf('outerlink') != -1) {
                var result = getDownloadLinkWithClientAPI(selectFileList[0].path);
                if (result.errno == 0) {
                    linkList = {
                        filename: selectFileList[0].filename,
                        urls: result.urls
                    };
                } else if (result.errno == 1) {
                    alert('文件不存在!');
                    return;
                } else if (result.errno == 2) {
                    alert('文件不存在或者已被百度和谐,无法下载!');
                    return;
                } else {
                    alert('发生错误!');
                    return;
                }
                tip = '提示:获取打包压缩链接不支持多文件及文件夹!压缩下载链接可以用下载工具超级加速,不需要传递Cookie。';
                dialog.open({
                    title: '下载链接',
                    type: 'link',
                    list: linkList,
                    tip: tip,
                    showcopy: true,
                    showedit: true
                });
            }
        }
        //dialog.open({title:'下载链接',type:'link',list:linkList,tip:tip});
    }

    // 我的网盘 - 批量下载
    function batchClick(event) {
        //console.log('batchClick');
        slog('选中文件列表:', selectFileList);
        if (selectFileList.length === 0) {
            alert('获取选中文件失败,请刷新重试!');
            return;
        }
        var id = event.target.id;
        var linkType, tip;
        linkType = id.indexOf('https') == -1 ? (id.indexOf('http') == -1 ? location.protocol + ':' : 'http:') : 'https:';
        batchLinkList = [];
        batchLinkListAll = [];
        if (id.indexOf('direct') != -1) {
            batchLinkList = getDirectBatchLink(linkType);
            tip = '提示:这里是批量获取的所有选中文件的直接下载链接,多文件/文件夹是打包压缩的下载直链。';
            if (batchLinkList.length === 0) {
                alert('没有链接可以显示,API链接不要全部选中文件夹!');
                return;
            }
            dialog.open({title:'批量获取链接',type:'batch',list:batchLinkList,tip:tip,showcopy:true});
        } else if (id.indexOf('api') != -1) {
            batchLinkList = getAPIBatchLink(linkType);
            tip = '提示:这里不支持获取多文件/文件夹的打包压缩下载链接,仅显示所有选中单文件的压缩下载直链';
            if (batchLinkList.length === 0) {
                alert('没有链接可以显示,API链接不要全部选中文件夹!');
                return;
            }
            dialog.open({title: '批量获取链接', type: 'batch', list: batchLinkList, tip: tip, showcopy: true});
        } else if (id.indexOf('outerlink') != -1) {
            batchLinkListAll = getOuterlinkBatchLinkAll();
            batchLinkList = getOuterlinkBatchLinkFirst(batchLinkListAll);
            tip = '显示所有选中文件的外部下载链接,不显示文件夹';
            if (batchLinkList.length === 0) {
                alert('没有链接可以显示,API链接不要全部选中文件夹!');
                return;
            }

            dialog.open({
                title: '获取链接',
                type: 'batch',
                list: batchLinkList,
                tip: tip,
                showcopy: true,
                alllist: batchLinkListAll,
                showall: true
            });
        }

        //dialog.open({title:'批量获取链接',type:'batch',list:batchLinkList,tip:tip,showcopy:true});
    }

    function getDirectBatchLink(linkType) {
        var list = [];
        $.each(selectFileList, function (index, element) {
            var downloadType, downloadLink, result;
            if (element.isdir == 0)
                downloadType = 'dlink';
            else
                downloadType = 'batch';
            fid_list = getFidList([element]);
            result = getDownloadLinkWithPanAPI(downloadType);
            if (result.errno == 0) {
                if (downloadType == 'dlink')
                    downloadLink = result.dlink[0].dlink;
                else if (downloadType == 'batch')
                    downloadLink = result.dlink;
                downloadLink = downloadLink.replace(/^([A-Za-z]+):/, linkType);
                //downloadLink = replaceDownloadLink(downloadLink);
            } else {
                downloadLink = 'error';
            }
            list.push({filename: element.filename, downloadlink: downloadLink});
        });
        return list;
    }

    function getAPIBatchLink(linkType) {
        var list = [];
        $.each(selectFileList, function (index, element) {
            if (element.isdir == 1)
                return;
            var downloadLink;
            downloadLink = getDownloadLinkWithRESTAPIBaidu(element.path);
            downloadLink = downloadLink.replace(/^([A-Za-z]+):/, linkType);
            list.push({filename: element.filename, downloadlink: downloadLink});
        });
        return list;
    }

    function getOuterlinkBatchLinkAll() {
        var list = [];
        $.each(selectFileList, function (index, element) {
            var result;
            if (element.isdir == 1)
                return;
            result = getDownloadLinkWithClientAPI(element.path);
            if (result.errno == 0) {
                list.push({filename: element.filename, links: result.urls});
            } else {
                list.push({filename: element.filename, links: [{rank: 1, url: 'error'}]});
            }
        });
        return list;
    }

    function getOuterlinkBatchLinkFirst(list) {
        var result = [];
        $.each(list, function (index, element) {
            result.push({filename: element.filename, downloadlink: element.links[0].url});
        });
        return result;
    }

    function getSign() {
        var signFnc;
        try {
            signFnc = new Function("return " + yunData.sign2)();
        } catch (e) {
            throw new Error(e.message);
        }
        return base64Encode(signFnc(yunData.sign5, yunData.sign1));
    }

    //获取当前目录
    function getPath() {
        var hash = location.hash;
        var regx = new RegExp("path=([^&]*)(&|$)", 'i');
        var result = hash.match(regx);
        //console.log(result);
        return decodeURIComponent(result[1]);
    }

    //获取分类显示的类别,即地址栏中的type
    function getCategory() {
        var hash = location.hash;
        var regx = new RegExp("path=([^&]*)(&|$)", 'i');
        var result = hash.match(regx);
        return decodeURIComponent(result[1]);
    }

    function getSearchKey() {
        var hash = location.hash;
        var regx = new RegExp("key=([^&]*)(&|$)", 'i');
        var result = hash.match(regx);
        return decodeURIComponent(result[1]);
    }

    //获取当前页面(all或者category或search)
    function getCurrentPage() {
        var hash = location.hash;
        //console.log(hash.substring(hash.indexOf('#') + 2, hash.indexOf('?')));
        return hash.substring(hash.indexOf('#') + 2, hash.indexOf('?'));
    }

    //获取文件列表
    function getFileList() {
        var filelist = [];
        var listUrl = panAPIUrl + "list";
        var path = getPath();
        logid = getLogID();
        var params = {
            dir: path,
            bdstoken: bdstoken,
            logid: logid,
            order: 'size',
            desc: 0,
            clienttype: 0,
            showempty: 0,
            web: 1,
            channel: 'chunlei',
            appid: 250528
        };

        $.ajax({
            url: listUrl,
            async: false,
            method: 'GET',
            data: params,
            success: function (response) {
                filelist = 0 === response.errno ? response.list : [];
            }
        });
        return filelist;
    }

    //获取分类页面下的文件列表
    function getCategoryFileList() {
        var filelist = [];
        var listUrl = panAPIUrl + "categorylist";
        var category = getCategory();
        logid = getLogID();
        var params = {
            category: category,
            bdstoken: bdstoken,
            logid: logid,
            order: 'size',
            desc: 0,
            clienttype: 0,
            showempty: 0,
            web: 1,
            channel: 'chunlei',
            appid: 250528
        };
        $.ajax({
            url: listUrl,
            async: false,
            method: 'GET',
            data: params,
            success: function (response) {
                filelist = 0 === response.errno ? response.info : [];
            }
        });
        return filelist;
    }

    function getSearchFileList() {
        var filelist = [];
        var listUrl = panAPIUrl + 'search';
        logid = getLogID();
        searchKey = getSearchKey();
        var params = {
            recursion: 1,
            order: 'time',
            desc: 1,
            showempty: 0,
            web: 1,
            page: 1,
            num: 100,
            key: searchKey,
            channel: 'chunlei',
            app_id: 250528,
            bdstoken: bdstoken,
            logid: logid,
            clienttype: 0
        };
        $.ajax({
            url: listUrl,
            async: false,
            method: 'GET',
            data: params,
            success: function (response) {
                filelist = 0 === response.errno ? response.list : [];
            }
        });
        return filelist;
    }

    //生成下载时的fid_list参数
    function getFidList(list) {
        var fidlist = null;
        if (list.length === 0)
            return null;
        var fileidlist = [];
        $.each(list, function (index, element) {
            fileidlist.push(element.fs_id);
        });
        fidlist = '[' + fileidlist + ']';
        return fidlist;
    }

    function getTimestamp() {
        return yunData.timestamp;
    }

    function getBDStoken() {
        return yunData.MYBDSTOKEN;
    }

    //获取直接下载地址
    //这个地址不是直接下载地址,访问这个地址会返回302,response header中的location才是真实下载地址
    //暂时没有找到提取方法
    function getDownloadLinkWithPanAPI(type) {
        var downloadUrl = panAPIUrl + "download";
        var result;
        logid = getLogID();
        var params = {
            sign: sign,
            timestamp: timestamp,
            fidlist: fid_list,
            type: type,
            channel: 'chunlei',
            web: 1,
            app_id: 250528,
            bdstoken: bdstoken,
            logid: logid,
            clienttype: 0
        };
        $.ajax({
            url: downloadUrl,
            async: false,
            method: 'GET',
            data: params,
            success: function (response) {
                result = response;
            }
        });
        return result;
    }

    function getDownloadLinkWithRESTAPIBaidu(path) {
        var link = restAPIUrl + 'file?method=download&app_id=250528&path=' + encodeURIComponent(path);
        return link;
    }

    function getDownloadLinkWithRESTAPIES(path) {
        var link = restAPIUrl + 'file?method=download&app_id=266719&path=' + encodeURIComponent(path);
        return link;
    }

    function getDownloadLinkWithClientAPI(path) {
        var result;
        var url = clientAPIUrl + 'file?method=locatedownload&app_id=250528&ver=4.0&path=' + encodeURIComponent(path);
        $.ajax({
            url: url,
            method: 'POST',
            xhrFields: {
                withCredentials: true
            },
            async: false,
            success: function (response) {
                result = JSON.parse(response);
            },
            statusCode: {
                404: function (response) {
                    result = response;
                }
            }
        });
        if (result) {
            if (result.error_code == undefined) {
                if (result.urls == undefined) {
                    result.errno = 2;
                } else {
                    $.each(result.urls, function (index, element) {
                        result.urls[index].url = element.url.replace('\\', '');
                    });
                    result.errno = 0;
                }
            } else if (result.error_code == 31066) {
                result.errno = 1;
            } else {
                result.errno = -1;
            }
        } else {
            result = {};
            result.errno = -1;
        }
        return result;
    }

    function execDownload(link) {
        slog("下载链接:" + link);
        $('#helperdownloadiframe').attr('src', link);
    }

    function createIframe() {
        var $div = $('<div class="helper-hide" style="padding:0;margin:0;display:block"></div>');
        var $iframe = $('<iframe src="javascript:void(0)" id="helperdownloadiframe" style="display:none"></iframe>');
        $div.append($iframe);
        $('body').append($div);

    }
}

//分享页面的下载助手
function PanShareHelper() {
    var yunData, sign, timestamp, bdstoken, channel, clienttype, web, app_id, logid, encrypt, product, uk,
        primaryid, fid_list, extra, shareid;
    var vcode;
    var shareType, buttonTarget, currentPath, list_grid_status, observer, dialog, vcodeDialog;
    var fileList = [], selectFileList = [];
    var panAPIUrl = location.protocol + "//" + location.host + "/api/";
    var shareListUrl = location.protocol + "//" + location.host + "/share/list";

    this.init = function () {
        yunData = unsafeWindow.yunData;
        slog('yunData:', yunData);
        if (yunData === undefined || yunData.FILEINFO == null) {
            slog('页面未正常加载,或者百度已经更新!');
            return;
        }
        initParams();
        addButton();
        dialog = new Dialog({addCopy: false});
        vcodeDialog = new VCodeDialog(refreshVCode, confirmClick);
        createIframe();

        if (!isSingleShare()) {
            registerEventListener();
            createObserver();
        }

        slog('分享直接下载加载成功!');
    };

    function initParams() {
        shareType = getShareType();
        sign = yunData.SIGN;
        timestamp = yunData.TIMESTAMP;
        bdstoken = yunData.MYBDSTOKEN;
        channel = 'chunlei';
        clienttype = 0;
        web = 1;
        app_id = 250528;
        logid = getLogID();
        encrypt = 0;
        product = 'share';
        primaryid = yunData.SHARE_ID;
        uk = yunData.SHARE_UK;

        if (shareType == 'secret') {
            extra = getExtra();
        }
        if (isSingleShare()) {
            var obj = {};
            if (yunData.CATEGORY == 2) {
                obj.filename = yunData.FILENAME;
                obj.path = yunData.PATH;
                obj.fs_id = yunData.FS_ID;
                obj.isdir = 0;
            } else {
                obj.filename = yunData.FILEINFO[0].server_filename,
                    obj.path = yunData.FILEINFO[0].path,
                    obj.fs_id = yunData.FILEINFO[0].fs_id,
                    obj.isdir = yunData.FILEINFO[0].isdir
            }
            selectFileList.push(obj);
        } else {
            shareid = yunData.SHARE_ID;
            currentPath = getPath();
            list_grid_status = getListGridStatus();
            fileList = getFileList();
        }
    }

    //判断分享类型(public或者secret)
    function getShareType() {
        return yunData.SHARE_PUBLIC === 1 ? 'public' : 'secret';
    }

    //判断是单个文件分享还是文件夹或者多文件分享
    function isSingleShare() {
        return yunData.getContext === undefined ? true : false;
    }

    //判断是否为自己的分享链接
    function isSelfShare() {
        return yunData.MYSELF == 1 ? true : false;
    }

    function getExtra() {
        var seKey = decodeURIComponent(getCookie('BDCLND'));
        return '{' + '"sekey":"' + seKey + '"' + "}";
    }

    //获取当前目录
    function getPath() {
        var hash = location.hash;
        var regx = new RegExp("path=([^&]*)(&|$)", 'i');
        var result = hash.match(regx);
        return decodeURIComponent(result[1]);
    }

    //获取当前的视图模式
    function getListGridStatus() {
        var status = 'list';
        if ($('.list-switched-on').length > 0) {
            status = 'list';
        } else if ($('.grid-switched-on').length > 0) {
            status = 'grid';
        }
        return status;
    }

    //添加下载助手按钮
    function addButton() {
        if (isSingleShare()) {
            $('div.slide-show-right').css('width', '500px');
            $('div.frame-main').css('width', '96%');
            $('div.share-file-viewer').css('width', '740px').css('margin-left', 'auto').css('margin-right', 'auto');
        }
        else
            $('div.slide-show-right').css('width', '500px');
        var $dropdownbutton = $('<span class="g-dropdown-button"></span>');
        var $dropdownbutton_a = $('<a class="g-button" data-button-id="b200" data-button-index="200" href="javascript:void(0);"></a>');
        var $dropdownbutton_a_span = $('<span class="g-button-right"><em class="icon icon-download" title="百度网盘下载助手"></em><span class="text" style="width: auto;">下载助手</span></span>');
        var $dropdownbutton_span = $('<span class="menu" style="width:auto;z-index:41"></span>');

        var $downloadButton = $('<a data-menu-id="b-menu207" class="g-button-menu" href="javascript:void(0);">点击直接下载</a>');
        var $linkButton = $('<a data-menu-id="b-menu208" class="g-button-menu" href="javascript:void(0);">获取下载链接</a>');

        $dropdownbutton_span.append($downloadButton).append($linkButton);
        $dropdownbutton_a.append($dropdownbutton_a_span);
        $dropdownbutton.append($dropdownbutton_a).append($dropdownbutton_span);

        $dropdownbutton.hover(function () {
            $dropdownbutton.toggleClass('button-open');
        });

        $downloadButton.click(downloadButtonClick);
        $linkButton.click(linkButtonClick);

        $('div.module-share-top-bar div.bar div.x-button-box').append($dropdownbutton);
    }

    function createIframe() {
        var $div = $('<div class="helper-hide" style="padding:0;margin:0;display:block"></div>');
        var $iframe = $('<iframe src="javascript:void(0)" id="helperdownloadiframe" style="display:none"></iframe>');
        $div.append($iframe);
        $('body').append($div);
    }

    function registerEventListener() {
        registerHashChange();
        registerListGridStatus();
        registerCheckbox();
        registerAllCheckbox();
        registerFileSelect();
    }

    //监视地址栏#标签变化
    function registerHashChange() {
        window.addEventListener('hashchange', function (e) {
            list_grid_status = getListGridStatus();
            if (currentPath == getPath()) {
                return;
            } else {
                currentPath = getPath();
                refreshFileList();
                refreshSelectFileList();
            }
        });
    }

    function refreshFileList() {
        fileList = getFileList();
    }

    function refreshSelectFileList() {
        selectFileList = [];
    }

    //监视视图变化
    function registerListGridStatus() {
        var $a_list = $('a[data-type=list]');
        $a_list.click(function () {
            list_grid_status = 'list';
        });

        var $a_grid = $('a[data-type=grid]');
        $a_grid.click(function () {
            list_grid_status = 'grid';
        });
    }

    //监视文件选择框
    function registerCheckbox() {
        //var $checkbox = $('span.checkbox');
        var $checkbox = $('span.' + wordMap['checkbox']);
        $checkbox.each(function (index, element) {
            $(element).bind('click', function (e) {
                var $parent = $(this).parent();
                var filename;
                if (list_grid_status == 'list') {
                    filename = $('div.file-name div.text a', $parent).attr('title');
                } else if (list_grid_status == 'grid') {
                    filename = $('div.file-name a', $parent).attr('title');
                }
                if ($parent.hasClass('item-active')) {
                    slog('取消选中文件:' + filename);
                    for (var i = 0; i < selectFileList.length; i++) {
                        if (selectFileList[i].filename == filename) {
                            selectFileList.splice(i, 1);
                        }
                    }
                } else {
                    slog('选中文件:' + filename);
                    $.each(fileList, function (index, element) {
                        if (element.server_filename == filename) {
                            var obj = {
                                filename: element.server_filename,
                                path: element.path,
                                fs_id: element.fs_id,
                                isdir: element.isdir
                            };
                            selectFileList.push(obj);
                        }
                    });
                }
            });
        });
    }

    function unregisterCheckbox() {
        //var $checkbox = $('span.checkbox');
        var $checkbox = $('span.' + wordMap['checkbox']);
        $checkbox.each(function (index, element) {
            $(element).unbind('click');
        });
    }

    //监视全选框
    function registerAllCheckbox() {
        //var $checkbox = $('div.col-item.check');
        var $checkbox = $('div.' + wordMap['col-item'] + '.' + wordMap['check']);
        $checkbox.each(function (index, element) {
            $(element).bind('click', function (e) {
                var $parent = $(this).parent();
                //if($parent.hasClass('checked')){
                if ($parent.hasClass(wordMap['checked'])) {
                    slog('取消全选');
                    selectFileList = [];
                } else {
                    slog('全部选中');
                    selectFileList = [];
                    $.each(fileList, function (index, element) {
                        var obj = {
                            filename: element.server_filename,
                            path: element.path,
                            fs_id: element.fs_id,
                            isdir: element.isdir
                        };
                        selectFileList.push(obj);
                    });
                }
            });
        });
    }

    function unregisterAllCheckbox() {
        //var $checkbox = $('div.col-item.check');
        var $checkbox = $('div.' + wordMap['col-item'] + '.' + wordMap['check']);
        $checkbox.each(function (index, element) {
            $(element).unbind('click');
        });
    }

    //监视单个文件选中
    function registerFileSelect() {
        console.log('registerFileSelect');
        //var $dd = $('div.list-view dd');
        var $dd = $('div.' + wordMap['list-view'] + ' dd');
        $dd.each(function (index, element) {
            $(element).bind('click', function (e) {
                var nodeName = e.target.nodeName.toLowerCase();
                if (nodeName != 'span' && nodeName != 'a' && nodeName != 'em') {
                    selectFileList = [];
                    var filename = $('div.file-name div.text a', $(this)).attr('title');
                    slog('选中文件:' + filename);
                    $.each(fileList, function (index, element) {
                        if (element.server_filename == filename) {
                            var obj = {
                                filename: element.server_filename,
                                path: element.path,
                                fs_id: element.fs_id,
                                isdir: element.isdir
                            };
                            selectFileList.push(obj);
                        }
                    });
                }
            });
        });
    }

    function unregisterFileSelect() {
        //var $dd = $('div.list-view dd');
        var $dd = $('div.' + wordMap['list-view'] + ' dd');
        $dd.each(function (index, element) {
            $(element).unbind('click');
        });
    }

    //监视文件列表显示变化
    function createObserver() {
        var MutationObserver = window.MutationObserver;
        var options = {
            'childList': true
        };
        observer = new MutationObserver(function (mutations) {
            unregisterCheckbox();
            unregisterAllCheckbox();
            unregisterFileSelect();
            registerCheckbox();
            registerAllCheckbox();
            registerFileSelect();
        });
        //var list_view = document.querySelector('.list-view');
        //var grid_view = document.querySelector('.grid-view');

        var list_view = document.querySelector('.' + wordMap['list-view']);
        var grid_view = document.querySelector('.' + wordMap['grid-view']);

        observer.observe(list_view, options);
        observer.observe(grid_view, options);
    }

    //获取文件信息列表
    function getFileList() {
        var result = [];
        if (getPath() == '/') {
            result = yunData.FILEINFO;
        } else {
            logid = getLogID();
            var params = {
                uk: uk,
                shareid: shareid,
                order: 'other',
                desc: 1,
                showempty: 0,
                web: web,
                dir: getPath(),
                t: Math.random(),
                bdstoken: bdstoken,
                channel: channel,
                clienttype: clienttype,
                app_id: app_id,
                logid: logid
            };
            $.ajax({
                url: shareListUrl,
                method: 'GET',
                async: false,
                data: params,
                success: function (response) {
                    if (response.errno === 0) {
                        result = response.list;
                    }
                }
            });
        }
        return result;
    }

    function downloadButtonClick() {
        //console.log('点击直接下载按钮');
        slog('选中文件列表:', selectFileList);
        if (selectFileList.length === 0) {
            alert('获取文件ID失败,请重试');
            return;
        }
        buttonTarget = 'download';
        var downloadLink = getDownloadLink();

        if (downloadLink.errno == -20) {
            vcode = getVCode();
            if (vcode.errno !== 0) {
                alert('获取验证码失败!');
                return;
            }
            vcodeDialog.open(vcode);
        } else if (downloadLink.errno == 112) {
            alert('页面过期,请刷新重试');
            return;
        } else if (downloadLink.errno === 0) {
            var link;
            if (selectFileList.length == 1 && selectFileList[0].isdir === 0)
                link = downloadLink.list[0].dlink;
            else
                link = downloadLink.dlink;
            //link = link.replace("https://d.pcs.baidu.com","http://yqall02.baidupcs.com");
            execDownload(link);
        } else {
            alert('获取下载链接失败!');
            return;
        }
    }

    //获取验证码
    function getVCode() {
        var url = panAPIUrl + 'getvcode';
        var result;
        logid = getLogID();
        var params = {
            prod: 'pan',
            t: Math.random(),
            bdstoken: bdstoken,
            channel: channel,
            clienttype: clienttype,
            web: web,
            app_id: app_id,
            logid: logid
        };
        $.ajax({
            url: url,
            method: 'GET',
            async: false,
            data: params,
            success: function (response) {
                result = response;
            }
        });
        return result;
    }

    //刷新验证码
    function refreshVCode() {
        vcode = getVCode();
        $('#dialog-img').attr('src', vcode.img);
    }

    //验证码确认提交
    function confirmClick() {
        var val = $('#dialog-input').val();
        if (val.length === 0) {
            $('#dialog-err').text('请输入验证码');
            return;
        } else if (val.length < 4) {
            $('#dialog-err').text('验证码输入错误,请重新输入');
            return;
        }
        var result = getDownloadLinkWithVCode(val);
        if (result.errno == -20) {
            vcodeDialog.close();
            $('#dialog-err').text('验证码输入错误,请重新输入');
            refreshVCode();
            if (!vcode || vcode.errno !== 0) {
                alert('获取验证码失败!');
                return;
            }
            vcodeDialog.open();
        } else if (result.errno === 0) {
            vcodeDialog.close();
            var link;
            if (selectFileList.length == 1 && selectFileList[0].isdir === 0)
                link = result.list[0].dlink;
            else
                link = result.dlink;
            if (buttonTarget == 'download') {
                execDownload(link);
            } else if (buttonTarget == 'link') {
                var filename = '';
                $.each(selectFileList, function (index, element) {
                    if (selectFileList.length == 1)
                        filename = element.filename;
                    else {
                        if (index == 0)
                            filename = element.filename;
                        else
                            filename = filename + ',' + element.filename;
                    }
                });
                //link = replaceDownloadLink(link, true);
                var linkList = {
                    filename: filename,
                    urls: [
                        {url: link, rank: 1}
                    ]
                };
                var tip = "提示:单文件获取的是直接下载链接,多文件和文件夹获取的是打包压缩下载直链!(压缩链接可以使用下载工具超级加速)";
                dialog.open({title:'直接下载地址',type:'link',list:linkList,tip:tip});
            }
        } else {
            alert('发生错误!');
            return;
        }
    }

    //生成下载用的fid_list参数
    function getFidList() {
        var fidlist = [];
        $.each(selectFileList, function (index, element) {
            fidlist.push(element.fs_id);
        });
        return '[' + fidlist + ']';
    }

    function linkButtonClick() {
        slog('选中文件列表:', selectFileList);
        if (selectFileList.length === 0) {
            alert('没有选中文件,请重试');
            return;
        }
        buttonTarget = 'link';
        var downloadLink = getDownloadLink();

        if (downloadLink.errno == -20) {
            vcode = getVCode();
            if (!vcode || vcode.errno !== 0) {
                alert('获取验证码失败!');
                return;
            }
            vcodeDialog.open(vcode);
        } else if (downloadLink.errno == 112) {
            alert('页面过期,请刷新重试');
            return;
        } else if (downloadLink.errno === 0) {
            var link;
            if (selectFileList.length == 1 && selectFileList[0].isdir === 0)
                link = downloadLink.list[0].dlink;
            else
                link = downloadLink.dlink;
            if (selectFileList.length == 1)
                $('#dialog-downloadlink').attr('href', link).text(link);
            else
                $('#dialog-downloadlink').attr('href', link).text(link);
            var filename = '';
            $.each(selectFileList, function (index, element) {
                if (selectFileList.length == 1)
                    filename = element.filename;
                else {
                    if (index == 0)
                        filename = element.filename;
                    else
                        filename = filename + ',' + element.filename;
                }
            });
            //link = replaceDownloadLink(link, true);
            var linkList = {
                filename: filename,
                urls: [
                    {url: link, rank: 1}
                ]
            };
            var tip = "提示:单文件获取的是直接下载链接,多文件和文件夹获取的是打包压缩下载直链!(压缩链接可以使用下载工具超级加速)'";
            dialog.open({title:'直接下载地址',type:'link',list:linkList,tip:tip});
        } else {
            alert('获取下载链接失败!');
            return;
        }
    }

    //获取下载链接
    function getDownloadLink() {
        var result;
        if (isSingleShare) {
            fid_list = getFidList();
            logid = getLogID();
            var url = panAPIUrl + 'sharedownload?sign=' + sign + '&timestamp=' + timestamp + '&bdstoken=' + bdstoken + '&channel=' + channel + '&clienttype=' + clienttype + '&web=' + web + '&app_id=' + app_id + '&logid=' + logid;
            var params = {
                encrypt: encrypt,
                product: product,
                uk: uk,
                primaryid: primaryid,
                fid_list: fid_list
            };
            if (shareType == 'secret') {
                params.extra = extra;
            }
            if (selectFileList[0].isdir == 1 || selectFileList.length > 1) {
                params.type = 'batch';
            }
            $.ajax({
                url: url,
                method: 'POST',
                async: false,
                data: params,
                success: function (response) {
                    result = response;
                }
            });
        }
        return result;
    }

    //有验证码输入时获取下载链接
    function getDownloadLinkWithVCode(vcodeInput) {
        var result;
        if (isSingleShare) {
            fid_list = getFidList();
            var url = panAPIUrl + 'sharedownload?sign=' + sign + '&timestamp=' + timestamp + '&bdstoken=' + bdstoken + '&channel=' + channel + '&clienttype=' + clienttype + '&web=' + web + '&app_id=' + app_id + '&logid=' + logid;
            var params = {
                encrypt: encrypt,
                product: product,
                vcode_input: vcodeInput,
                vcode_str: vcode.vcode,
                uk: uk,
                primaryid: primaryid,
                fid_list: fid_list
            };
            if (shareType == 'secret') {
                params.extra = extra;
            }
            if (selectFileList[0].isdir == 1 || selectFileList.length > 1) {
                params.type = 'batch';
            }
            $.ajax({
                url: url,
                method: 'POST',
                async: false,
                data: params,
                success: function (response) {
                    result = response;
                }
            });
        }
        return result;
    }

    function execDownload(link) {
        slog('下载链接:' + link);
        $('#helperdownloadiframe').attr('src', link);
    }
}

function base64Encode(t) {
    var a, r, e, n, i, s, o = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
    for (e = t.length, r = 0, a = ""; e > r;) {
        if (n = 255 & t.charCodeAt(r++), r == e) {
            a += o.charAt(n >> 2);
            a += o.charAt((3 & n) << 4);
            a += "==";
            break;
        }
        if (i = t.charCodeAt(r++), r == e) {
            a += o.charAt(n >> 2);
            a += o.charAt((3 & n) << 4 | (240 & i) >> 4);
            a += o.charAt((15 & i) << 2);
            a += "=";
            break;
        }
        s = t.charCodeAt(r++);
        a += o.charAt(n >> 2);
        a += o.charAt((3 & n) << 4 | (240 & i) >> 4);
        a += o.charAt((15 & i) << 2 | (192 & s) >> 6);
        a += o.charAt(63 & s);
    }
    return a;
}

function detectPage() {
    var regx = /[\/].+[\/]/g;
    var page = location.pathname.match(regx);
    return page[0].replace(/\//g, '');
}

function getCookie(e) {
    var o, t;
    var n = document, c = decodeURI;
    return n.cookie.length > 0 && (o = n.cookie.indexOf(e + "="), -1 != o) ? (o = o + e.length + 1, t = n.cookie.indexOf(";", o), -1 == t && (t = n.cookie.length), c(n.cookie.substring(o, t))) : "";
}

function getLogID() {
    var name = "BAIDUID";
    var u = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/~!@#¥%……&";
    var d = /[\uD800-\uDBFF][\uDC00-\uDFFFF]|[^\x00-\x7F]/g;
    var f = String.fromCharCode;

    function l(e) {
        if (e.length < 2) {
            var n = e.charCodeAt(0);
            return 128 > n ? e : 2048 > n ? f(192 | n >>> 6) + f(128 | 63 & n) : f(224 | n >>> 12 & 15) + f(128 | n >>> 6 & 63) + f(128 | 63 & n);
        }
        var n = 65536 + 1024 * (e.charCodeAt(0) - 55296) + (e.charCodeAt(1) - 56320);
        return f(240 | n >>> 18 & 7) + f(128 | n >>> 12 & 63) + f(128 | n >>> 6 & 63) + f(128 | 63 & n);
    }

    function g(e) {
        return (e + "" + Math.random()).replace(d, l);
    }

    function m(e) {
        var n = [0, 2, 1][e.length % 3];
        var t = e.charCodeAt(0) << 16 | (e.length > 1 ? e.charCodeAt(1) : 0) << 8 | (e.length > 2 ? e.charCodeAt(2) : 0);
        var o = [u.charAt(t >>> 18), u.charAt(t >>> 12 & 63), n >= 2 ? "=" : u.charAt(t >>> 6 & 63), n >= 1 ? "=" : u.charAt(63 & t)];
        return o.join("");
    }

    function h(e) {
        return e.replace(/[\s\S]{1,3}/g, m);
    }

    function p() {
        return h(g((new Date()).getTime()));
    }

    function w(e, n) {
        return n ? p(String(e)).replace(/[+\/]/g, function (e) {
            return "+" == e ? "-" : "_";
        }).replace(/=/g, "") : p(String(e));
    }

    return w(getCookie(name));
}

function Dialog() {
    var linkList = [];
    var showParams;
    var dialog, shadow;

    function createDialog() {
        var screenWidth = document.body.clientWidth;
        var dialogLeft = screenWidth > 800 ? (screenWidth - 800) / 2 : 0;
        var $dialog_div = $('<div class="dialog" style="width: 800px; top: 0px; bottom: auto; left: ' + dialogLeft + 'px; right: auto; display: hidden; visibility: visible; z-index: 52;"></div>');
        var $dialog_header = $('<div class="dialog-header"><h3><span class="dialog-title" style="display:inline-block;width:740px;white-space:nowrap;overflow-x:hidden;text-overflow:ellipsis"></span></h3></div>');
        var $dialog_control = $('<div class="dialog-control"><span class="dialog-icon dialog-close">×</span></div>');
        var $dialog_body = $('<div class="dialog-body" style="max-height:450px;overflow-y:auto;padding:0 20px;"></div>');
        var $dialog_tip = $('<div class="dialog-tip" style="padding-left:20px;background-color:#faf2d3;border-top: 1px solid #c4dbfe;"><p></p></div>');

        $dialog_div.append($dialog_header.append($dialog_control)).append($dialog_body);

        //var $dialog_textarea = $('<textarea class="dialog-textarea" style="display:none;width"></textarea>');
        var $dialog_radio_div = $('<div class="dialog-radio" style="display:none;width:760px;padding-left:20px;padding-right:20px"></div>');
        var $dialog_radio_multi = $('<input type="radio" name="showmode" checked="checked" value="multi"><span>多行</span>');
        var $dialog_radio_single = $('<input type="radio" name="showmode" value="single"><span>单行</span>');
        $dialog_radio_div.append($dialog_radio_multi).append($dialog_radio_single);
        $dialog_div.append($dialog_radio_div);
        $('input[type=radio][name=showmode]', $dialog_radio_div).change(function () {
            var value = this.value;
            var $textarea = $('div.dialog-body textarea[name=dialog-textarea]', dialog);
            var content = $textarea.val();
            if (value == 'multi') {
                content = content.replace(/\s+/g, '\n');
                $textarea.css('height', '300px');
            } else if (value == 'single') {
                content = content.replace(/\n+/g, ' ');
                $textarea.css('height', '');
            }
            $textarea.val(content);
        });

        var $dialog_button = $('<div class="dialog-button" style="display:none"></div>');
        var $dialog_button_div = $('<div style="display:table;margin:auto"></div>')
        var $dialog_copy_button = $('<button id="dialog-copy-button" style="display:none">复制</button>');
        var $dialog_edit_button = $('<button id="dialog-edit-button" style="display:none">编辑</button>');
        var $dialog_exit_button = $('<button id="dialog-exit-button" style="display:none">退出</button>');

        $dialog_button_div.append($dialog_copy_button).append($dialog_edit_button).append($dialog_exit_button);
        $dialog_button.append($dialog_button_div);
        $dialog_div.append($dialog_button);

        $dialog_copy_button.click(function () {
            var content = '';
            if (showParams.type == 'batch') {
                $.each(linkList, function (index, element) {

                     // alert(element.filename);
                    if (element.downloadlink == 'error')
                        return;
                    if (index == linkList.length - 1)
                        content = content +element.filename+':'+ element.downloadlink;//添加共享文件名称和链接到黏贴版
                    else
                        content = content + element.filename+':'+element.downloadlink + '\n';
                });
            } else if (showParams.type == 'link') {
                $.each(linkList, function (index, element) {
                    if (element.url == 'error')
                        return;
                    if (index == linkList.length - 1)
                        content = content + element.url;
                    else
                        content = content + element.url + '\n';
                });
            }
            GM_setClipboard(content, 'text');
            alert('已将链接复制到剪贴板啦啦啦!');
        });

        $dialog_edit_button.click(function () {
            var $dialog_textarea = $('div.dialog-body textarea[name=dialog-textarea]', dialog);
            var $dialog_item = $('div.dialog-body div', dialog);
            $dialog_item.hide();
            $dialog_copy_button.hide();
            $dialog_edit_button.hide();
            $dialog_textarea.show();
            $dialog_radio_div.show();
            $dialog_exit_button.show();
        });

        $dialog_exit_button.click(function () {
            var $dialog_textarea = $('div.dialog-body textarea[name=dialog-textarea]', dialog);
            var $dialog_item = $('div.dialog-body div', dialog);
            $dialog_textarea.hide();
            $dialog_radio_div.hide();
            $dialog_item.show();
            $dialog_exit_button.hide();
            $dialog_copy_button.show();
            $dialog_edit_button.show();
        });

        $dialog_div.append($dialog_tip);
        $('body').append($dialog_div);
        $dialog_div.dialogDrag();
        $dialog_control.click(dialogControl);
        return $dialog_div;
    }

    function createShadow() {
        var $shadow = $('<div class="dialog-shadow" style="position: fixed; left: 0px; top: 0px; z-index: 50; background: rgb(0, 0, 0) none repeat scroll 0% 0%; opacity: 0.5; width: 100%; height: 100%; display: none;"></div>');
        $('body').append($shadow);
        return $shadow;
    }

    this.open = function (params) {
        showParams = params;
        linkList = [];
        if (params.type == 'link') {
            linkList = params.list.urls;
            $('div.dialog-header h3 span.dialog-title', dialog).text(params.title + ":" + params.list.filename);
            $.each(params.list.urls, function (index, element) {
                var $div = $('<div><div style="width:30px;float:left">' + element.rank + ':</div><div style="white-space:nowrap;overflow:hidden;text-overflow:ellipsis"><a href="' + element.url + '">' + element.url + '</a></div></div>');
                $('div.dialog-body', dialog).append($div);
            });
        } else if (params.type == 'batch') {
            linkList = params.list;
            $('div.dialog-header h3 span.dialog-title', dialog).text(params.title);
            if (params.showall) {
                $.each(params.list, function (index, element) {
                    var $item_div = $('<div class="item-container" style="overflow:hidden;text-overflow:ellipsis;white-space:nowrap"></div>');
                    var $item_name = $('<div style="width:100px;float:left;overflow:hidden;text-overflow:ellipsis" title="' + element.filename + '">' + element.filename + '</div>');
                    var $item_sep = $('<div style="width:12px;float:left"><span>:</span></div>');
                    var $item_link_div = $('<div class="item-link" style="float:left;width:618px;"></div>');
                    var $item_first = $('<div class="item-first" style="overflow:hidden;text-overflow:ellipsis"><a href="' + element.downloadlink + '">' + element.downloadlink + '</a></div>');
                    $item_link_div.append($item_first);
                    $.each(params.alllist[index].links, function (n, item) {
                        if (element.downloadlink == item.url)
                            return;
                        var $item = $('<div class="item-ex" style="display:none;overflow:hidden;text-overflow:ellipsis"><a href="' + item.url + '">' + item.url + '</a></div>');
                        $item_link_div.append($item);
                    });
                    var $item_ex = $('<div style="width:15px;float:left;cursor:pointer;text-align:center;font-size:16px"><span>+</span></div>');
                    $item_div.append($item_name).append($item_sep).append($item_link_div).append($item_ex);
                    $item_ex.click(function () {
                        var $parent = $(this).parent();
                        $parent.toggleClass('showall');
                        if ($parent.hasClass('showall')) {
                            $(this).text('-');
                            $('div.item-link div.item-ex', $parent).show();
                        } else {
                            $(this).text('+');
                            $('div.item-link div.item-ex', $parent).hide();
                        }
                    });
                    $('div.dialog-body', dialog).append($item_div);
                });
            } else {
                $.each(params.list, function (index, element) {
                    var $div = $('<div style="overflow:hidden;text-overflow:ellipsis;white-space:nowrap"><div style="width:100px;float:left;overflow:hidden;text-overflow:ellipsis" title="' + element.filename + '">' + element.filename + '</div><span>:</span><a href="' + element.downloadlink + '">' + element.downloadlink + '</a></div>');
                    $('div.dialog-body', dialog).append($div);
                });
            }
        }

        if (params.tip) {
            $('div.dialog-tip p', dialog).text(params.tip);
        }

        if (params.showcopy) {
            $('div.dialog-button', dialog).show();
            $('div.dialog-button button#dialog-copy-button', dialog).show();
        }
        if (params.showedit) {
            $('div.dialog-button', dialog).show();
            $('div.dialog-button button#dialog-edit-button', dialog).show();
            var $dialog_textarea = $('<textarea name="dialog-textarea" style="display:none;resize:none;width:758px;height:300px;white-space:pre;word-wrap:normal;overflow-x:scroll"></textarea>');
            var content = '';
            if (showParams.type == 'batch') {
                $.each(linkList, function (index, element) {
                    if (element.downloadlink == 'error')
                        return;
                    if (index == linkList.length - 1)
                        content = content + element.downloadlink;
                    else
                        content = content + element.downloadlink+'\n';
                });
            } else if (showParams.type == 'link') {
                $.each(linkList, function (index, element) {
                    if (element.url == 'error')
                        return;
                    if (index == linkList.length - 1)
                        content = content + element.url;
                    else
                        content = content + element.url+ '\n';
                });
            }
            $dialog_textarea.val(content);
            $('div.dialog-body', dialog).append($dialog_textarea);
        }
       // alert(params.list.filename);
        shadow.show();
       dialog.show();
    }

    this.close = function () {
        dialogControl();
    }

    function dialogControl() {
        $('div.dialog-body', dialog).children().remove();
        $('div.dialog-header h3 span.dialog-title', dialog).text('');
        $('div.dialog-tip p', dialog).text('');
        $('div.dialog-button', dialog).hide();
        $('div.dialog-radio input[type=radio][name=showmode][value=multi]', dialog).prop('checked', true);
        $('div.dialog-radio', dialog).hide();
        $('div.dialog-button button#dialog-copy-button', dialog).hide();
        $('div.dialog-button button#dialog-edit-button', dialog).hide();
        $('div.dialog-button button#dialog-exit-button', dialog).hide();
        dialog.hide();
        shadow.hide();
    }

    dialog = createDialog();
    shadow = createShadow();
}

function VCodeDialog(refreshVCode, confirmClick) {
    var dialog, shadow;

    function createDialog() {
        var screenWidth = document.body.clientWidth;
        var dialogLeft = screenWidth > 520 ? (screenWidth - 520) / 2 : 0;
        var $dialog_div = $('<div class="dialog" id="dialog-vcode" style="width:520px;top:0px;bottom:auto;left:' + dialogLeft + 'px;right:auto;display:none;visibility:visible;z-index:52"></div>');
        var $dialog_header = $('<div class="dialog-header"><h3><span class="dialog-header-title"><em class="select-text">提示</em></span></h3></div>');
        var $dialog_control = $('<div class="dialog-control"><span class="dialog-icon dialog-close icon icon-close"><span class="sicon">x</span></span></div>');
        var $dialog_body = $('<div class="dialog-body"></div>');
        var $dialog_body_div = $('<div style="text-align:center;padding:22px"></div>');
        var $dialog_body_download_verify = $('<div class="download-verify" style="margin-top:10px;padding:0 28px;text-align:left;font-size:12px;"></div>');
        var $dialog_verify_body = $('<div class="verify-body">请输入验证码:</div>');
        var $dialog_input = $('<input id="dialog-input" type="text" style="padding:3px;width:85px;height:23px;border:1px solid #c6c6c6;background-color:white;vertical-align:middle;" class="input-code" maxlength="4">');
        var $dialog_img = $('<img id="dialog-img" class="img-code" style="margin-left:10px;vertical-align:middle;" alt="点击换一张" src="" width="100" height="30">');
        var $dialog_refresh = $('<a href="javascript:void(0)" style="text-decoration:underline;" class="underline">换一张</a>');
        var $dialog_err = $('<div id="dialog-err" style="padding-left:84px;height:18px;color:#d80000" class="verify-error"></div>');
        var $dialog_footer = $('<div class="dialog-footer g-clearfix"></div>');
        var $dialog_confirm_button = $('<a class="g-button g-button-blue" data-button-id="" data-button-index href="javascript:void(0)" style="padding-left:36px"><span class="g-button-right" style="padding-right:36px;"><span class="text" style="width:auto;">确定</span></span></a>');
        var $dialog_cancel_button = $('<a class="g-button" data-button-id="" data-button-index href="javascript:void(0);" style="padding-left: 36px;"><span class="g-button-right" style="padding-right: 36px;"><span class="text" style="width: auto;">取消</span></span></a>');

        $dialog_header.append($dialog_control);
        $dialog_verify_body.append($dialog_input).append($dialog_img).append($dialog_refresh);
        $dialog_body_download_verify.append($dialog_verify_body).append($dialog_err);
        $dialog_body_div.append($dialog_body_download_verify);
        $dialog_body.append($dialog_body_div);
        $dialog_footer.append($dialog_confirm_button).append($dialog_cancel_button);
        $dialog_div.append($dialog_header).append($dialog_body).append($dialog_footer);
        $('body').append($dialog_div);

        $dialog_div.dialogDrag();

        $dialog_control.click(dialogControl);
        $dialog_img.click(refreshVCode);
        $dialog_refresh.click(refreshVCode);
        $dialog_input.keypress(function (event) {
            if (event.which == 13)
                confirmClick();
        });
        $dialog_confirm_button.click(confirmClick);
        $dialog_cancel_button.click(dialogControl);
        $dialog_input.click(function () {
            $('#dialog-err').text('');
        });
        return $dialog_div;
    }

    this.open = function (vcode) {
        if (vcode)
            $('#dialog-img').attr('src', vcode.img);
        dialog.show();
        shadow.show();
    }
    this.close = function () {
        dialogControl();
    }
    dialog = createDialog();
    shadow = $('div.dialog-shadow');

    function dialogControl() {
        $('#dialog-img', dialog).attr('src', '');
        $('#dialog-err').text('');
        dialog.hide();
        shadow.hide();
    }
}

$.fn.dialogDrag = function () {
    var mouseInitX, mouseInitY, dialogInitX, dialogInitY;
    var screenWidth = document.body.clientWidth;
    var $parent = this;
    $('div.dialog-header', this).mousedown(function (event) {
        mouseInitX = parseInt(event.pageX);
        mouseInitY = parseInt(event.pageY);
        dialogInitX = parseInt($parent.css('left').replace('px', ''));
        dialogInitY = parseInt($parent.css('top').replace('px', ''));
        $(this).mousemove(function (event) {
            var tempX = dialogInitX + parseInt(event.pageX) - mouseInitX;
            var tempY = dialogInitY + parseInt(event.pageY) - mouseInitY;
            var width = parseInt($parent.css('width').replace('px', ''));
            tempX = tempX < 0 ? 0 : tempX > screenWidth - width ? screenWidth - width : tempX;
            tempY = tempY < 0 ? 0 : tempY;
            $parent.css('left', tempX + 'px').css('top', tempY + 'px');
        });
    });
    $('div.dialog-header', this).mouseup(function (event) {
        $(this).unbind('mousemove');
    });
}})();

下载地址:
链接: https://pan.baidu.com/s/14jNidP3Gj0Uym2c72ufGuA 密码: 4b8d

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,233评论 6 495
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,357评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,831评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,313评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,417评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,470评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,482评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,265评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,708评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,997评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,176评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,827评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,503评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,150评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,391评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,034评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,063评论 2 352

推荐阅读更多精彩内容