Manual:Short URL/zh


 * 以下的一些资料可能会过时或不正确. 如果你熟悉以下的内容，请尝试帮助我们更新这篇文章. 

万维网的发明者蒂姆伯纳斯-李曾经说过，良好的网页URL地址应该永远保持不变. 隐藏了复杂的程序代码的网页地址能给访客一个好的体验. 在开始之前，请花几分钟时间为您的网站制订一个稳定的网址结构，以减少以后一些不必要的麻烦. 为了阅读方便，这个页面已经被分成独立的章节，下面有目录.

默认配置
MediaWiki的默认安装路径一般都是下面这样:
 * (用Root账户安装)
 * (虚拟主机安装)

MediaWiki的默认页面地址一般是下面这样：
 * (最新版本的Mediawiki, 没有使用CGI)
 * (最新版本的Mediawiki, 使用了CGI)

使用下面将提到的方法, 我们可以把地址设置成下面的样子:
 * ( 标准形式，像Wikipedia那样的)
 * (不建议采用！)

好处与坏处
长URL有一个显著地好处：他们在所有的主机环境中都运行良好——这是个好消息，免得某天你把你的wiki转移到一个你不能继续使用其他人都收藏了或是连接了的URL的主机环境中.

短URL的好处是他们隐藏了所有的技术细节，对URL 来说是最佳的处理方式. 这意味着如果你的主机环境支持的话，当相关机制变化时，他们依然是稳定的. 对访问者来说，他们也更易于记忆并且让访问者更方便的根据URL进行导航.

一旦你确信你需要使用短URL并且愿意付出努力的话，你要准备好经历下述的漫长的错误调试历程.

公共主机/虚拟主机
大多数虚拟主机系统不允许修改httpd.conf文件. 如果你使用一个shared host，首先询问你的服务提供商，他们有可能解决你的问题. 如果不管用的话，取决于你的服务提供商，你有可能可以编辑.htaccess文件 (详见下述).

If you have a choice, you should edit httpd.conf (which requires root access and is the preferred method because your wiki will perform better ). You only need to edit either .htaccess or httpd.conf, not both.

建议的配置步骤（以 Wikipedia 的配置为例）
下面的配置过程已为 Wikipedia 所采用，且较稳定和容易搭建. 除非你实在不喜欢它的某些方面（比如没有重写全部 URL）或者你干脆不能这样操作（需要 root 用户登录），你应该遵循这个配置过程.

优势

 * 本方法是可靠的，且被保证将在 MediaWiki 未来版本可以使用的. MediaWiki 的开发者不会测试其它方案. 当软件有改动时，其它方案可能会失败.
 * 没有重写全部 URL ，但这很好. 有这么一个简单的规则，很容易地阻止了搜索引擎的爬虫查看后台页面（比如编辑表单或历史页面），在日志分析中分离了查看内容和其他访问，等等. 尽管到编辑页和后台页的链接有点难记，这没什么大不了：重要的是内容.
 * 本方法使用别名而不是重写. 这更简单也更可靠.

缺陷

 * 这个方法需要 Apache 以及 root 用户登录.

配置步骤
首先，确保你用的是 Apache 并且有 root 访问权限（这样你才能修改httpd.conf，修改.htaccess是不够的）. 如果任意一个不行，你就不能用这个方法. 你需要对其进行相应的改动，或使用后面列出的其他方法. 建议Manual:Short URL/wiki/Page title -- no root access.

倘若之前你不知道，选择 /wiki/ 作为 MediaWiki 的安装目录，那就把它改个新名字（这里是 /w/</tt>）并把你看到的所有 /wiki/</tt> 替换为新目录（这里是 /w/</tt>）（通常只有一个  文件要修改）. 安装目录一定不能和虚拟目录相同，也一定不能是网络根目录，第一点很重要，不要试着忽略它来让 URL 漂亮一点，否则这样配置不会成功.
 * 1) 找到你 wiki 安装的目录. 缺省情况下，是个叫做 /w 的子目录，位于你的 web 服务器的文件根目录（网络根目录）. 这个根目录是你服务器上所有公开的 html 文件所在的目录. 例如，如果你的网络根目录上 /var/www，那么你的 wiki 可能在 /var/www/w. 在这个目录中，你可以看到一些文件，如 index.php 和 LocalSettings.php . 这可能让你有点糊涂，因为在一些系统（如：Debian），子目录 /w 可能只是个符号链接（如：到 /usr/share/mediawiki/）.
 * 2) 选择一个你想让你的文章出现的虚拟目录. 下面假定你选了 /wiki/</tt>（和 Wikipedia 一样）. 文章将被这样访问  http://www.example.com/wiki/文章标题 </tt>. 别建这个虚拟目录，它不能在网络根目录中存在！下面假定，和 Wikipedia 一样，你把 MediaWiki 安装到了网络根目录的 /w/</tt> 子目录，而不是 /wiki/</tt> 目录.

