WordPress实现外链加密及伪静态跳转

很早就分享过张戈博客关于 wordpress 网站外链转内链的优化代码,当初由于对 Nginx 服务器比较陌生,根本就不敢根据文中所说的去折腾外链转内链跳转地址为 Base64 加密地址,不过现在终于有胆量去折腾了,而且还一次过成功了,所以今天特意跟大家分享一下。外链转内链跳转地址为 Base64 加密地址的详细步骤:
1、将以下跳转代码保存为 index.php,然后在网站根目录新建一个 go 文件夹,并把 index.php 上传到 go 文件夹中:

  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=="yigujin" ) {
  14.        $t_url="https://www.yigujin.cn";
  15.     } elseif($t_url=="nana") {
  16.        $t_url="https://www.yigujin.cn/nana";
  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>

其中第行代码中自定义的一些特别外链,这个功能特别好,因为我们每个站点都或多或少有一些特殊的外链,如果也变成 Base64 加密地址就不好看了,所以此处我们可以多添加几个比较有个性化的外链跳转地址。

2、将以下代码添加到我们的 Nginx 服务器相应配置文件中的 location / { 前面,保存配置文件后平滑重启 Nginx 即可:

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

3、替换文章原外链跳转地址格式(/go/?url=外链)变更为新的外链格式(/goto/ base64 加密串),我们只需要将以下代码代替主题文件的 functions.php 文件中原先给外部链接加上跳转的代码即可:

  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()."/goto/".base64_encode($val)."\"",$content);
  9.                 }
  10.             }
  11.         }
  12.         return $content;
  13.     }

4、对于评论外链,是不需要改变成 base64 加密串的,保持原汁原味会比较好,所以本站就没有做评论外链跳转的相关操作,所以这步更变评论外链的步骤直接忽略。

5、将下载原外链跳转地址格式(/go/?url=外链)变更为新的外链格式(/goto/ base64 加密串),我们首先将以下代码添加到主题文件 functions.php 文件最后一个?>(记得修改代码中的 boke112.com 为自己的域名)。

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

然后将主题文件中关于下载链接的地址改为以下代码即可:

  1. <?php echo links_nofollow($url);?>

boke112 导航的下载链接文件就在 inc\file.php(其他主题请自行寻找),然后将四个下载链接地址分别改成上述相对应的代码即可,如将第一个下载链接地址:

  1. <?php echo $url1; ?>

改为:

  1. <?php echo links_nofollow($url1);?>

至此,外链及下载地址均变成新的跳转格式(/goto/ base64 加密串),最难得的是原旧跳转格式(/go/?url=外链)依然有效,这个才是值得点赞的。

PS:还记得我们第一步自定义的那些个性化外链吗?到了这里,我们就可以在文章内或侧边栏或广告栏添加相应的链接了。

原创文章,作者:DavidWu,如若转载,请注明出处:https://www.davidwu.net/archives/88472

WordPress安全防护插件
服务项目 服务内容 收费标准(元)
开发定制 WordPress主题/插件开发定制 (以最终需求为准)
主题/插件汉化 汉化团队WordPress主题/插件,翻译率95% (以标的主题/插件的句子数量为准)
服务器环境配置 基于您现有服务器,搭建配置网站运行环境,结合我们多年来实战经验,可完美支持WordPress等PHP程序运行,并配置伪静态规则、优化目录权限等问题。服务器我们强烈推荐使用Linux系统。 100元/次
网站托管 若贵站目前尚无技术人员,无法完成服务器环境配置,可选择我们的网站托管服务,直接交付正常运行的WordPress站点,并且无需担心服务器的后续维护工作,一切都由我们来帮您完成。 标配套餐:1000元/年/站点 高配套餐:联系客服获取
网站加速优化 从服务器后端配置优化到WordPress数据库缓存、前端页面缓存、JS和CSS压缩合并,全方位优化网站加载速度,实现秒开。(此服务仅针对(云)服务器/VPS) 500元/次(仅站内优化200元/次)
主题配置 本站所有主题均支持,可快速实现,若有任何问题可以咨询客服解决,若您希望我们提供配置服务,可选购此服务。 英文主题安装 60元/次 汉化主题安装 30元/次
HTTPS配置 HTTPS已经不断普及,并且有着更高的安全性以及SEO上的优待。该服务收取的为服务费,SSL证书产生的费用请自行承担。 100元/次
网站搬家 迁移网站所有文件和数据库信息、网站相关配置的调整、以及迁移中的疑难问题故障排除。 标准收费:500元/次 若网站数据量大,需协商
网站运维 提供整站的运维服务,保证网站正常运行。包含:网站故障定位及排除、网站数据备份和恢复、网站攻击及木马等问题的处理等 标准收费:2000元/年 IP 5000以上需协商

发表评论

电子邮件地址不会被公开。 必填项已用*标注

51建站客服微信二维码
点击这里购买