用php来改写404错误页让你的页面更友好

2015-01-24信息快讯网

404错误,很多人都知道,如果要访问的url不存在的时候就读取显示这个页面;以往在处理404写几行字,有心人对其稍加美化,首先我来说明一下我的404究竟都能帮我做哪些事情以及PHP如何来改写你的404错误页

404错误,很多人都知道,如果要访问的url不存在的时候就读取显示这个页面.以往在处理404方面我们通常的做法是要麽简单写几行字,而有心人士或许还会对其稍加美化,另外一少部份想投机取巧的砘锷踔劣meta标`做延时转向,仅此而已,其实404还可以帮我们做很多事,这就是今天我们要讨论的重点了.

首先我来说明一下我的404究竟都能帮我做哪些事情:
1.他可以告诉我何时来自哪e的用户要访问我哪个URL结果失败了.
2.他能告诉我对方为何要访问这个URL,并帮助我优化网站
3.他能告诉我对方的IP地址
4.他能告诉我此人的居心何在
5.我可以让他把那些不想告诉我的给闭嘴
6.他能把他想要告诉我的用email方式发给我
7.他能帮我做301永久重定向.
8.他能告诉我有人正在试图入侵我的网站或主机

听起来很玄也很炫,好吧,接下来我们就来讨论一下究竟他是怎麽做到的.逐一分析:
1.我们可以用PHP捕捉用户的来源URL和当前的URL,所以第一点我们可以很简单的做到.
2.因为有了来源URL,所以你就能很直观的猜测到用户的意图了,我举个例子,就像我的网站http://www.jb51.net,如果某个用户的来源URL是http://www.jb51.net,而捕捉到他目前的URL是http://www.jb51.net/user.php?id=1这就说明此人在浏览我的网站的时候当点击了某个人的个人资料页时结果找不到这个人的资料从而出错,说明:ID=1的这个可能不存在货已经被删掉了,那麽你就要看一下网站上是否还有这个URL的超链接,如果有的话就要想办法把它给删掉吧!
3.这个功能就比较简单了,只需要用PHP捕捉一下对方的ip即可.然后配合其他网站的IP转物理地址的功能就能知道此人来自哪e了.
4.这个功能很好,很强大.因为我的网站www.7di.net是自己配置的服务器,所以安全方面都要靠自己来处理,而往往有些不入流的砘锒员鹑说姆务器感兴趣,他们会用程序尝试各种方法来进入服务器,而此时你就会发现你在短时间内收到大量的404错误,且来源URL为空,他们要访问的URL都是一些很敏感的URL,此时你需要做的就是打开你的防火设置,然后乾Q俐落的封掉这个IP.最近这段时间我就是用此方法封了几十个IP,真是小兵立大功!忘记说了,信息产业部的IP也被我封了,我服务器在台湾你来验证个什么劲,真是的~~!
5.说实话,这个插件刚开始的时候让我非常烦恼,因为托他的福我每天会收到几百封Email,有的是因为用户正常浏览导致的,有的是因为各家搜索引擎来窦内容导致的,有些是因为小瘪三们想入侵导致的,总之不厌其烦,后来我稍作改动,把扩展名符合条件或IP符合条件的都加入了验证,只要这些符合条件就不用发送Email了,这样一来清爽多了.
6.这一切都脱离不了PHP即时发送Email的功能,我的做法是修改PHP.INI来实现PHP内部mail函数发送,当然了如果你也可以用其他的方法,例如:安装sendmail或者开发一个mail类来藉助第三方smtp发送皆可.只要你爽就好(具体细节不是今天的讨论范围).
7.既然能够访问到这个页面,说明用户访问的URL是不存在的,所以我们要引导用户能够访问到正确的URL才对,那麽既然是引导用户访问正确的URL或许你会说直接用一个meta标`或一句JS延时就行了何必大费周章301转向呢?因为我不想被搜索引擎认为我是在作弊!回答完毕.
8.这一点我在上边已经阐述过了,基本上对于小瘪三的判断要根据你的经验和对你自己网站的熟悉程度来决定,更有甚者,你要大体t解你的网站都有哪些URL被其他网站给反链了(经验啊,非一朝一夕能一蹴而就的).

该说的,该放的否完了,接下来好戏要上演了,把下边的代码存为404.php,然后apache或nginx之类的把你的404错误页指向过来就行了.
 
