Greasy Fork is available in English.

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

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

Verzia zo dňa 2017-03-19 12:17:18 UTC. Pozri najnovšiu verziu.

// ==UserScript==
// @name AC-baidu:优化百度、搜狗搜索结果之重定向去除
// @author         AC
// @namespace      1353464539@qq.com
// @description    繞過百度、搜狗搜索結果中的自己的跳轉鏈接,直接訪問原始網頁-反正都能看懂
// @version        7.3
// @create         2015-11-25
// @lastmodified   2017-2-17
// @include        http://www.baidu.com/*
// @include        https://www.baidu.com/*
// @include        http://www.sogou.com/*
// @include        https://www.sogou.com/*
// @copyright      20157, AC
// @run-at         document-end
// @grant		    GM_xmlhttpRequest
// @icon            https://coding.net/u/zb227/p/zbImg/git/raw/master/img0/icon.jpg
// @note            2017.3.19-V7.3 修复打开百度之后再次点击“百度一下”导致的无法更新重定向问题
// @note            2017.3.19-V7.2 未知原因chrome的MutationObserver无法使用了,继续回归以前的DOMNodeInserted
// @note            2017.2.17-V7.0 修复搜狗的搜索结果重定向问题+改个名字
// @note            2017.2.17-V6.9 修复搜狗的搜索结果重定向问题
// @note            2016.12.10-V6.8 ***
// @note            2016.10.27-V6.7 修复了以前的重复请求,现在的请求数应该小了很多,网络也就不卡了,感觉萌萌哒
// @note            2016.4.24-V6.6 恢复以前的版本,因为兼容性问题
// @note            2015.12.1-V5.0 加入搜狗的支持,但是支出不是很好
// @note            2015.11.25-V2.0 优化,已经是真实地址的不再尝试获取
// @connect *
// @note            2015.11.25-V1.0 完成去掉百度重定向的功能
// ==/UserScript==

// 采用MutationObserver监视会大大实际代码的调用次数-比DOMNodeInserted更好的调用方式

var targets;
var list;
var time;
var Stype;
if (location.href.indexOf("baidu.com") > -1) Stype = "h3.t>a";
else if (location.href.indexOf("sogou.com") > -1) Stype = "h3.pt>a, h3.vrTitle>a";

document.body.addEventListener("DOMNodeInserted", function(event){
    var element = event.target;
    list = document.querySelectorAll(Stype);
    resetURL();
});

function resetURL(){
    for(var i = 0; i < list.length; i++){
        // 此方法是异步,故在结束的时候使用i会出问题-严重!
        // 采用调用前通过context过去,调用结束后通过response.context获得
        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){
                GM_xmlhttpRequest({
                        url: curhref,
                        headers: {
                            "Accept": "text/html"
                        },
                        context: curhref, //直接传递i,在i=0的时候反馈回来时null-猜想被会被转换掉,所以+1
                        method: "GET",
                        onload: function(response) {
                        },
                        onreadystatechange:function(response) {
                            if(response.status==200){
                                //alert(response.responseText);
                                //alert(response.readyState);
                            //if(response.readyState==4||response.status==0){
                                DealResult(response);
                            }
                            //console.log(response);
                        }
                });
            }else{
                console.log("绕过百度重定向直接访问网页: 第"+i+"个已经处理了");
            }
        }
    }
}
function DealResult(response){
    var resultURL = response.finalUrl;
    if(Stype.length > 10){
        //如果是搜狗的结果
        var resultResponseUrl = Reg_Get(response.responseText, "URL='([^']+)'");
        if(resultResponseUrl !== null)
            resultURL = resultResponseUrl;
    }
    var indexhref = Reg_Get(response.context, "((?:http)[^&]+)");// 必须要提取部分数据,因为之后的莫名加了其他参数ck=0.0.0.0.....
    var ccnode = document.querySelectorAll("h3>[href*='"+indexhref+"']")[0];
    // console.log(ccnode.href);
    if(ccnode !== null){
        ccnode.href = resultURL;
    }else{
        console.log("该链接已经被其他脚本干掉了哦"+response.finalUrl);
    }
}
function Reg_Get(HTML, reg){
    var RegE = new RegExp(reg);
    return RegE.exec(HTML)[1];
}