Discuz:Discuz!URL静态化的使用

来自站长百科
跳转至: 导航、​ 搜索

导航: 上一级 | Discuz | 首页 | PhpWind | 动网论坛 | vBulletin | phpBB | MolyX | Discuz!NT

Discuz! URL 静态化的使用

  • Discuz! 4.1.0 新增了 Discuz! URL 静态化(以下简称 URL 静态化)功能。此功能可以将 Discuz! Archiver 及部分常用页面(如 forumdisplay.php、viewthread.php、viewpro.php 等)进行 URL 静态化转换,形成类似 http://www.demo.net/discuz/forum-1-1.html 形式的超级链接,从而使论坛内容更容易被搜索引擎挖掘,提高被收录的机率。

使用注意事项

  • 您可以通过 系统设置 中 Discuz! 选项 来控制 URL 静态化 的打开或关闭及其工作状态
  • 本功能对服务器环境有特殊要求,独立主机用户需要对 Web 服务器增加相应的 Rewrite 规则,因此需要服务器权限才可使用。对于虚拟主机用户,您需要向您的空间服务商进行咨询:空间是否支持 Rewrite 以及是否支持对站点目录中 .htaccess 的文件解析,只有满足这两条件,URL 静态化 功能才会生效。
  • 打开 URL 静态化 后,论坛一些常用链接会变成类似 http://www.demo.net/discuz/forum-1-1.html 形式,如果您的服务器环境不支持或者尚未配置好,访问这些链接会出现“网页无法显示”的错误信息,论坛将无法正常访问。发生无法访问的现象时,请您进入管理后台,关闭 URL 静态化 功能,论坛即可恢复正常状态。

URL 静态化 工作状态

在 Discuz! 选项 中提供了四种 URL 静态化 的工作状态,分别是:

    • 不启用 URL 静态化 功能。
  • Discuz! Archiver 静态化
    • 当论坛启用 Archiver 功能时,Archiver 内的所有链接均采用 *.html 形式。
  • 普通页面静态化
    • 对论坛常用页面(如 forumdisplay.php、viewthread.php、viewpro.php、space.php 等)进行 URL 静态化转换。
  • Archiver 和普通页面均静态化
    • 对 Archiver 以及论坛常用页面(如 forumdisplay.php、viewthread.php、viewpro.php、space.php 等)进行 URL 静态化转换。

Discuz! URL 静态化 服务器环境的设置

  • Discuz! URL 静态化 功能受到论坛所在服务器环境的制约,在开启此功能之前,请根据你的 Web 服务器环境,选择相应的环境配置方法。错误的设置有可能造成服务器无法启动或者功能无效。以下仅提供 Apache 和 Zeus 的配置方法,IIS或其他 Web 服务器您可根据原理自行修改。

Apache Web Server(独立主机用户)

首先确定您使用的 Apache 版本,及是否加载了 mod_rewrite 模块。

Apache 1.x 的用户请检查 conf/httpd.conf 中是否存在如下两段代码:

	LoadModule rewrite_module     libexec/mod_rewrite.so
	AddModule mod_rewrite.c

Apache 2.x 的用户请检查 conf/httpd.conf 中是否存在如下一段代码:

	LoadModule rewrite_module     modules/mod_rewrite.so
  • 如果存在,那么在配置文件(通常就是 conf/httpd.conf)中加入如下代码。此时请务必注意,如果网站使用通过虚拟主机来定义,请务必加到虚拟主机配置,即 <VirtualHost> 中去,如果加在虚拟主机配置外部将可能无法使用。改好后然后将 Apache 重启。
	<IfModule mod_rewrite.c>
		RewriteEngine On
		RewriteRule ^(.*)/archiver/((fid|tid)-[\w\-]+\.html)$ $1/archiver/index.php?$2
		RewriteRule ^(.*)/forum-([0-9]+)-([0-9]+)\.html$ $1/forumdisplay.php?fid=$2&page=$3
		RewriteRule ^(.*)/thread-([0-9]+)-([0-9]+)-([0-9]+)\.html$ $1/viewthread.php?tid=$2&extra=page\%3D$4&page=$3
		RewriteRule ^(.*)/space-(username|uid)-(.+)\.html$ $1/space.php?$2=$3
		RewriteRule ^(.*)/tag-(.+)\.html$ $1/tag.php?name=$2
	</IfModule>
  • 如果没有安装 mod_rewrite,您可以重新编译 Apache,并在原有 configure 的内容中加入 --enable-rewrite=shared,然后再在 Apache 配置文件中加入上述代码即可。