<?PHP 
#设置URL,注意没有后划线/ 
$MyURL = (isSet($_SERVER['HTTP_HOST'])) ? Str_iReplace('http://','',StrToLower(rTrim($_SERVER['HTTP_HOST'],'/'))) : 'www.7di.net'; 
#设置URL,注意没有后划线/ 
$MyDomain = (isSet($_SERVER['HTTP_HOST'])) ? 'http://'.Str_iReplace('http://','',StrToLower(rTrim($_SERVER['HTTP_HOST'],'/'))) : 'http://www.jb51.net'; 
//设定时区.主要用来修正8小时时差 
Date_Default_Timezone_Set('Etc/GMT-8'); 
//输出头部 
Header('Content-type:text/html; charset=utf-8'); 
/** 
发送电邮 
参数: 
收件人,邮件标题(不可有换行符),邮件内容(行与行之间必须用\n分隔,每行不可超过70个字符) 
说明: 
调用PHP内置函式Mail发送电邮 
返回: 
返回布尔值 
用法: 
$IsSend=Fun::Mail2($email,$tit,$msg); 
/**/ 
Function Mail2($to,$tit,$msg) { 
IF(Filter_var($to,FILTER_VALIDATE_EMAIL)==''){ 
throw new Exception('电邮地址错误!'); 
} 
$tit='=?UTF-8?B?'.Base64_Encode($tit).'?='; 
$msg = str_replace("\n.","\n..",$msg); //Windows如果在一行开头发现一个句号则会被删掉,要避免此问题将单个句号替换成两个句号 
Return Mail($to,$tit,$msg,'From:[email protected]'."\n".'Content-Type:text/html;charset=utf-8'); 
} 
$msg='<table cellspacing="0" cellpadding="0" border="0"><tr><td style="padding:5px;background-color:#F57900;font-size:13px;border:2px solid #222;color:#222;">'; 
$msg.=(isSet($_SERVER['REMOTE_ADDR'])) ? "<b>来访者IP是:</b><br><a href='http://www.ip138.com/ips138.asp?ip={$_SERVER['REMOTE_ADDR']}&action=2' target='_blank'>{$_SERVER['REMOTE_ADDR']}</a><br>" : ''; 
$msg.="<b>来访时间:</b><br>".date('Y-m-d H:i:s',time()).'<br><br>'; 
$msg.=(isSet($_SERVER['REMOTE_HOST'])) ? "<a href='http://www.ip138.com/ips138.asp?ip={$_SERVER['REMOTE_HOST']}&action=2' target='_blank'>{$_SERVER['REMOTE_HOST']}</a><br><br>" : '<br>'; 
$msg.=(isSet($_SERVER['HTTP_USER_AGENT'])) ? "<b>来访者详细资料:</b><br>{$_SERVER['HTTP_USER_AGENT']}<br><br>" : ''; 
$msg.=(isSet($_SERVER['REQUEST_URI'])) ? "<b>要访问的页面是:</b><br>{$MyDomain}{$_SERVER['REQUEST_URI']}<br><br>" : ''; 
$msg.=(isSet($_SERVER['HTTP_REFERER']) And Trim($_SERVER['HTTP_REFERER'])!='') ? "<b>来源地址是:</b><br>{$_SERVER['HTTP_REFERER']}<br><br>" : ''; 
$msg.='</td></tr></table>'; 
//哪些类型的URL不发Email,如果不屏蔽掉这些的话能烦死我 
$arr=Array('mp3','rm','swf','jpg','gif'); 
//哪些IP不发Email,这些基本都是搜索引擎的蜘蛛 
$arrIP=Array('66.249.77.217','66.249.74.67'); 
//要访问的扩展名 
$needEx=Explode('.',StrToLower(Trim($_SERVER['REQUEST_URI']))); 
$needEx=end($needEx); 
IF(!In_Array($needEx,$arr) And !In_Array(Trim($_SERVER['REMOTE_ADDR']),$arrIP)) { 
Mail2('[email protected]','来自【'.$MyURL.'】的404错误!',$msg); 
} 
unSet($MyURL,$msg,$needEx,$arr); 
Header('HTTP/1.1 301 Moved Permanently'); 
Header ("Location:{$MyDomain}"); 
Die(); 

注意:如果你感觉上边代码中所实现的功能还不能满足你的j望,那麽鼓励你改写他,完善它,加强他,我绝不反对,但请你把你的作品分享给我,谢谢啦~~~~!
访问编码后的中文URL返回404错误的解决方法
利用curl抓取远程页面内容的示例代码
解析VS2010利用VS.PHP插件调试PHP的方法
js限制checkbox勾选的个数以及php获取多个checkbbox的方法深入解析
php的数组与字符串的转换函数整理汇总
使用PHP编写的SVN类
解析PHP中的unset究竟会不会释放内存
thinkphp 一个页面使用2次分页的实现方法
如何解决CI框架的Disallowed Key Characters错误提示
解决php使用异步调用获取数据时出现(错误c00ce56e导致此项操作无法完成)
计算php页面运行时间的函数介绍
浅析Dos下运行php.exe,出现没有找到php_mbstring.dll 错误的解决方法
PHP 过滤页面中的BOM(实现代码)
关于url地址传参数时字符串有回车造成页面脚本赋值失败的解决方法
PHP错误提示的关闭方法详解
php连接Access数据库错误及解决方法
PHP header()函数使用详细(301、404等错误设置)
php压缩HTML函数轻松实现压缩html/js/Css及注意事项
php对大文件进行读取操作的实现代码
php删除与复制文件夹及其文件夹下所有文件的实现代码
php删除文件夹及其文件夹下所有文件的函数代码
php定时删除文件夹下文件(清理缓存文件)
PHP关联数组的10个操作技巧
用PHP即时捕捉PHP中的错误并发送email通知的实现代码
PHP 的异常处理、错误的抛出及回调函数等面向对象的错误处理方法
php 定义404页面的实现代码
屏蔽机器人从你的网站搜取email地址的php代码
php中防止恶意刷新页面的代码小结
php页面缓存ob系列函数介绍
记录PHP错误日志 display_errors与log_errors的区别
用C/C++扩展你的PHP 为你的php增加功能
简单的方法让你的后台登录更加安全(php中加session验证)
PhpMyAdmin出现export.php Missing parameter: what /export_type错误解决方法
PHP服务器页面间跳转实现方法
php切割页面div内容的实现代码分享
PHP Parse Error: syntax error, unexpected $end 错误的解决办法
PHP 杂谈《重构-改善既有代码的设计》之一 重新组织你的函数
php中修改浏览器的User-Agent来伪装你的浏览器和操作系统
php 404错误页面实现代码
©2014-2025 dbsqp.com