WordPress博客添加go跳转效果的详细教程(附跳转代码)

2019年4月22日19:42:53 1 0
摘要

经常看到一些博客点击外链跳转到其他网站上的时候都会有一个跳转页面,很是美观。据说既有利于SEO,又可保护站点避免权重流失,不过个人只是觉得好看、高逼格便加上了 。

仙踪小栈用的是知更鸟的Begin主题自带go跳转,但是别的主题不一定有,所以有些朋友就想移植这个功能,网上相关的源代码很多,只是代码使用的方法不太详细,对于很多新手小白可能并不友好,借着这次博客折腾我将把使用方法尽可能地详细说明,希望能够帮助新人快速地使用上这个跳转功能。

 

WordPress博客添加go跳转效果的详细教程(附跳转代码)

 

首先需要说明的是代码来自 AE博客 与 张戈博客 ,代码版权归原作者所有,这里仅介绍使用方法。实现 Go 页面跳转的简单原理是:以往我们跳转到其他网站是直接访问该网站的链接;使用 Go 页面跳转后,我们先访问本地的 Go 页面(也就是下面 go 文件夹下的 index.php 或直接 go.php文件)然后再跳转到相应的外链网站。

 

代码方法

代码部署

①、新建一个go.php文件,放置到wordpress的根目录下,在go.php里面输入以下代码

这是知更鸟Begin主题集成的go.php代码

  1. <?php
  2. // http://www.ixianzong.com/
  3. $t_url = preg_replace('/^url=(.*)$/i','$1',$_SERVER["QUERY_STRING"]);
  4. if(!emptyempty($t_url)) {
  5.     preg_match('/(http|https):\/\//',$t_url,$matches);
  6.     if($matches){
  7.         $url=$t_url;
  8.         $title='页面加载中,请稍候...';
  9.     } else {
  10.         preg_match('/\./i',$t_url,$matche);
  11.         if($matche){
  12.             $url='http://'.$t_url;
  13.             $title='页面加载中,请稍候...';
  14.         } else {
  15.             $url='http://www.ixianzong.com/';
  16.             $title='参数错误,正在返回首页...';
  17.         }
  18.     }
  19. else {
  20.     $title='参数缺失,正在返回首页...';
  21.     $url='http://www.ixianzong.com/';
  22. }
  23. ?>
  24. <html>
  25. <head>
  26. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  27. <meta http-equiv="refresh" content="1;url='<?php echo $url;?>';">
  28. <title><?php echo $title;?></title>
  29. <style>
  30. body{background:#000}.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:50%;left:50%;margin-left:-90px;margin-top: 2px;color:#BBB;letter-spacing:1px;font-weight:700;font-size:36px;font-family:Arial}.spinner{position:absolute;top:50%;left:50%;display:block;margin-left:-160px;width:1px;height:1px;border:25px solid rgba(100,100,100,0.2);-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)}}
  31. </style>
  32. </head>
  33. <body>
  34. <div class="loading">
  35.   <div class="spinner-wrapper">
  36.     <span class="spinner-text">页面加载中,请稍候...</span>
  37.     <span class="spinner"></span>
  38.   </div>
  39. </div>
  40. </body>
  41. </html>

使用方法

②、保存,则外链跳转形式为: {本站地址}/go.php?url={外链地址}

使用:在添加外链的时候,只要给外链加上统一的跳转前缀:http://网站地址/go.php?url= 即可。


 

外链方法的使用是需要在手动添加外链的,同时跳转样式可以自行修改。但是这样每次添加外链都手动添加的话太麻烦,使用下面的代码既可以实现外链自动添加http://网站地址/go.php?url=

 

A、文章内外链添加go跳转

在主题目录下的functions.php新增如下函数,即可将文章中的外链替换为go跳转的形式:

  1. //文章内外链添加go跳转
  2. add_filter('the_content','the_content_nofollow',999);
  3. function the_content_nofollow($content)
  4. {
  5.     preg_match_all('/<a(.*?)href="(.*?)"(.*?)>/',$content,$matches);
  6.     if($matches){
  7.     foreach($matches[2] as $val){
  8.     if(strpos($val,'://')!==false && strpos($val,home_url())===false && !preg_match('/\.(jpg|jepg|png|ico|bmp|gif|tiff)/i',$val)){
  9.         $content=str_replace("href=\"$val\"""href=\"".home_url()."/go.php?url=$val\" ",$content);
  10.     }
  11.     }
  12.     }
  13.     return $content;
  14. }

 

B、评论者链接添加go跳转

在主题目录下的functions.php查找是否存在修改评论链接为新窗口commentauthor函数,如果存在则如下修改第8行,将$url修改为/go.php/?url=$url,其实就是在前面新增一个go跳转即可,相同的道理!

  1. //评论者链接添加go跳转
  2.  add_filter('get_comment_author_link', 'add_redirect_comment_link', 5);
  3.  add_filter('comment_text', 'add_redirect_comment_link', 99);
  4.  function add_redirect_comment_link($text = ''){
  5.     $text=str_replace('href="', 'href="'.get_option('home').'/go.php?url=', $text);
  6.     return $text;
  7.  }

Ps:如果functions里面没有这个评论新窗口的函数,请自己找到评论列表输出的代码位置(可能在comments.php),然后参考修改即可(国内主题一般都会有个评论新窗口函数,自己仔细找找看)!

只要参考上述代码,修改一下替换后的链接形式即可。部署后,刷新前台文章或评论,就能看到效果了。

此方法博主未测试,如在使用过程中遇到问题请在下方留言或都查看原文。

 

一般情况下我们将站点的这两处链接替换掉就可以了,当然如果你有其他需要只需要想办法将原有外链替换为带有 http://网站地址/go.php?url= 的就可以了。为了避免 go 页面文件复制粘贴过程中出现错误,下面给大家提供3种源文件的下载。

 

效果参考

点击查看:http://weibo.com/ixianzong

 

插件实现

有些插件也能实现这个外链跳转

1. Simple URLs插件

设置简单,只需要要后台设置好后缀和目标页面即可

2. Link-Hopper插件

跳转链接的基础地址可以随意设置

3. Pretty Link Lite插件

后台功能十分强大的,还有Pro版本,不过要money的。用它完全可以做一个短网址,像t.cn和bit.ly一样。

4. Affiliate Link Cloaking插件

推广链接转换工具,用来推广你的淘宝客等要隐藏的链接,可以使用它,附带统计功能。

5. WP No External Links插件

这个一款可以自动将博客内的外部链接转成内部链接,如http://www.baidu.com,则显示为http://www.orwei.com/goto/http://www.baidu.com,可以尝试使用这个插件防权重丢失的。

6. Go Codes插件

和前面的wordpress外链跳转链接插件设置一样简单,带统计功能。


插件具体使用与否可以自己尝试,这里不做太多解释,也不对插件对错负责。

 

 

若文章图片、下载链接等信息出错,请在评论区留言反馈,博主将第一时间更新!如果喜欢,请打赏支持本站,谢谢大家!

Warning: mysqli_query(): (HY000/1194): Table 'wp_posts' is marked as crashed and should be repaired in /home/www/ixianzong.com/wp-includes/class-wpdb.php on line 2431

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

目前评论:1   其中:访客  0   博主  0

    • 叶忠文博客 叶忠文博客 4 来自天朝的朋友 火狐浏览器 Windows 10 湖北省武汉市 联通

      这个功能牛逼