请注意,本文编写于 1043 天前,最后修改于 488 天前,其中某些信息可能已经过时。
最近一段时间一直被这个宝塔面板默认给的 wordpress 的伪静态规则所困扰。
不设置伪静态规则,则前台大家的文章内页会无法访问,返回 404,所以这肯定是要设置的。但是伪静态规则设置了之后,前台是能正常访问了,但是后台我的 wordpress 的文章的 “分类目录”、“标签” 这两个的页面均无法正常访问,返回 404。
对应页面链接为:
https://16886.net/wp-admin/edit-tags.php?taxonomy=category
https://16886.net/wp-admin/edit-tags.php?taxonomy=post_tag
可以看到,他们都有一个共同的特点,用的都是 edit-tags.php
,带的访问参数名都是 taxonomy
,值不一样。
这导致了什么问题呢?
- 无法设置新的分类目录,也无法管理现有的分类目录。这个还好,不是经常操作的。
- 无法在写文章的时候给文章添加文章标签,每次一添加标签写文章的页面就会刷新,压根无法加标签。这个就是最烦人的。
这导致了我在近期的一段时间内,很憋屈的,当需要给文章加标签的时候,需要到后台先删除网站的伪静态配置(这会短暂的让大家无法看文章内页),然后我用迅雷不及掩耳之势编写好文章的标签。然后再赶紧加上伪静态配置,这才完成,每次都超级麻烦。我知道问题肯定是出来了伪静态的配置上(之前我定位问题也定位了好几天)。
因此我近段时间都在想有什么办法来解决这个问题呢?
其实也不是没想过。
网站用的是 IIS,不比以前用 apache 或者有的人用的 ngnix。然后宝塔面板的伪静态配置用的不是过去的什么 httpd.ini
文件,所以很多过去的网站发表的文章的方法都失效了。
网站用的是 web.config
文件(一种 IIS 的配置文件)来进行网站配置。
web.config
文件里面会写入伪静态规则的配置:
<?xml version="1.0" ?>
<configuration>
<location allowOverride="false" inheritInChildApplications="false" path=".">
<system.webServer>
<rewrite>
<rules configSource="web_configrewrite.config"></rules>
</rewrite>
<defaultDocument configSource="web_configdefault.config"></defaultDocument>
<httpErrors configSource="web_confighttpErrors.config"></httpErrors>
<handlers configSource="web_configphp.config"></handlers>
</system.webServer>
</location>
</configuration>
可以发现,这里的这一行:<rules configSource="web_configrewrite.config"></rules>
表示的就是在下一级目录中有一个叫做 rewrite.config
的文件是用来写伪静态的规则的。
目前宝塔面板给的 wordpress 默认的伪静态规则是这样的:
<?xml version="1.0" ?>
<rules>
<rule name="category_rewrite">
<match url="category/?(.*)"/>
<conditions logicalGrouping="MatchAll" trackAllCaptures="false"/>
<action appendQueryString="false" logRewrittenUrl="false" type="Rewrite" url="/index.php?category_name={R:1}"/>
</rule>
<rule name="tags_rewrite">
<match url="tag/?(.*)"/>
<conditions logicalGrouping="MatchAll" trackAllCaptures="false"/>
<action type="Rewrite" url="index.php?tag={R:1}"/>
</rule>
<rule name="Main Rule_rewrite" stopProcessing="true">
<match url=".*"/>
<conditions logicalGrouping="MatchAll" trackAllCaptures="false">
<add input="{REQUEST_FILENAME}" matchType="IsFile" negate="true"/>
<add input="{REQUEST_FILENAME}" matchType="IsDirectory" negate="true"/>
</conditions>
<action type="Rewrite" url="index.php/{R:0}"/>
</rule>
<rule name="wordpress_rewrite" patternSyntax="Wildcard">
<match url="*"/>
<conditions logicalGrouping="MatchAll" trackAllCaptures="false">
<add input="{REQUEST_FILENAME}" matchType="IsFile" negate="true"/>
<add input="{REQUEST_FILENAME}" matchType="IsDirectory" negate="true"/>
</conditions>
<action type="Rewrite" url="index.php"/>
</rule>
</rules>
其中大家可以看到有四段规则。当然这些我百度了老半天了,一直没能解决问题,也看了一些英文网站,依然无法解决。当然在宝塔的论坛也有发过帖子,看着别人的问题都是有解答的我想这个用你们产品的问题应该有解答吧,应该很快吧。但让我失望的是,几个月过去了,宝塔的运维理都不理,还好近期看到自己的帖子被另外一位网友评论了,说自己也遇到了类似的问题,但不知道怎么解决。
可以说,这个办法是全网首发。
我只好自己找资料,自己尝试写规则测试。还好,我看得懂一些英文。雅思英语还是过关的。
最后我想了一个办法,将这里的四段规则删除一些,留下一些,把可疑的单独删除,看能否正常访问。幸运的是,最后让我测试出来了,问题出现在这一段上:
<rule name="tags_rewrite">
<match url="tag/?(.*)"/>
<conditions logicalGrouping="MatchAll" trackAllCaptures="false"/>
<action type="Rewrite" url="index.php?tag={R:1}"/>
</rule>
我一想,这是用来给 tag 前台标签能正常访问的伪静态规则,为啥会影响到后台页面呢?后来我猜,有可能是我访问的分类目录和标签的页面都有 edit-tags.php
,这不有 tag 单词在里面吗?难道是多匹配了?
这里有两个解决方案,目前还未确定哪种最好,我需要先用一段时间再看吧。
第一种方案:
直接把这段规则删除。
我删除后,无需重启服务器等,分类目录、标签等页面就已经能正常访问了,也能给文章加标签了。
但我猜测这样有可能前台访问类似这样的链接:
http://fox-9.com/tag/post/
的时候会找不到网页。
但让我诧异的是,访问也是正常的。
目前我用这种方法测试一下后续是否有问题。
所以直接删除造成的问题我们后面再看。
补充说明一点,我是安装了一个中文 tag 也能显示的插件的,叫做:IIS Chinese Tag Permalink
这个插件就一个 iis-chinese-tag-permalink.php
文件,它的代码为:
<?php
add_action('init', 'bossma_get_urf8_pathandurl');
add_filter('get_pagenum_link','bossma_set_utf8_pagenumlink');
add_action('parse_query','bossma_chinese_tag_encode');
function bossma_get_urf8_pathandurl() {
$_SERVER['PATH_INFO']=iconv("GBK","UTF-8",$_SERVER['PATH_INFO']);
$_SERVER['REQUEST_URI']=iconv("GBK","UTF-8",$_SERVER['REQUEST_URI']);
}
function bossma_chinese_tag_encode($query){
if(isset($is_tag)&&$is_tag){
if($query->query_vars['tag']!=''){
$query->query_vars['tag']=urlencode($query->query_vars['tag']);
}
}
}
function bossma_set_utf8_pagenumlink($result){
$tag_index=stripos($result,"/tag/");
$link_len=strlen($result);
if($tag_index!==false){
$link_base=substr($result,0,$tag_index);
$page_index=stripos($result,"/page/");
if($page_index!==false){
$tag_str=substr($result,$tag_index+5,$page_index-$tag_index-5);
$result=$link_base."/tag/".rawurlencode($tag_str).substr($result,$page_index);
}else{
$tag_str=substr($result,$tag_index+5);
$result=$link_base."/tag/".rawurlencode($tag_str)."/";
}
}
return $result;
}
?>
第二种方案:
将伪静态规则修改为这样,让它匹配不到 edit-tags
:
<rule name="tags_rewrite">
<match url="/tag/?(.*)"/>
<conditions logicalGrouping="MatchAll" trackAllCaptures="false"/>
<action type="Rewrite" url="index.php?tag={R:1}"/>
</rule>
可以看到就多加了一个 /
,匹配规则变成了 /tag/?(.*)
,这样就不会匹配到 edit-tags
路径了。
目前测试发现,这个方法存在一个问题,就是偶尔的,文章在添加新的标签的时候,或者在所有文章的页面点击 “快速编辑” 按钮的时候会无法编辑或者刷新页面。
如果你也有类似的问题,希望我的文章和解决方案能够帮到你,谢谢!欢迎跟我交流!
转载自《雪山凌狐教程》
相关