“配置MW:短链接”的版本间差异
小 (Eijux移动页面短链接:MediaWiki至MediaWiki:短链接,不留重定向) |
无编辑摘要 |
||
第11行: | 第11行: | ||
=== LocalSettings.php设置 === | === LocalSettings.php设置 === | ||
如下: | 如下: | ||
< | <syntaxhighlight lang="php" line> | ||
# Short URL | # Short URL | ||
$wgArticlePath = "/$1"; | $wgArticlePath = "/$1"; | ||
$wgUsePathInfo = true; | $wgUsePathInfo = true; | ||
$wgScriptExtension = ".php"; | $wgScriptExtension = ".php"; | ||
</ | </syntaxhighlight> | ||
=== nginx configuration设置 === | === nginx configuration设置 === | ||
第22行: | 第22行: | ||
(宝塔中站点的nginx配置文件(如"wiki.eijux.com.conf"),位于"/www/server/panel/vhost/nginx")<br/> | (宝塔中站点的nginx配置文件(如"wiki.eijux.com.conf"),位于"/www/server/panel/vhost/nginx")<br/> | ||
添加: | 添加: | ||
< | <syntaxhighlight lang="php" line> | ||
location / { | location / { | ||
try_files $uri $uri/ @rewrite; | try_files $uri $uri/ @rewrite; | ||
第30行: | 第30行: | ||
rewrite ^/(.*)$ /index.php; | rewrite ^/(.*)$ /index.php; | ||
} | } | ||
</ | </syntaxhighlight> | ||
就可完成短链接的转换。另: | 就可完成短链接的转换。另: | ||
< | <syntaxhighlight lang="php" line> | ||
# 限制访问.ht文件 | # 限制访问.ht文件 | ||
location ~ \.ht { | location ~ \.ht { | ||
第56行: | 第56行: | ||
try_files $uri @rewrite; | try_files $uri @rewrite; | ||
} | } | ||
</ | </syntaxhighlight> | ||
=== 重载nginx配置 === | === 重载nginx配置 === | ||
第66行: | 第66行: | ||
设置以上<code>$wgArticlePath</code>等设置之后,页面的链接变为了短链接(如:<code>http://wiki.eijux.com/%E9%A6%96%E9%A1%B5</code>),但是页面的编辑、移动、删除、历史等页面,仍然是长链接页面(如:<code>http://wiki.eijux.com/%E9%A6%96%E9%A1%B5?action=edit&veswitched=1</code>),若要使操作页面也应用短链接,则应该设置<code>$wgActionPaths</code>。(参见[https://www.mediawiki.org/wiki/Manual:$wgActionPaths#Spam_prevention Manual:$wgActionPaths])<br/> | 设置以上<code>$wgArticlePath</code>等设置之后,页面的链接变为了短链接(如:<code>http://wiki.eijux.com/%E9%A6%96%E9%A1%B5</code>),但是页面的编辑、移动、删除、历史等页面,仍然是长链接页面(如:<code>http://wiki.eijux.com/%E9%A6%96%E9%A1%B5?action=edit&veswitched=1</code>),若要使操作页面也应用短链接,则应该设置<code>$wgActionPaths</code>。(参见[https://www.mediawiki.org/wiki/Manual:$wgActionPaths#Spam_prevention Manual:$wgActionPaths])<br/> | ||
如,设置Action在页面之后: | 如,设置Action在页面之后: | ||
< | <syntaxhighlight lang="php" line> | ||
# Short URL of Action | # Short URL of Action | ||
$actions = array( 'edit', 'watch', 'unwatch', 'delete','revert', 'rollback', 'protect', 'unprotect', 'markpatrolled', 'render', 'submit', 'history', 'purge', 'info' ); | $actions = array( 'edit', 'watch', 'unwatch', 'delete','revert', 'rollback', 'protect', 'unprotect', 'markpatrolled', 'render', 'submit', 'history', 'purge', 'info' ); | ||
第74行: | 第74行: | ||
$wgActionPaths['view'] = "/$1"; | $wgActionPaths['view'] = "/$1"; | ||
$wgArticlePath = $wgActionPaths['view']; | $wgArticlePath = $wgActionPaths['view']; | ||
</ | </syntaxhighlight> | ||
则页面编辑链接为<code>http://wiki.eijux.com/%E9%A6%96%E9%A1%B5/edit</code>。 | 则页面编辑链接为<code>http://wiki.eijux.com/%E9%A6%96%E9%A1%B5/edit</code>。 | ||
2020年9月14日 (一) 18:48的版本
短URL或URL重写会隐藏页面地址中的php文件扩展名。格式如:http://wiki.eijux.com/%E9%A6%96%E9%A1%B5
、http://wiki.eijux.com/wiki/%E9%A6%96%E9%A1%B5
MediwWiki默认的文章链接格式为如:http://wiki.eijux.com/index.php?title=%E9%A6%96%E9%A1%B5
默认文章操作链接格式如:http://wiki.eijux.com/index.php?title=%E9%A6%96%E9%A1%B5&action=edit
(短链接的修改参见Manual:Short URL页面,对于MediaWiki设置Short URL的注意事项,以及针对不同服务器环境的配置都十分具体。)
配置步骤
(此次采用的设置参见Manual:Short URL/Page title - nginx, Root Access, PHP as a CGI module)
LocalSettings.php设置
如下:
# Short URL
$wgArticlePath = "/$1";
$wgUsePathInfo = true;
$wgScriptExtension = ".php";
nginx configuration设置
修改站点的nginx配置文件,使用BTPabel安装的LNMP环境,可在面板操作“网站->wiki.eijux.com设置->配置文件”进行设置。
(宝塔中站点的nginx配置文件(如"wiki.eijux.com.conf"),位于"/www/server/panel/vhost/nginx")
添加:
location / {
try_files $uri $uri/ @rewrite;
}
location @rewrite {
rewrite ^/(.*)$ /index.php;
}
就可完成短链接的转换。另:
# 限制访问.ht文件
location ~ \.ht {
deny all;
}
# 限制对maintenance该路径的访问,返回403
location ^~ /maintenance/ {
return 403;
}
# 以下配置允许运行.php的程序
# 关于fastcgi的配置,参见"/www/server/nginx/conf"中的"enable-php-73.conf"
# ("fastcgi_params"和"fastcgi.conf"均位于"/www/server/nginx/conf"中)
location ~ \.php$ {
include /www/server/nginx/conf/fastcgi_params;
fastcgi_pass unix:/tmp/php-cgi-73.sock;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
try_files $uri @rewrite;
}
重载nginx配置
使用BTPanel或命令进行nginx的重载配置。
完成配置。长链接http://wiki.eijux.com/index.php?title=%E9%A6%96%E9%A1%B5
、短链接http://wiki.eijux.com/%E9%A6%96%E9%A1%B5
均可正常访问。
关于$wgActionPaths
设置以上$wgArticlePath
等设置之后,页面的链接变为了短链接(如:http://wiki.eijux.com/%E9%A6%96%E9%A1%B5
),但是页面的编辑、移动、删除、历史等页面,仍然是长链接页面(如:http://wiki.eijux.com/%E9%A6%96%E9%A1%B5?action=edit&veswitched=1
),若要使操作页面也应用短链接,则应该设置$wgActionPaths
。(参见Manual:$wgActionPaths)
如,设置Action在页面之后:
# Short URL of Action
$actions = array( 'edit', 'watch', 'unwatch', 'delete','revert', 'rollback', 'protect', 'unprotect', 'markpatrolled', 'render', 'submit', 'history', 'purge', 'info' );
foreach ( $actions as $action ) {
$wgActionPaths[$action] = "/$1/$action";
}
$wgActionPaths['view'] = "/$1";
$wgArticlePath = $wgActionPaths['view'];
则页面编辑链接为http://wiki.eijux.com/%E9%A6%96%E9%A1%B5/edit
。
- 但是:
- 使用
$wgActionPaths
设置,则不能创建某些与$actions
中定义的操作词相关的页面,如:创建名为“首页/edit”(action后置)、“edit/首页”(action后置)、“首页/history”的页面时,会跳转到“首页”相关的操作页面。所以不建议使用,或者修改$actions
的操作词为不常用词(可能需要修改页面代码?)。
- 使用
关于example.com/Page_title
使用域的根目录作为wiki目录,并使url如下所示:example.com/Page_title
,但并不是官方建议的方式。因为它可能会导致与其他文件和目录冲突。如:图像位于/images/目录中,则无法访问wiki中名为“images”的页面;并且无法创建控制搜索引擎索引页面的robots.txt.txt文件。(参见Manual:Wiki in site root directory)
- 可能的bug如:task T34621、task T40048。
但同时这种方式在Gamepedia运行良好。
目前并没有遇到、涉及上述问题,私人小站也不担心链接变动的SEO影响(Cool URIs don't change)。