typecho设置伪静态规则

2023-07-01 15:43:49 浏览数 (4)

环境说明: Nginx:1.18 ubuntu:20.04 博客框架:typecho 1.1-17.10.30

前言

记得当时我自己手动搭建好LNMP环境,安装上typecho之后,满心欢喜的打开网站首页,却发现除了首页其他的页面都是打不开的,全部显示“403”。当时还困饶了我大半天(后来才知道是没有正确设置伪静态的原因),一度以为是环境没搭好,重置服务器再搭环境这么试了好几次,还是一样的错误。后来,直到在其官方文档里看到服务器设置伪静态的方法,就尝试了一下,果然有用。(不过很奇怪的是在官方文档中是找不到这个文档页面的,当时还是在搜索引擎中才找到的)

以下为整个过程:

正文

首先找到网站的nginx配置文件,像我这样手动安装nginx的话,配置文件应该在/etc/nginx/site-enabled目录下面。在配置文件中加入以下的配置信息:

代码语言:javascript复制
if (-f $request_filename/index.html) {
    rewrite (.*) $1/index.html break;
}
if (-f $request_filename/index.php) {
    rewrite (.*) $1/index.php;
}
if (!-f $request_filename) {
    rewrite (.*) /index.php;
}

保存文件之后重启Nginx服务器:

代码语言:javascript复制
sudo nginx -s reload

然后进入博客的后台(域名/admin/),依次点击“网站设置”->“永久链接”->“是否使用地址重写功能”,选择“启用”,然后下面会有错误提示,不用管直接在下面打对勾,强制启用。

现在再访问网站,其他页面就可以打开了。

最后附上一些安装typecho博客过程中其他可能会出现的问题,转自服务器环境设置 - Typecho Docs :

1. 无法登录后台,出现"405, method not allowed"

这主要是由于nginx的固有bug导致,因为typecho使用的是静态化地址,而nginx 0.7之前的版本是不允许对静态地址做post请求的,所以会出现这个错误。

解决方法

升级nginx至0.7或者0.7以上的版本即可

2. 无法登录后台,点击前台链接或者后台登录时出现"404, not found"

这是nginx的设置时没有注意支持pathinfo导致的,具体关于php pathinfo的信息可以在网上搜索到。

解决方法

一般的出现这种情况时,nginx.conf里的的location设置都是类似这样

代码语言:javascript复制
location ~ .*.php$

要支持pathinfo,要改成

代码语言:javascript复制
location ~ .*.php(/.*)*$

然后在location里加上

代码语言:javascript复制
set $path_info "";
set $real_script_name $fastcgi_script_name;
if ($fastcgi_script_name ~ "^(. ?.php)(/. )$") {
set $real_script_name $1;
set $path_info $2;
}
fastcgi_param SCRIPT_FILENAME $document_root$real_script_name;
fastcgi_param SCRIPT_NAME $real_script_name;fastcgi_param PATH_INFO $path_info;

在某些老版本的php里面,可能还要打开php.ini里的cgi.fix_pathinfo

代码语言:javascript复制
cgi.fix_pathinfo = 1

1 人点赞