Apache Web Server(虚拟主机用户)

  • 在开始以下设置之前,请首先咨询您的空间服务商,空间是否支持 Rewrite 以及是否支持对站点目录中 .htaccess 的文件解析,否则即便按照下面的方法设置好了,也无法使用。
  • 检查论坛所在目录中是否存在 .htaccess 文件,如果不存在,请手工建立此文件。Win32 系统下,无法直接建立 .htaccess 文件,您可以从其他系统中拷贝一份,或者在 Discuz.net 技术支持栏目中下载此文件。编辑并修改 .htaccess 文件,添加以下内容
	# 将 RewriteEngine 模式打开
	RewriteEngine On

	# 修改以下语句中的 /discuz 为你的论坛目录地址,如果程序放在根目录中,请将 /discuz 修改为 /
	RewriteBase /discuz

	# Rewrite 系统规则请勿修改
	RewriteRule ^archiver/((fid|tid)-[\w\-]+\.html)$ archiver/index.php?$1
	RewriteRule ^forum-([0-9]+)-([0-9]+)\.html$ forumdisplay.php?fid=$1&page=$2
	RewriteRule ^thread-([0-9]+)-([0-9]+)-([0-9]+)\.html$ viewthread.php?tid=$1&extra=page\%3D$3&page=$2
	RewriteRule ^space-(username|uid)-(.+)\.html$ space.php?$1=$2
	RewriteRule ^tag-(.+)\.html$ tag.php?name=$1
  • 添加内容时,请遵照上面的提示,修改论坛所在的路径,然后保存。将 .htaccess 文件上传到论坛所在的目录中。然后进入论坛系统设置的搜索引擎优化,根据需要开启 URL 静态化功能。

IIS Web Server(独立主机用户)

  • 首先在 IIS 的 Isapi 上添加这个筛选器,筛选器名称为 Rewrite ,可执行文件选择 Rewrite.dll ,重新启动 IIS。附件中 httpd.ini 已经设置好,其中内容如下:
  • 	[ISAPI_Rewrite]
    
    	# 3600 = 1 hour
    	CacheClockRate 3600
    
    	RepeatLimit 32
    
    	# Protect httpd.ini and httpd.parse.errors files
    	# from accessing through HTTP
    	RewriteRule ^(.*)/archiver/((fid|tid)-[\w\-]+\.html)\?*(.*)$ $1/archiver/index\.php\?$2&$4
    	RewriteRule ^(.*)/forum-([0-9]+)-([0-9]+)\.html\?*(.*)$ $1/forumdisplay\.php\?fid=$2&page=$3&$4
    	RewriteRule ^(.*)/thread-([0-9]+)-([0-9]+)-([0-9]+)\.html\?*(.*)$ $1/viewthread\.php\?tid=$2&extra=page\%3D$4&page=$3&$4
    	RewriteRule ^(.*)/space-(username|uid)-(.+)\.html\?*(.*)$ $1/space\.php\?$2=$3&$4
    	RewriteRule ^(.*)/tag-(.+)\.html\?*(.*)$ $1/tag\.php\?name=$2&$3
    

    Zeus Web Server

    在虚拟主机配置中找到 Request Rewriting,在 Rewrite Script 中写入以下内容,然后 Apply changes 并 make it take effect。

    	match URL into $ with ^(.*)/archiver/((fid|tid)-[\w\-]+\.html)?*(.*)$
    	if matched then
    		set URL = $1/archiver/index.php?$2&$4
    	endif
    	match URL into $ with ^(.*)/forum-([0-9]+)-([0-9]+)\.html?*(.*)$
    	if matched then
    		set URL = $1/forumdisplay.php?fid=$2&page=$3&$4
    	endif
    	match URL into $ with ^(.*)/thread-([0-9]+)-([0-9]+)-([0-9]+)\.html?*(.*)$
    	if matched then
    		set URL = $1/viewthread.php?tid=$2&extra=page\%3D$4&page=$3&$4
    	endif
    	match URL into $ with ^(.*)/space-(username|uid)-(.+?)\.html?*(.*)$
    	if matched then
    		set URL = $1/space.php?$2=$3&$4
    	endif
    	match URL into $ with ^(.*)/tag-(.+?)\.html?*(.*)$
    	if matched then
    		set URL = $1/tag.php?name=$2$3
    	endif
    

    修改完服务器配置后请进入论坛 系统设置,打开 URL 静态化 功能,测试功能是否正常。如果出现问题,请仔细检查你所做的每一步。