如果你在用一个本地化版本的 MediaWiki（非英文版），这两个特殊页面的名字是翻译过的. 检查你 wiki 中的实际链接以便得到特殊页面的 URL. 它们与用户的个性化语言设置无关.
 * 1) 对 LocalSettings.php</tt> ，做如下改动：   注意   应已被设置成 /w</tt>. 如果没有（比如，你正从另一 URL 方案迁移），先去把它设成那样.
 * 2) 编辑 httpd.conf</tt> ，使其包含规则  . 注意第二个路径是基于文件系统的根目录，而不是网络根目录！例如，如果 /var/www/</tt> 是你的网络根目录，这里可能是  . 如果这样设置不行或返回了 403 错误，设一个 MediaWiki 安装的绝对路径. 比如  . 这个别名设置是个最小化的配置. 想了解更多的选项，参见 Apache configuration . 如果你在用 Apache 2 ，配置文件叫 apache2.conf</tt>. 如果你那里没有 httpd.conf</tt>，请使用这个.
 * 3) 让 Apache 重新读取配置文件（优雅地重启）. 比如，你可能以 root 用户调用   或一个类似的命令，或使用WebHost Manager或其他类似软件的特性. 如果你在用 Apache 2 ，该命令是.
 * 4) 在你的网络根目录，如果没有名为 robots.txt</tt> 的文件，创建一个. 然后把这几行加入文件末尾：    第一个“Disallow”规则阻止网络爬虫检索历史记录、编辑页面和其他无益于用户搜索的后台页面. 也防止了重复的内容被索引到. 第二、三个规则阻止网络爬虫检索两个可能使其困惑并一般来说无用的页面.

完成了，你的 wiki 应该已经完美地工作了. 如果没有，到 irc://irc.freenode.org/mediawiki 报告任何问题.

其他方式的缩写配置
Anyone is welcome to create a how-to solution page and list it below. Please use a sensible name for the page, one that fits in with the below names. When each unique solution has its own page, readers can skip complexity they do not want. Keep it simple, readable, short, with a separate page per separate solution.

To help others find out which Short URL methods really work, after trying each method please edit the page and increase the "worked" or "didn't_work" numbers for that guide and make a brief (or long, your choice) description on what went wrong by clicking the link on your number.

URL 示例： example.com/wiki/Page_title
How to create example.com/wiki/Page_title</tt> URLs: - recommended method if you don't have root access; should also work with PHP as CGI mode

Root access

These methods require that you have access to the server configuration. If you are on a shared host, you most likely don't; see the "no root access" examples instead.

(If the Alias method is not suitable [for example, you use PHP as a CGI], you can use Apache instead.)

URL 示例： example.com/Page_title
How to create example.com/Page_title</tt> URLs: 

(used this method: x2) (also works with 1.10 & 1.13, but not with 1.11., very similar to the above solution)

URL 示例： wiki.example.com/Page_title
How to create <tt>wiki.example.com/Page_title</tt> URLs.

(the above enhanced, work with 1.14)

Ampersand (&) problem
The ampersand problem shows up when you have page titles with symbols in (such as &, ?, #, + and /) that, despite being correctly encoded in the link are not being passed correctly from mod_rewrite to the script. This manifests in 404 page-not-found errors, because the title gets cut off at the special character. For example, clicking on a link to "John & Maria's page" gets a 404, because MediaWiki is looking for a page named "John ".

This is because ampersands in long-form names are treated as query string separators, and would never reach the PHP runtime environment. This is caused by an old and problematic mod_rewrite bug. There are discussions of other possible solutions at lists.wikimedia.org and fgiasson.com.

Solutions:

Looping alias/rewrite errors
If you receive looping alias/rewrite errors such as "Cannot find page www.example.com/wiki/wiki/wiki/wiki/wiki/ [...] /index.php", try one of these fixes:

No Skins
With Ubuntu 8.10 and Mediawiki 1.11.2 (and maybe later versions) if you use the Mediawiki sanctioned directions your skins may fail to load. To fix this, create a symbolic link in /var/www pointing to /var/lib/mediawiki with the value of $wgScriptPath in LocalSettings.php. If, for example, $wgScriptPath is set to "/w" then you need to run the command "sudo ln -s /var/lib/mediawiki /var/www/w".

Revert to default
If you need to revert to the default values of your wiki but have accidentally deleted them, here are the defaults:

Redirect visitor of your domain to your wiki
Drop a <tt>index.php</tt> file in your web root directory with the following lines: