博客
关于我
zblog纯静态化插件 html静态文件生成_ZBlog全站静态化方案
阅读量:385 次
发布时间:2019-03-05

本文共 1734 字,大约阅读时间需要 5 分钟。

使用Z-Blog ASP 2.3版本,可以很方便的实现全站静态化,包括目录和标签tag都静态化输出,这里就给出一个详细的实现方法。

这个方案可以实现全站的全部链接(文章页、列表页、分类页、标签页、作者页、分页等)全部实现静态以及伪静态HTML输出。平时频繁更新发布的时候,可以使用伪静态HTML方式,如果长期不更新内容,可以使用纯静态HTML方式,两种方式可以相互切换。纯静态HTML可以部署到各类免费虚拟主机上,实现低成本网站发布。

下面说一下具体实现方法:

首先服务器必须是Windows Server 2008以上版本,安装IIS 7.5,启用URL重写模块。

之后安装Z-Blog 2.3,下载安装YT.Build插件。

YT.Build系统配置里选择“开启”。

在Z-Blog“静态管理中心”里,设置全局静态化选项为“1.文章静态 ”。

静态化配置参数如下:

文章的URL配置

{%host%}/{%post%}/{%id%}.html

页面的URL配置

{%host%}/{%alias%}.html

首页分页的URL配置

{%host%}/page/index.html

分类页的URL配置

{%host%}/cat/{%alias%}.html

作者页的URL配置

{%host%}/author/{%id%}.html

TAGS页的URL配置

{%host%}/tag/{%alias%}.html

日期页的URL配置

{%host%}/date/{%date%}.html

点击“保存”后,系统会生成一个ReWrite文件,覆盖到根目录下的web.config文件。

作者页和日期页由于会生成大量重复文件,并且似乎的确也没什么用,因此可以在模板里将和其相关的代码都删除,我们只用分类页、标签页和首页分页即可。

静态化使用“ 1.文章静态”,因为文章页访问量较大,目录页和TAG页使用伪静态,如果进行主机迁移,则用YT.Build生成目录页和TAG页的html文件,然后就可以将全部html文件部署到另一台主机上。如果遇到突发大流量,可以用YT.Build生成目录页和TAG页的html文件,然后将web.config里的重写删除即可。

在静态化tag的时候,使用{%alias%}标签,系统依旧按照name来构建url,查看了一下,可能是Z-Blog代码的问题,于是做了如下修改。

修改c_system_lib.asp文件

将 Url =ParseCustomDirectoryForUrl(Tags(i).FullRegex,ZC_STATIC_DIRECTORY,"","","","","",Tags(i).ID,Tags(i).Name,Tags(i).EncodeName)

修改为 Url =ParseCustomDirectoryForUrl(Tags(i).FullRegex,ZC_STATIC_DIRECTORY,"","","","","",Tags(i).ID,Tags(i).Name,Tags(i).EncodeIntro)

此外,YTBuild的Tag也存在一样的问题,同样也是代码的问题。

修改YTBuild插件的YT.Lib.asp

将 UrlRules=ParseCustomDirectoryForPath(UrlRules,ZC_STATIC_DIRECTORY,"","","","","",jTag.ID,jTag.Name,jTag.Name)

修改为 UrlRules=ParseCustomDirectoryForPath(UrlRules,ZC_STATIC_DIRECTORY,"","","","","",jTag.ID,jTag.Name,jTag.Intro)

之后在tag里使用{%alias%}标签,即可正常生成url。

这样,整个系统就会将全部动态页面变成静态HTML文件,以节省系统资源。经过静态化之后,就可以将Z-Blog全站都放在只支持HTML的免费主机上了,因为HTML耗费资源极低,因此可以实现低成本的网站发布。编辑catalog.asp这个文件,将其代码修改为如下即可:

3f45342b9ccff45a92d246cc3bfea5c0.png

转载地址:http://kjjg.baihongyu.com/

你可能感兴趣的文章
mysql5.7的安装和Navicat的安装
查看>>
mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
查看>>
Mysql8 数据库安装及主从配置 | Spring Cloud 2
查看>>
mysql8 配置文件配置group 问题 sql语句group不能使用报错解决 mysql8.X版本的my.cnf配置文件 my.cnf文件 能够使用的my.cnf配置文件
查看>>
MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
查看>>
MYSQL8.0以上忘记root密码
查看>>
Mysql8.0以上重置初始密码的方法
查看>>
mysql8.0新特性-自增变量的持久化
查看>>
Mysql8.0注意url变更写法
查看>>
Mysql8.0的特性
查看>>
MySQL8修改密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
查看>>
MySQL8修改密码的方法
查看>>
Mysql8在Centos上安装后忘记root密码如何重新设置
查看>>
Mysql8在Windows上离线安装时忘记root密码
查看>>
MySQL8找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
查看>>
mysql8的安装与卸载
查看>>
MySQL8,体验不一样的安装方式!
查看>>
MySQL: Host '127.0.0.1' is not allowed to connect to this MySQL server
查看>>
Mysql: 对换(替换)两条记录的同一个字段值
查看>>
mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
查看>>