动态页面生成静态页面的原理

真静态与伪静态

目前网络上好多网站的新闻发布系统都采用了动态服务器技术生成静态HTML的做法,这样做的好处是:一是能减轻其服务器的负担,二是因为生成了HTML静态页面,所以其网站被搜索引擎搜索到的机率更大一些。因此,在这里,想简单地谈一下这种做法的思路。这篇文章适合于对PHP+MYSQL数据库操作,SQL语句以及网页设计有点基础的朋友,如果您是一个从头开始学的朋友,那么请先打好基础吧!到这里就不用往下看了。如果您都符合上述条件的话,那么恭喜您,请接着往下看。但是,在具体动手构建之前,您还要做好以下几点准备工作。

  • 静态化分真静态(2#)和伪静态(3#),下面分别介绍。

    真静态实现

    (1)在MYSQL里新建一数据库,命名为 database (可自定义),新建一表,命名为 news(因为是新闻发布嘛,取个好记的名字即可,可自定

    义),然后建立这几个字段名:

    id (自动递增,这是关键,类型:INT)

    title (顾名思义,新闻标题,类型可取 TEXT)

    content (新闻内容,类型可取 TEXT)

    path (HTML文件路径,类型可取 TEXT)

    (2)建立 conn.php

    这是连接数据库的PHP文件,你可以把连接数据的语句单独放在这一文件里,以后多个需要连接数据库的文件直接引用这个文件即可。

    (3)设计添加新闻的表格 add.form 简单的源代码如下:

    <form method=”post” action=”add.php”> //提交至 add.php

    新闻标题:<input type=”text” name=”title” size=”20”><br>

    新闻内容:<textarea name=”content” cols=”10” rows=”25”></textarea><br>

    <input type=”submit” name=”提交”>

    </form>

    (4)建立一个 HTML 的模板,另存为model.htm,和 add.php可以在同一目录下。

    示例源代码:

    <html>

    <body>

    此新闻的标题:{title}

    此新闻的内容:{content}

    </body>

    </html>

    { }大括号内的内容即是要被替换的内容,整个静态模板的设计可以根据自己的思路,但{ }内被替换的内容必须包含在内,如上面的{title},

    {content};咔咔~简单地说,设计好一个很好看的新闻模板后,把要被替换的如{title},{content}等标记放到需要的地方就可以了撒。

    (5)详解 add.php 源码

    <?php

    require_once("conn.php"); //引用conn.php,连接数据库

    $title=$_POST["title"];

    $content=$_POST["content"]; //获得表单变量

    //以下建立一文本文档,其值自动计数

    $countfile="count.txt";

    if(!file_exists($countfile))

    {

    fopen($countfile,"w"); //如果此文件不存在,则自动建立一个

    }

    $fp=fopen($countfile,"r");

    $num=fgets($fp,20);

    $num=$num+1; //每次其值自动加一

    fclose($fp);

    $fp=fopen($countfile,"w");

    fwrite($fp,$num); //更新其值

    fclose($fp);

    //利用上面自动计数的值获得HTML的路径$path

    $houzui=”.html”;

    $path=$num.$houzui;

    //这样形成的路径是自动增长的,如1.html,2.html,3.html……….添加一条新闻便自动加上1

    //以下用SQL语句添加数据至表 news

    $sql=”insert into news (title,content,path) values (‘”.$title.”’,’”.$content.”’,’”.$path.”’)”;

    $query=mysql_query($sql);

    //以下为关键之处,把从表单获得的数据替换模板中的{title},{content}标记

    $fp=fopen("model.htm","r"); //只读打开模板

    $str=fread($fp,filesize("mode.htm"));//读取模板中内容

    $str=str_replace("{title}",$title,$str);

    $str=str_replace("{content}",$content,$str);//替换内容

    fclose($fp);

    $handle=fopen($path,"w"); //写入方式打开新闻路径

    fwrite($handle,$str); //把刚才替换的内容写进生成的HTML文件

    fclose($handle);

    //收尾工作:

    echo "<a href=$path target=_blank>查看刚才添加的新闻</a>";

    ?>

    OK,整个生成HTML的示例源码就到这里,其关键是用了替换的方法。

    $str=str_replace("{被替换的内容}",$替换的内容,$str);

    因此,总结一下以上的做法:先设计好新闻模板,把需要被替换的内容用{ }放到模板中相应的位置,然后设计表单,再是最后的表单处理程序

    ,把从表单中获取的变量替换模板中相应的内容即可,这样每次都会生成不同的HTML;如果需要修改HTML的内容也是一样的,获得修改后的表

    单内容后,先用 update 语句更新数据库,再重新替换一下模板中的内容即可;删除的话,先delete表中要删除的内容,再用unlink($path)

    来删除HTML的物理文件即可。本文讲的只是最简单的思路而已,要投入使用还有待完善。

    伪静态实现

    比如这个网页

    http://www.*.net/soft.php/1,100,8630.html

    其实处理的脚本是soft.php 参数为1,100,8630

    相当于soft.php?a=1&b=100&c=8630 只不过这样的URL太难记。搜索引擎也不喜欢。

    真静态只是完全生成了HTML。

    客户端访问的时候直接输出。不用脚本解释。在流量非常大的时候(比如每天有上百万的访问量的时候)会起到很好的效果。也就是说服务器端实实在在的存在这个HTML页面。

    当然在你网站的流量没有那么大的时候。URL重写是最好的方法(个人观点,大流量的时候可以考虑负载均衡了。同样没有关系)

    附URL重写的方法有很多种,APACHE,IISREWRITE。甚至PHP脚本都可以直接处理。比如上例中就是PHP脚本直接处理(该方法好处是大流量的时候直接减轻WEB伺服器的压力。PS:同样也是个人观点:

    ================================================

    下面以程序为例讲一下PHP伪静态的程序实现方法

    程序为例:

    http://www.*.net/soft.php/1,100,8630.html

    <?php

    //利用server变量 取得PATH_INFO信息 该例中为 /1,100,8630.html 也就是执行脚本名后面的部分

    if(@$path_info =$_SERVER["PATH_INFO"]){

    //正则匹配一下参数

    if(preg_match("///(/d+),(/d+),(/d+)/.html/si",$path_info,$arr_path)){

    $gid =intval($arr_path[1]); //取得值 1

    $sid =intval($arr_path[2]); //取得值100

    $softid =intval($arr_path[3]); //取得值8630

    }else die("Path:Error!");

    //相当于soft.php?gid=1&sid=100&softid=8630

    }else die('Path:Nothing!');

    //就是这么简单了。~)

    ?>

    真静态和伪静态的优缺点

    html静态页(真静态)的好处有三点;一是减少服务器对数据响应的负荷,二是加载不用调动数据库,响应速度快。三是便于化化引擎。

    缺点也有三点:一是维护不方便,每次都要手动生成。三是空间占用比较大。三是生成的文件多了,服务器对html文件的响应负担也较重。

    url重写(伪静态)的好处:一,可以方便的实现对化化引擎的优化,并且比生成静态更加方便。二、占空间比较小。三、首页每天都自动变化,不用维护。网站首页一般都有热点排行之类的,你可以设为,24小时排行,一周排行,再加上最新文章,最新点评等。这样首页天天是有变化的。四,便于广告的轮显。比如:你可以把art1234.aspx,这个虚成n个页,如art_1234.aspx,news_1234.aspx,top_1234.aspx,在不同的页面放不同的广告.总之是动态的,你就可以随意动。

    url重写的缺点:我看只有一个,那就是效率不如生成html的,因为它不是真正意义上的静态页,每次请求是要读取数据库的。但你可以用缓存技术来补偿一下。

jsp生成静态页面

为了减轻服务器压力,将原来的文章管理系统由JSP文件的从数据库中取数据显示改为由jsp生成静态html文件后直接访问html文件。首先应创建一个模板文件,文件名和文件后缀可以随意,但我一般常用的还是 *.template ,因此,这里就以 template.template 为例( 将模板文件放入 /WEB-INF/templates/ 文件夹下 ):下面是一个简单的示例

buildhtml.jsp

<%@ page contentType="text/html; charset=gb2312" import="java.util.*,java.io.*"%>
<%
try{
&nbsp;&nbsp;&nbsp;&nbsp; //设置字符编码
&nbsp;&nbsp;&nbsp;&nbsp; request.setCharacterEncoding( "gb2312" );
&nbsp;&nbsp;&nbsp;&nbsp; response.setCharacterEncoding( "gb2312" );

String title="This is Title";
String content="This is Content Area";
String editer="LaoMao";
String filePath = "";
// 获得模板文件的路径
filePath = request.getRealPath("/")+"test/template.htm";
//out.print(filePath+"<br>");
String templateContent="";
//读取模块文件
FileInputStream fileinputstream = new FileInputStream(filePath);
int lenght = fileinputstream.available();
byte bytes[] = new byte[lenght];
fileinputstream.read(bytes);
fileinputstream.close();
templateContent = new String(bytes);
//out.print(templateContent);
templateContent=templateContent.replaceAll("###title###",title);
templateContent=templateContent.replaceAll("###content###",content);
templateContent=templateContent.replaceAll("###author###",editer);//替换掉模块中相应的地方
//out.print(templateContent);
// 根据时间得文件名
Calendar calendar = Calendar.getInstance();
String fileame = String.valueOf(calendar.getTimeInMillis()) +".html";
//生成的html文件保存路径
fileame = request.getRealPath("/")+fileame;
//建立文件输出流
FileOutputStream fileoutputstream = new FileOutputStream(fileame);
byte tag_bytes[] = templateContent.getBytes();
fileoutputstream.write(tag_bytes);
fileoutputstream.close();

}catch(Exception e){
out.print(e.toString());
}


%>

template.template

<html>
<head>
<title>###title###</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<LINK href="../css.css" rel=stylesheet type=text/css>
</head>


<body>
<table width="500" border="0" align="center" cellpadding="0" cellspacing="2">
<tr>
<td align="center">###title###</td>
</tr>
<tr>
<td align="center">author:###author###&nbsp;&nbsp;</td>
</tr>
<tr>
<td>###content###
</td>

</tr>

</table>
</body>
</html>

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值