WordPress固定链接404的解决办法

mengkun 16.5K 21

一般的大型网站系统,都依赖伪静态。如果服务器的伪静态没有配置好,访问部分链接就会出现 404 的情况。

在 WordPress 则具体表现为后台“固定链接”选项设置失效

mkBlog主题的说说、搜索以及外链 GO 跳转就采用了高大上的伪静态的形式而无需新建页面(其它的主题一般都需要新建页面,忒麻烦![aru_30]),因此如果使用 mkBlog 主题,也必须配置好伪静态。[aru_49]

下面就提供各种 web 环境下的 WordPress 伪静态规则设置教程。

Apache、Kangle伪静态

下载 Apache -Kangle WordPress 伪静态配置文件,解压后将里面的 .htaccess 上传至网站根目录,然后在 WordPress 后台>设置>固定链接>拉到最下面点击“保存更改”即可。

Nginx伪静态

打开nginx.conf或者某个站点的配置环境,比如 mkblog.cn.conf(不同的网站配置不一样),在server { }大括号里面添加下面的代码:

  1. location / {  
  2.     index index.html index.php;   
  3.     if (-f $request_filename/index.html){   
  4.         rewrite (.*) $1/index.html break;   
  5.     }   
  6.     if (-f $request_filename/index.php){   
  7.         rewrite (.*) $1/index.php;   
  8.     }   
  9.     if (!-f $request_filename){   
  10.         rewrite (.*) /index.php;   
  11.     }   
  12. }   
  13.   
  14. rewrite /wp-admin$ $scheme://$host$uri/ permanent;  

然后在 WordPress 后台>设置>固定链接>拉到最下面点击“保存更改”即可。

IIS伪静态

这里强烈不推荐使用 Windows+IIS 建站,因为坑太多!

IIS 的版本不同,伪静态的设置方式也不一样。

如果你的站点根目录有 web.config 文件,则打开 web.config,在 system.webServer 里加入如下代码:

  1. <rewrite>  
  2.     <rules>  
  3.         <rule name="WordPress" patternSyntax="Wildcard">  
  4.             <match url="*"/>  
  5.                 <conditions>  
  6.                     <add input="{REQUEST_FILENAME}" matchType="IsFile" negate="true"/>  
  7.                     <add input="{REQUEST_FILENAME}" matchType="IsDirectory" negate="true"/>  
  8.                 </conditions>  
  9.             <action type="Rewrite" url="index.php"/>  
  10.         </rule>  
  11.     </rules>  
  12. </rewrite>  

如下图所示:
WordPress固定链接404的解决办法

然后在 WordPress 后台>设置>固定链接>拉到最下面点击“保存更改”即可。

如果你的站点根目录没有 web.config 文件,则试试下面这种方法:

先新建一个 txt 文件,将下面的代码复制粘贴过去:

  1. [ISAPI_Rewrite]  
  2. # Defend your computer from some worm attacks  
  3. #RewriteRule .*(?:global.asa|default\.ida|root\.exe|\.\.).* . [F,I,O]  
  4. # 3600 = 1 hour  
  5.    
  6. CacheClockRate 3600  
  7. RepeatLimit 32  
  8.    
  9. # Protect httpd.ini and httpd.parse.errors files  
  10. # from accessing through HTTP  
  11. # Rules to ensure that normal content gets through  
  12.    
  13. RewriteRule /tag/(.*) /index\.php\?tag=$1  
  14. RewriteRule /software-files/(.*) /software-files/$1 [L]  
  15. RewriteRule /images/(.*) /images/$1 [L]  
  16. RewriteRule /sitemap.xml /sitemap.xml [L]  
  17. RewriteRule /favicon.ico /favicon.ico [L]  
  18. # For file-based wordpress content (i.e. theme), admin, etc.  
  19. RewriteRule /wp-(.*) /wp-$1 [L]  
  20. # For normal wordpress content, via index.php  
  21. RewriteRule ^/$ /index.php [L]  
  22. RewriteRule /(.*) /index.php/$1 [L]  

然后另存为 httpd.ini 文件,上传到网站根目录,再到 WordPress 后台>设置>固定链接>拉到最下面点击“保存更改”即可。

IIS另类方法

其实还有一种另类的方法,不过不推荐使用此方法,治标不治本。

在网站根目录建立一个 404.php 文件。然后打开编辑,插入如下代码:

  1. <?php   
  2. $qs = $_SERVER['QUERY_STRING'];  
  3. $_SERVER['REQUEST_URI'] = substr($qsstrpos($qs,':80')+3);  
  4. $_SERVER['PATH_INFO'] = $_SERVER['REQUEST_URI'];  
  5. include('index.php');  
  6. ?>  

参考资料:http://www.admin5.com/article/20130711/514219.shtml

宝塔面板设置伪静态

如果你的服务器上安装了宝塔面板,就方便多了——

在 宝塔面板>网站>设置>伪静态 里选择对应的伪静态规则(WordPress)并保存即可。

别忘了必备操作:在 WordPress 后台>设置>固定链接>拉到最下面点击“保存更改”![aru_56]

后记

如果你按照上述方法设置了还是不起作用,那么有可能是你的服务器压根就没有安装伪静态模块!请自行搜索对应教程安装或联系服务器提供商解决[aru_59]

发表评论 取消回复
表情 图片 链接 代码

  1. 隐匿
    隐匿 Lv 1

    重点在宝塔[aru_17]

  2. beibei
    beibei Lv 1

    终于可以碎觉了 把百度找遍了才看到你 必须得顶上去让大家节省时间

  3. beibei
    beibei Lv 1

    顶上去

  4. 杰新博客
    杰新博客 Lv 3

    学习中...[aru_10]

  5. 666
    666 Lv 1

    找了一万篇文章,就你这个成功了

  6. Maybe
    Maybe Lv 1

    [aru_135]伪静态

  7. 嬴冰
    嬴冰 Lv 1

    个人觉得小白还是面板安逸些,要不然瞎搞出问题也是常有的事情。我就喜欢面板,多省事啊[aru_2]

  8. 泪雪博客
    泪雪博客 Lv 1

    没办法,WordPress除了动态就是伪静态,要想缓存就得依靠插件或者开发,而且现在的主机或者服务器都可以比较方便的配置伪静态规则,其实也还是蛮不错的。

  9. kissrain
    kissrain Lv 1

    还是用面板安逸,个性化操作,人性化界面,我喜欢#(捂嘴笑)

  10. 老司机
    老司机 Lv 5

    感觉可以加上“上一篇 ,下一篇”翻页

  11. 老司机
    老司机 Lv 5

    一日不水,万分难受

  12. 小白-白
    小白-白 Lv 2

    [aru_8]IIS我用的404.PHP大法

  13. 陈鑫威blog
    陈鑫威blog Lv 1

    没错,孟坤又水了一篇文章[aru_13]

  14. 惶心
    惶心 Lv 2

    孟坤又水了一篇~

  15. admin
    admin Lv 1

    学会了

  16. 隔壁小蒋
    隔壁小蒋 Lv 2

    [aru_66]点击图片的这个效果,咋实现 https://i.loli.net/2018/02/27/5a94c55b4d7ac.png

    • mengkun
      mengkun 站长

      @隔壁小蒋添加媒体(图片)时选择链接到媒体文件 查看图片

      • 隔壁小蒋
        隔壁小蒋 Lv 2

        @mengkun[aru_147]搞定啦

      • 反馈吧
        反馈吧 Lv 1

        @mengkun博主上传图床是一张一张传的吗?[aru_66]https://ws1.sinaimg.cn/large/a15b4afegy1fout5zefztj208a073glp.jpg

分享