博客
关于我
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创建函数报错_mysql在创建存储函数时报错
查看>>
mysql创建数据库和用户 并授权
查看>>
mysql创建数据库指定字符集
查看>>
MySql创建数据表
查看>>
MySQL创建新用户以及ERROR 1396 (HY000)问题解决
查看>>
MySQL创建用户与授权
查看>>
MySQL创建用户报错:ERROR 1396 (HY000): Operation CREATE USER failed for 'slave'@'%'
查看>>
MySQL创建索引时提示“Specified key was too long; max key length is 767 bytes”
查看>>
mysql初始密码错误问题
查看>>
MySQL删除数据几种情况以及是否释放磁盘空间【转】
查看>>
Mysql删除重复数据通用SQL
查看>>
mysql判断某一张表是否存在的sql语句以及方法
查看>>
mysql加入安装策略_一键安装mysql5.7及密码策略修改方法
查看>>
mysql加强(1)~用户权限介绍、分别使用客户端工具和命令来创建用户和分配权限
查看>>
mysql加强(3)~分组(统计)查询
查看>>
mysql加强(4)~多表查询:笛卡尔积、消除笛卡尔积操作(等值、非等值连接),内连接(隐式连接、显示连接)、外连接、自连接
查看>>
mysql加强(5)~DML 增删改操作和 DQL 查询操作
查看>>
mysql加强(6)~子查询简单介绍、子查询分类
查看>>
mysql加强(7)~事务、事务并发、解决事务并发的方法
查看>>
MySQL千万级多表关联SQL语句调优
查看>>