html+php技术,PHP生成HTML的技术原理

本文介绍了如何使用MySQL创建新闻数据库表,通过PHP设计添加新闻的表单和模板,实现新闻标题、内容、路径的自动增长,并利用str_replace函数动态替换模板。重点在于表单处理和HTML路径的生成,适合初学者理解数据库操作和PHP应用。
摘要由CSDN通过智能技术生成

(1)在MYSQL里新建一数据库,命名为 database (可自定义),新建一表,命名为 news(因为是新闻发布嘛,取个好记的名字即可,可自定义),然后建立这几个字段名:360扣扣保镖源代码下载与最新动态

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 源码

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

$path

target=_blank>查看刚才添加的新闻

”;

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

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

因此,总结一下以上的做法:先设计好新闻模板,把需要被替换的内容用{

}放到模板中相应的位置,然后设计表单,再是最后的表单处理程序,把从表单中获取的变量替换模板中相应的内容即可,这样每次都会生成不同的HTML;如果

需要修改HTML的内容也是一样的,获得修改后的表单内容后,先用 update

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

来删除HTML的物理文件即可。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQLAlchemy 是一个 SQL 工具包和对象关系映射(ORM)库,用于 Python 编程语言。它提供了一个高级的 SQL 工具和对象关系映射工具,允许开发者以 Python 类和对象的形式操作数据库,而无需编写大量的 SQL 语句。SQLAlchemy 建立在 DBAPI 之上,支持多种数据库后端,如 SQLite, MySQL, PostgreSQL 等。 SQLAlchemy 的核心功能: 对象关系映射(ORM): SQLAlchemy 允许开发者使用 Python 类来表示数据库表,使用类的实例表示表中的行。 开发者可以定义类之间的关系(如一对多、多对多),SQLAlchemy 会自动处理这些关系在数据库中的映射。 通过 ORM,开发者可以像操作 Python 对象一样操作数据库,这大大简化了数据库操作的复杂性。 表达式语言: SQLAlchemy 提供了一个丰富的 SQL 表达式语言,允许开发者以 Python 表达式的方式编写复杂的 SQL 查询。 表达式语言提供了对 SQL 语句的灵活控制,同时保持了代码的可读性和可维护性。 数据库引擎和连接池: SQLAlchemy 支持多种数据库后端,并且为每种后端提供了对应的数据库引擎。 它还提供了连接池管理功能,以优化数据库连接的创建、使用和释放。 会话管理: SQLAlchemy 使用会话(Session)来管理对象的持久化状态。 会话提供了一个工作单元(unit of work)和身份映射(identity map)的概念,使得对象的状态管理和查询更加高效。 事件系统: SQLAlchemy 提供了一个事件系统,允许开发者在 ORM 的各个生命周期阶段插入自定义的钩子函数。 这使得开发者可以在对象加载、修改、删除等操作时执行额外的逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值