Greasy Fork is available in English.

AC-baidu: 优化百度、搜狗搜索结果之重定向去除

繞過百度、搜狗搜索結果中的自己的跳轉鏈接,直接訪問原始網頁-反正都能看懂

Verzia zo dňa 2017-05-04 06:36:21 UTC. Pozri najnovšiu verziu.

// ==UserScript==
// @name AC-baidu: 优化百度、搜狗搜索结果之重定向去除
// @icon            https://coding.net/u/zb227/p/zbImg/git/raw/master/img0/icon.jpg
// @grant		    GM_xmlhttpRequest
// @author          AC
// @create          2015-11-25
// @run-at          document-start
// @version         8.0
// @connect         *
// @include         http://www.baidu.com/*
// @include         https://www.baidu.com/*
// @include         http://www.sogou.com/*
// @include         https://www.sogou.com/*
// @include         /^https?\:\/\/encrypted.google.[^\/]+/
// @include         /^https?\:\/\/www.google.[^\/]+/
// @include         https://zhidao.baidu.com/*
// @home-url        https://greasyfork.org/zh-TW/scripts/14178
// @namespace       1353464539@qq.com
// @copyright       2017, AC
// @description     繞過百度、搜狗搜索結果中的自己的跳轉鏈接,直接訪問原始網頁-反正都能看懂
// @lastmodified    2017-05-04
// @feedback-url    https://greasyfork.org/zh-TW/scripts/14178
// @note            2017.05.04-V8.0 终于修复了百度知道图片替换了文字的这个大BUG,待测试
// @note            2017.03.28-V7.6 修复在ViolentMonkey上的不支持的问题
// @note            2017.03.28-V7.5 尝试修复chrome上的问题
// @note            2017.03.21-V7.4 尝试处理Edge上不支持的问题,结果发现是Edge本身的TamperMonkey支持有问题
// @note            2017.03.19-V7.3 修复打开百度之后再次点击“百度一下”导致的无法更新重定向问题
// @note            2017.03.19-V7.2 未知原因chrome的MutationObserver无法使用了,继续回归以前的DOMNodeInserted
// @note            2017.02.17-V7.0 修复搜狗的搜索结果重定向问题+改个名字
// @note            2017.02.17-V6.9 修复搜狗的搜索结果重定向问题
// @note            2016.12.10-V6.8 ***
// @note            2016.10.27-V6.7 修复了以前的重复请求,现在的请求数应该小了很多,网络也就不卡了,感觉萌萌哒
// @note            2016.04.24-V6.6 恢复以前的版本,因为兼容性问题
// @note            2015.12.01-V5.0 加入搜狗的支持,但是支出不是很好
// @note            2015.11.25-V2.0 优化,已经是真实地址的不再尝试获取
// @note            2015.11.25-V1.0 完成去掉百度重定向的功能
// ==/UserScript==

// 采用MutationObserver监视会大大实际代码的调用次数-比DOMNodeInserted更好的调用方式
var targets;
var list;
var time;
var Stype;
if (location.href.indexOf("www.baidu.com") > -1) Stype = "h3.t>a";
else if (location.href.indexOf("sogou.com") > -1) Stype = "h3.pt>a, h3.vrTitle>a";
else if (location.host.indexOf("google") > -1) Stype = "h3>a";
else{
    console.log("i'am in");
    addStyle(".word-replace{display: none  !important;}");
    return;
}
document.addEventListener("DOMNodeInserted", function(event){
    var element = event.target;
    list = document.querySelectorAll(Stype);
    resetURL();
});
function addStyle(css) { //添加CSS的代码--copy的
    var pi = document.createProcessingInstruction(
        'xml-stylesheet',
        'type="text/css" href="data:text/css;utf-8,' + encodeURIComponent(css) + '"'
    );
    return document.insertBefore(pi, document.documentElement);
}
function resetURL(){
    for(var i = 0; i < list.length; i++){
        // 此方法是异步,故在结束的时候使用i会出问题-严重!
        // 采用闭包的方法来进行数据的传递
        var curhref = list[i].href;
        if(list[i].getAttribute("loaded_Status") == null){
            list[i].setAttribute("loaded_Status", "0");
            if(curhref.indexOf("baidu.com") > -1 || curhref.indexOf("sogou.com") > -1){
              (function(c_curhref){
                GM_xmlhttpRequest({
                        url: c_curhref,
                        headers: {
                            "Accept": "text/html"
                        },
                        method: "GET",
                        onreadystatechange:function(response) {
                            if(response.status==200){
                                DealResult(response, c_curhref);
                            }
                        }
                });
              })(curhref); //传递旧的网址过去,读作c_curhref
            }else if(curhref.indexOf("/interstitial") > -1){
                
            }else{
                console.log("绕过百度重定向直接访问网页: 第"+i+"个已经处理了");
            }
        }
    }
}
function DealResult(response, c_curhref){
    var resultURL = response.finalUrl;
    if(Stype.length > 10){
        //如果是搜狗的结果
        var resultResponseUrl = Reg_Get(response.responseText, "URL='([^']+)'");
        if(resultResponseUrl !== null)
            resultURL = resultResponseUrl;
    }
    var indexhref = Reg_Get(c_curhref, "((?:http)[^&]+)");// 必须要提取部分数据,因为之后的莫名加了其他参数ck=0.0.0.0.....
    var ccnode = document.querySelectorAll("h3>[href*='"+indexhref+"']")[0];
    if(ccnode != null){
        ccnode.href = resultURL;
    }else{
        console.log("该链接已经被其他脚本干掉了哦"+resultURL);
    }
}
function Reg_Get(HTML, reg){
    var RegE = new RegExp(reg);
    return RegE.exec(HTML)[1];
}