分享张戈博主改善优化后的网站外链跳转页面代码

转载  张戈博客 2016-02-16 07:19 阅读 1,258 次 评论 38 条

前几天在张戈博客看到《分享最近对网站外链跳转页面代码的一些改善》这篇文章,虽然看得不是很明白,但是感觉改善优化后的跳转代码比较安全可靠,所以今天就特意整理后分享给大家。

分享张戈博主改善优化后的网站外链跳转页面代码

PS:本站原先使用的跳转代码详见《分享boke112导航外链跳转页面技术及代码》,文中代码也是来自于张戈博主分享的第一代代码。

外链跳转代码改善优化内容如下:

  • 安全加固:增加防止恶意请求的简单防护功能;
  • 跳转方式:使用noscript标签增加html的JS跳转模式;
  • 跳转加密:对外链进行Base64加密,同时兼容不加密跳转;
  • 禁止收录:增加一个禁止收录和抓取的META申明;
  • 禁止他用:禁止其他网站使用我们的跳转页面。

部署网站外链跳转的步骤:

一、完整跳转代码

IPHP版本

  1. <?php
  2. if(strlen($_SERVER['REQUEST_URI']) > 255 ||
  3.     strpos($_SERVER['REQUEST_URI'], "eval(") ||
  4.     strpos($_SERVER['REQUEST_URI'], "base64")) {
  5.         @header("HTTP/1.1 414 Request-URI Too Long");
  6.         @header("Status: 414 Request-URI Too Long");
  7.         @header("Connection: Close");
  8.         @exit;
  9. }
  10. //通过QUERY_STRING取得完整的传入数据,然后取得url=之后的所有值,兼容性更好
  11. $t_url = preg_replace('/^url=(.*)$/i','$1',$_SERVER["QUERY_STRING"]);
  12. //此处可以自定义一些特别的外链,不需要可以删除以下5行
  13. if($t_url=="zhangge" ) {
  14.    $t_url="https://zhangge.net";
  15. elseif($t_url=="baidu") {
  16.    $t_url="https://www.baidu.com/";
  17. }
  18. //数据处理
  19. if(!empty($t_url)) {
  20.     //判断取值是否加密
  21.     if ($t_url == base64_encode(base64_decode($t_url))) {
  22.         $t_url =  base64_decode($t_url);
  23.     }
  24.     //对取值进行网址校验和判断
  25.     preg_match('/^(http|https|thunder|qqdl|ed2k|Flashget|qbrowser):\/\//i',$t_url,$matches);
  26.     if($matches){
  27.         $url=$t_url;
  28.         $title='页面加载中,请稍候...';
  29.     } else {
  30.         preg_match('/\./i',$t_url,$matche);
  31.         if($matche){
  32.             $url='http://'.$t_url;
  33.             $title='页面加载中,请稍候...';
  34.         } else {
  35.             $url = 'http://'.$_SERVER['HTTP_HOST'];
  36.             $title='参数错误,正在返回首页...';
  37.         }
  38.     }
  39. else {
  40.     $title = '参数缺失,正在返回首页...';
  41.     $url = 'http://'.$_SERVER['HTTP_HOST'];
  42. }
  43. ?>
  44. <html>
  45. <head>
  46. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  47. <meta name="robots" content="noindex, nofollow" />
  48. <noscript><meta http-equiv="refresh" content="1;url='<?php echo $url;?>';"></noscript>
  49. <script>
  50. function link_jump()
  51. {
  52.     //禁止其他网站使用我们的跳转页面
  53.     var MyHOST = new RegExp("<?php echo $_SERVER['HTTP_HOST']; ?>");
  54.     if (!MyHOST.test(document.referrer)) {
  55.          location.href="http://" + MyHOST;
  56.     }
  57.     location.href="<?php echo $url;?>";
  58. }
  59. //延时1S跳转,可自行修改延时时间
  60. setTimeout(link_jump, 1000);
  61. //延时50S关闭跳转页面,用于文件下载后不会关闭跳转页的问题
  62. setTimeout(function(){window.opener=null;window.close();}, 50000);
  63. </script>
  64. <title><?php echo $title;?></title>
  65. <style type="text/css">
  66. body{background:#555}.loading{-webkit-animation:fadein 2s;-moz-animation:fadein 2s;-o-animation:fadein 2s;animation:fadein 2s}@-moz-keyframes fadein{from{opacity:0}to{opacity:1}}@-webkit-keyframes fadein{from{opacity:0}to{opacity:1}}@-o-keyframes fadein{from{opacity:0}to{opacity:1}}@keyframes fadein{from{opacity:0}to{opacity:1}}.spinner-wrapper{position:absolute;top:0;left:0;z-index:300;height:100%;min-width:100%;min-height:100%;background:rgba(255,255,255,0.93)}.spinner-text{position:absolute;top:45%;left:50%;margin-left:-100px;margin-top:2px;color:#000;letter-spacing:1px;font-size:20px;font-family:Arial}.spinner{position:absolute;top:45%;left:50%;display:block;margin-left:-160px;width:1px;height:1px;border:20px solid rgba(255,0,0,1);-webkit-border-radius:50px;-moz-border-radius:50px;border-radius:50px;border-left-color:transparent;border-right-color:transparent;-webkit-animation:spin 1.5s infinite;-moz-animation:spin 1.5s infinite;animation:spin 1.5s infinite}@-webkit-keyframes spin{0%,100%{-webkit-transform:rotate(0deg) scale(1)}50%{-webkit-transform:rotate(720deg) scale(0.6)}}@-moz-keyframes spin{0%,100%{-moz-transform:rotate(0deg) scale(1)}50%{-moz-transform:rotate(720deg) scale(0.6)}}@-o-keyframes spin{0%,100%{-o-transform:rotate(0deg) scale(1)}50%{-o-transform:rotate(720deg) scale(0.6)}}@keyframes spin{0%,100%{transform:rotate(0deg) scale(1)}50%{transform:rotate(720deg) scale(0.6)}}
  67. </style>
  68. </head>
  69. <body>
  70. <div class="loading">
  71.   <div class="spinner-wrapper">
  72.     <span class="spinner-text">页面加载中,请稍候...</span>
  73.     <span class="spinner"></span>
  74.   </div>
  75. </div>
  76. </body>
  77. </html>

将以上代码保存为go.php上传到网站根目录即可。

IIJS版本

  1. <html>
  2. <head>
  3. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  4. <meta name="robots" content="noindex, nofollow" />
  5. <script>
  6. //base64加密解密函数
  7. var base64EncodeChars="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";var base64DecodeChars=new Array(-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,62,-1,-1,-1,63,52,53,54,55,56,57,58,59,60,61,-1,-1,-1,-1,-1,-1,-1,0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,-1,-1,-1,-1,-1,-1,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,-1,-1,-1,-1,-1);function base64encode(str){var out,i,len;var c1,c2,c3;len=str.length;i=0;out="";while(i<len){c1=str.charCodeAt(i++)&255;if(i==len){out+=base64EncodeChars.charAt(c1>>2);out+=base64EncodeChars.charAt((c1&3)<<4);out+="==";break}c2=str.charCodeAt(i++);if(i==len){out+=base64EncodeChars.charAt(c1>>2);out+=base64EncodeChars.charAt(((c1&3)<<4)|((c2&240)>>4));out+=base64EncodeChars.charAt((c2&15)<<2);out+="=";break}c3=str.charCodeAt(i++);out+=base64EncodeChars.charAt(c1>>2);out+=base64EncodeChars.charAt(((c1&3)<<4)|((c2&240)>>4));out+=base64EncodeChars.charAt(((c2&15)<<2)|((c3&192)>>6));out+=base64EncodeChars.charAt(c3&63)}return out}function base64decode(str){var c1,c2,c3,c4;var i,len,out;len=str.length;i=0;out="";while(i<len){do{c1=base64DecodeChars[str.charCodeAt(i++)&255]}while(i<len&&c1==-1);if(c1==-1){break}do{c2=base64DecodeChars[str.charCodeAt(i++)&255]}while(i<len&&c2==-1);if(c2==-1){break}out+=String.fromCharCode((c1<<2)|((c2&48)>>4));do{c3=str.charCodeAt(i++)&255;if(c3==61){return out}c3=base64DecodeChars[c3]}while(i<len&&c3==-1);if(c3==-1){break}out+=String.fromCharCode(((c2&15)<<4)|((c3&60)>>2));do{c4=str.charCodeAt(i++)&255;if(c4==61){return out}c4=base64DecodeChars[c4]}while(i<len&&c4==-1);if(c4==-1){break}out+=String.fromCharCode(((c3&3)<<6)|c4)}return out}function utf16to8(str){var out,i,len,c;out="";len=str.length;for(i=0;i<len;i++){c=str.charCodeAt(i);if((c>=1)&&(c<=127)){out+=str.charAt(i)}else{if(c>2047){out+=String.fromCharCode(224|((c>>12)&15));out+=String.fromCharCode(128|((c>>6)&63));out+=String.fromCharCode(128|((c>>0)&63))}else{out+=String.fromCharCode(192|((c>>6)&31));out+=String.fromCharCode(128|((c>>0)&63))}}}return out}function utf8to16(str){var out,i,len,c;var char2,char3;out="";len=str.length;i=0;while(i<len){c=str.charCodeAt(i++);switch(c>>4){case 0:case 1:case 2:case 3:case 4:case 5:case 6:case 7:out+=str.charAt(i-1);break;case 12:case 13:char2=str.charCodeAt(i++);out+=String.fromCharCode(((c&31)<<6)|(char2&63));break;case 14:char2=str.charCodeAt(i++);char3=str.charCodeAt(i++);out+=String.fromCharCode(((c&15)<<12)|((char2&63)<<6)|((char3&63)<<0));break}}return out}function doit(){var f=document.f;f.output.value=base64encode(utf16to8(f.source.value));f.decode.value=utf8to16(base64decode(f.output.value))};
  8. //获取请求参数,支持伪静态
  9. function GetQueryString(name)
  10. {
  11.      var reg = new RegExp("(^|&)"+ name +"=(.*)$");
  12.      var r = window.location.search.substr(1).match(reg);
  13.      if(r!=null) {
  14.          return  unescape(r[2]);
  15.      } else {
  16.          return window.location.pathname.replace('/go/',''); //注意代码中的/goto/和跳转地址/goto/保持一致,请记得自行修改!
  17.      }
  18. }
  19. var jump_url = GetQueryString("url");
  20. //若传入的是base加密数据,则进行解密处理
  21. if( jump_url==base64encode(base64decode(jump_url))) {
  22.     jump_url = base64decode(jump_url);
  23. }
  24. //url简单正则
  25. var UrlReg = "^((http|https|thunder|qqdl|ed2k|Flashget|qbrowser|ftp|rtsp|mms)://)";
  26. //自定义一些跳转字符串,请根据实际需求自行发挥
  27. if(jump_url=="zhangge") {
  28.    var jump_url="https://zhangge.net/";
  29. }
  30. if(jump_url=="baidu") {
  31.   var jump_url="https://www.baidu.com/";
  32. }
  33. //网址校验
  34. if(jump_url == null || jump_url.toString().length<1 || !jump_url.match(UrlReg)) {
  35.     document.title = '参数错误,正在返回首页...';
  36.     jump_url = location.origin;
  37. }
  38. //延时执行跳转
  39. setTimeout(
  40. function link_jump()
  41. {
  42. //非本站域名不允许使用此跳转页面,请自行修改zhangge.net为自己的域名
  43.     var MyHOST = new RegExp("zhangge.net");
  44.     if (!MyHOST.test(document.referrer)) {
  45.         location.href = "http://" + MyHOST;
  46.         return;
  47.     }
  48.     location.href = jump_url;
  49. }, 1000);
  50. setTimeout(function(){window.opener=null;window.close();}, 50000);
  51. </script>
  52. <title>页面加载中,请稍候...</title>
  53. <style type="text/css">
  54. body{background:#555}.loading{-webkit-animation:fadein 2s;-moz-animation:fadein 2s;-o-animation:fadein 2s;animation:fadein 2s}@-moz-keyframes fadein{from{opacity:0}to{opacity:1}}@-webkit-keyframes fadein{from{opacity:0}to{opacity:1}}@-o-keyframes fadein{from{opacity:0}to{opacity:1}}@keyframes fadein{from{opacity:0}to{opacity:1}}.spinner-wrapper{position:absolute;top:0;left:0;z-index:300;height:100%;min-width:100%;min-height:100%;background:rgba(255,255,255,0.93)}.spinner-text{position:absolute;top:45%;left:50%;margin-left:-100px;margin-top:2px;color:#000;letter-spacing:1px;font-size:20px;font-family:Arial}.spinner{position:absolute;top:45%;left:50%;display:block;margin-left:-160px;width:1px;height:1px;border:20px solid rgba(255,0,0,1);-webkit-border-radius:50px;-moz-border-radius:50px;border-radius:50px;border-left-color:transparent;border-right-color:transparent;-webkit-animation:spin 1.5s infinite;-moz-animation:spin 1.5s infinite;animation:spin 1.5s infinite}@-webkit-keyframes spin{0%,100%{-webkit-transform:rotate(0deg) scale(1)}50%{-webkit-transform:rotate(720deg) scale(0.6)}}@-moz-keyframes spin{0%,100%{-moz-transform:rotate(0deg) scale(1)}50%{-moz-transform:rotate(720deg) scale(0.6)}}@-o-keyframes spin{0%,100%{-o-transform:rotate(0deg) scale(1)}50%{-o-transform:rotate(720deg) scale(0.6)}}@keyframes spin{0%,100%{transform:rotate(0deg) scale(1)}50%{transform:rotate(720deg) scale(0.6)}}
  55. </style>
  56. </head>
  57. <body>
  58. <div class="loading">
  59.   <div class="spinner-wrapper">
  60.     <span class="spinner-text">页面加载中,请稍候...</span>
  61.     <span class="spinner"></span>
  62.   </div>
  63. </div>
  64. </body>
  65. </html>

选择JS 版本将以上代码保存为 go.html 上传到网站根目录即可。

Ps:2个版本的功能是一致的,优缺点区别:PHP版本是动态的,会略微产生服务器的性能负载,而JS版本则需要浏览器支持JS才可以功能。不过目前来看,绝大部分浏览器都是支持的!

二、Nginx伪静态

之前的代码用的都是 “go.php?url=外链地址” 的形式,经常也看到有个别网站对外链跳转做了伪静态,也就是 “/goto/外链” 这种形式。想要实现这种伪静态,只要在Nginx中加入如下规则即可:

IPHP版本

  1. # 外链跳转伪静态 php版本
  2. rewrite ^/go/(.*)$ /go.php?url=$1 last; #注意go.php的实际路径,默认为网站根目录

IIJS 版本

  1. # 外链跳转伪静态 js 版本
  2. rewrite ^/go/(.*)$ /go.html?url=$1 last; #注意go.html 的实际路径,默认为网站根目录

III、张戈博客 TIPS

实际上,将php版本保存为 index.php 或 将JS版本保存为 index.html,然后在网站根目录新建一个go文件夹,把 index.php 或 index.html 上传到go文件夹中,那么Nginx就可以使用一条通用规则了:

  1. rewrite ^/go/(.*)$ /go/?url=$1 last;

因为 index.php 或 index.html 是WEB读取的默认文件,其中 index.html 一般优先级比 index.php更高一些,所以只需要重写到go目录即可,至于你选择js版本(go.html?url=)还是php版本(go.php?url=)就看你index放的是php还是html了。

Ps:上述代码如果不知道放到哪,可以直接放在 location / { 的前面即可。加入伪静态规则,并且重启Nginx之后,我们就可以通过 "/goto/外链加密串" 的方式进行跳转了。不过亲测发现无法使用 /goto/https://zhangge.net/xxx 这样直接丢http地址的方式进行跳转,因为http://会读取为 http:/,少了一个斜杠,这个之前博客文章其实有提到过,这里就不深究了。

三、Apache伪静态

还是有不少网站用的是Apache服务器,所以还是补充一下Aapace伪静态规则:

  1. RewriteRule ^go/(.*)$ /go.html?url=$1 [L]

将上述规则代码添加到 .htaccess 文件的第一行即可。

四、WordPress替换

做好了跳转页面,我们就需要将之前应用的相关函数都修改一下。其实就是将代码中的

/go/?url=外链

改成

/goto/base64加密串

的模式,下面贴一下具体代码,请自行参考修改。

A、文章外链替换

  1. //文章外链跳转伪静态版
  2. add_filter('the_content','link_jump',999);
  3. function link_jump($content){
  4.     preg_match_all('/<a(.*?)href="(.*?)"(.*?)>/',$content,$matches);
  5.     if($matches){
  6.         foreach($matches[2] as $val){
  7.             if(strpos($val,'://')!==false && strpos($val,home_url())===false && !preg_match('/\.(jpg|jepg|png|ico|bmp|gif|tiff)/i',$val) && !preg_match('/(ed2k|thunder|Flashget|flashget|qqdl):\/\//i',$val)){
  8.             $content=str_replace("href=\"$val\"""href=\"".home_url()."/go/".base64_encode($val)."\"",$content);
  9.             }
  10.         }
  11.     }
  12.     return $content;
  13. }

B、评论外链跳转

  1. //评论者链接重定向
  2. function commentauthor($comment_ID = 0) {
  3.     $url    = get_comment_author_url( $comment_ID );
  4.     $author = get_comment_author( $comment_ID );
  5.     if ( empty$url ) || 'http://' == $url ) {
  6.         echo $author;
  7.     } else {
  8.         if (!preg_match(home_url(),$url)) {
  9.             echo "<a href='".home_url()."/go/".base64_encode($url)."' rel='external nofollow' target='_blank' class='url'>$author</a>";
  10.         } else {
  11.             echo "<a href='$url' target='_blank' class='url'>$author</a>";
  12.         }
  13.     }
  14. }

C、下载外链跳转

  1. // 下载外链跳转
  2. function links_nofollow($url) {
  3.     if(strpos($url,'://')!==false && strpos($url,'zhangge.net')===false && !preg_match('/(ed2k|thunder|Flashget|flashget|qqdl):\/\//i',$url)) {
  4.     $url = str_replace($url, home_url()."/go/".base64_encode($url),$url);
  5.          }
  6.     return $url;
  7. }

用过之前外链跳转的网站,应该都有上述ABC代码,只要参考上述代码,修改一下替换后的链接形式即可。部署后,刷新前台文章或评论,就能看到效果了。

看了还是不太会的朋友,建议多看、多想、多动手、多搜索、少提问,这是网站折腾学习的不二法门!

文章标签: ,   ,  
原文地址:https://zhangge.net/5086.html
温馨提示:文章内容仅代表作者个人观点,不代表boke112导航赞同其观点和对其真实性负责!
版权声明:本文为转载文章,来源于 张戈博客 ,版权归原作者所有,欢迎分享本文,转载请保留出处!
WordPress免费响应式主题:Nana

发表评论


表情

  1. 张戈博客
    张戈博客 【镇长】 @回复

    //数据处理
    if(!emptyempty($t_url)) {
    这里多了一个empty

  2. 爱美说
    爱美说 【农民】 @回复

    求问一个问题,根据文章,把代码复制下来放进go.php中然后上传网站根目录,为什么文章的链接没有变化。。。

    • boke112导航
      boke112导航【站长】2016-08-09 14:12  回复

      @爱美说请认真阅读文章,弄好go.php文件后,还需要把你的外链变成带go跳转的链接地址,不明白的请看http://boke112.com/1906.html这篇基础文章

      • 爱美说
        爱美说 【农民】2016-08-09 15:15  回复

        @boke112导航根据你提供的地址,我进去看了一下,后面有更新说是自动替换文章中的外链为go跳转的形式,然后传送门来到你博文id为2021.html的文章,这篇文章是张戈的博文,我点进去后,里面的内容也是一再更新。最后变成只需要一个go.php文件即可。我看了一下你网站的外链跳转,你还是用的旧版的,张戈那边已经是用的伪静态base64加密的新版跳转代码

        • boke112导航
          boke112导航【站长】2016-08-09 17:47  回复

          @爱美说可以使用就行,我就是使用张戈新版的PHP文件,没有对那个GO链接地址进行修改,懒得折腾,你喜欢的话可以试试

  3. 快分享吧
    快分享吧 【队长】 @回复

    这个js的代码你自己测试了吗?我怎么测试一直不能用?

  4. 你爱屋博客
    你爱屋博客 【村长】 @回复

    看着貌似不错⊙▽⊙

  5. 我爱动感单车网
    我爱动感单车网 【省长】 @回复

    [流汗] 看到这些密密麻麻的代码我就头疼,哪怕功能再好,也只能是与我无缘了!

  6. 静松太极拳
    静松太极拳 【市长】 @回复

    张戈博客都来了,学习了

  7. 楚书业
    楚书业 【市长】 @回复

    看来我有必要要重新更新下啦!

  8. 好文章
    好文章 【省长】 @回复

    纯技术文章

  9. 伊檬博客
    伊檬博客 【队长】 @回复

    链接重定向会不会打消别人评论的积极性啊?

  10. 王商博客
    王商博客 【县长】 @回复

    我之前就是看到你分享的跳转代码,现在刚好修改一下就可以

  11. 静松太极拳
    静松太极拳 【市长】 @回复

    听说张戈博主是高手

  12. 明月登楼
    明月登楼 【总理】 @回复

    哇,好厉害呀!得研究一下!

  13. 姜辰
    姜辰 【市长】 @回复

    好腻害的样子~

  14. 网赚博客
    网赚博客 【农民】 @回复

    多谢分享啊

  15. 小C博客
    小C博客 【县长】 @回复

    学习中!!!

  16. 张戈博客
    张戈博客 【镇长】 @回复

    JS版本有点问题,解决中。

  17. 小宋日志
    小宋日志 【省长】 @回复

    学习啦。