博客
关于我
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/

你可能感兴趣的文章
MySQL —— 在CentOS9下安装MySQL
查看>>
MySQL —— 视图
查看>>
mysql 不区分大小写
查看>>
mysql 两列互转
查看>>
MySQL 中开启二进制日志(Binlog)
查看>>
MySQL 中文问题
查看>>
MySQL 中日志的面试题总结
查看>>
mysql 中的all,5分钟了解MySQL5.7中union all用法的黑科技
查看>>
MySQL 中的外键检查设置:SET FOREIGN_KEY_CHECKS = 1
查看>>
Mysql 中的日期时间字符串查询
查看>>
mysql 中索引的问题
查看>>
MySQL 中锁的面试题总结
查看>>
MySQL 中随机抽样:order by rand limit 的替代方案
查看>>
MySQL 为什么需要两阶段提交?
查看>>
mysql 为某个字段的值加前缀、去掉前缀
查看>>
mysql 主从
查看>>
mysql 主从 lock_mysql 主从同步权限mysql 行锁的实现
查看>>
mysql 主从互备份_mysql互为主从实战设置详解及自动化备份(Centos7.2)
查看>>
mysql 主从关系切换
查看>>
MYSQL 主从同步文档的大坑
查看>>