|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
掌握静态网页的制作技术是学习开发网站的先决条件,这一点就讲到这里,因为这篇文章不是教程文章,也就不对技术进行深入的刨析了。oracle|分页|数据|数据库|显示 大部分的网站,城市思索到和利用者之间的互动关系。这时候,用留言版的功效,可以让利用者留下到此一游,或是一些和网站的互动讯息。
在设计上,可以很复杂的只留下利用者的短篇留言,也能够设计到依性质分门别类很庞杂的 Web BBS 体系。固然,要若何打造一个属于本人网站的留言版,就全靠网站的性质和 Web 网站开辟人员的巧思了。 在这里引见的典范,是复杂的列示一切留言的内容。供利用者可以一次看到多笔留言的材料。体系的后端寄存留言是用 Oracle 7.x 版的材料库体系。典范中的材料库(database) 称号为 WWW,连线的利用者帐号为 user38、暗码为 iam3849。要直接利用本例,必需先履行上面的 SQL 指令,创立 guestbook 的材料表格。
CREATE TABLE guestbook (
serial varchar2(255) not null,
ref varchar2(255) null,
id char(8) not null,
alias varchar2(32) not null,
ip varchar2(1024) null,
msgdate date not null,
email varchar2(1024) null,
msg varchar2(2000) not null,
flag char(1) default 1,
primary key(serial)
);
下面的 SQL 各栏位申明及具体材料见下表
序号 栏位 称号 数据类型 长度 栏位 申明 限制 Key
0 流水号 serial varchar2 255 NN PK
1 参照流水号 ref varchar2 255 暂保存
覆留言功效用
2 帐号 id char 8 利用者帐号 NN
3 匿名 alias varchar2 32 显示的名字 NN
4 网址 ip varchar2 1024 上彀 IP
5 工夫 msgdate date NN
6 电子邮件 email varchar2 1024
7 留言内容 msg varchar2 2000 NN
8 显示旗标 flag char 1 0: 不显示
1: 显示 (内定)
在本节的留言版相干法式中,若到场了利用者认证功效,则可以在 guestbook材料表的帐号栏中留下利用者的认证帐号,便利 Webmaster 往后找寻不妥的发信者。在这儿先留下栏位,让需求的读者们练习了。
要利用本节的法式,起首要先装好 Oracle 7.x 版,并肯定 Web Server 真个SQL*net 可以顺遂连上 Oracle 材料库。以后还要在编译 PHP 时加
--with-oracle=/home/oracle/product/7.3.2 的选项,固然改成其它的途径也不妨,只需该途径真的是 Oracle 的途径便可。有关 Oracle 装设及利用上的细节请参考相干书本。
上面的法式是将利用者的留言信息加到 guestbook 留言数据表中。若要设定利用者认证功效,可在法式刚入手下手时反省,发留言者就能够确认身份,而读取留言就不用身份反省。这类设定可以避免不妥讲话,却又不会让留言功效只要多数人利用。
<?php
file://---------------------------
// 新增留言法式 addmsg.php
// Author: Wilson Peng
// Copyright (C) 2000
file://---------------------------
//
// 可自行在这儿到场身份反省功效
//
if (($alias!="") and ($msg!="")) {
putenv("ORACLE_SID=WWW");
putenv("NLS_LANG=american_taiwan.zht16big5");
putenv("ORACLE_HOME=/home/oracle/product/7.3.2");
putenv("LD_LIBRARY_PATH=/home/oracle/product/7.3.2/lib");
putenv("ORA_NLS=/home/oracle/product/7.3.2/ocommon/nls/admin/data");
putenv("ORA_NLS32=/home/oracle/product/7.3.2/ocommon/nls/admin/data");
$handle=ora_logon("user38@WWW","iam3849") or die;
$cursor=ora_open($handle);
ora_commitoff($handle);
$serial=md5(uniqid(rand()));
$ref="";
$id=$PHP_AUTH_USER;
$ip=$REMOTE_ADDR;
$msg=base64_encode($msg);
$flag="1";
$query="INSERT into guestbook(serial, ref, id, alias, ip,
msgdate, email, msg, flag) values('$serial', '$ref', '$id', '$alias', '$ip',
sysdate, '$email', '$msg', '$flag')";
ora_parse($cursor, $query) or die;
ora_exec($cursor);
ora_close($cursor);
ora_logoff($handle);
Header("Location: ./index.php");
exit;
} else {
?>
<html>
<head>
<title>填写留言</title>
</head>
<body bgcolor=ffffff>
<form method=POST action="<? echo $PHP_SELF; ?>">
<table border=0 cellpadding=2 width=395>
<tr>
<td nowrap><font color=004080>代号大名</font></td>
<td width=20%><input type=text name=alias size=8></td>
<td nowrap><font color=004080>电子邮件</font></td>
<td width=50%><input type=text name=email size=18></td>
</tr>
<tr>
<td nowrapvalign=top><font color=004080>内容</font></td>
<td width=80% colspan=3><textarea rows=5 name=msg
cols=33></textarea></td>
</tr>
<tr>
<td width=100% colspan=4 align=center>
<input type=submit value="送出留言">
<input type=reset value="擦失落留言">
</td>
</tr>
</table>
</form>
</body>
</html>
<?php
}
?>
下面的法式在履行时,先反省变数 alias 和 msg 是不是有材料,若无材料则送出填写留言的表格到利用者端,供利用者填写留言。
若利用者填好留言,按下 "送出留言" 的按钮后,则履行法式的前半部分。
法式也许分红五部分
1.. 设定 Oracle 需求的情况变数
2.. 连上 Oracle 材料库
3.. 收拾整顿材料,送入 Oracle 中
4.. 停止与 Oracle 的连线
5.. 停止法式,显示最新的留言材料
在设定 Oracle 情况的部分,用 PHP 的函式 putenv(),可设定功课体系层的情况变数。要利用中文要记得到场上面这行
putenv("NLS_LANG=american_taiwan.zht16big5");
以后就利用 Oracle 函式库的功效: ora_logon() 等等。详见 Oracle 材料库函式库。使用这个函式库,可以很等闲的操作 Oracle 材料库。
终于学会把表单的数据插入数据库,然后显示出来了,应该说一个程序的雏形已经诞生了。 |
|