<p> <a href="http://file.ddvip.com/2007_08/1188131018_ddvip_8075.rar">本文示例源代码或素材下载</a></p>
<p> 1、什么是PHP?</p><p> php是一种开发动态网站的很好的工具.</p><p> 2、php容易学么?</p><p> 非常容易,只要你掌握一点c或者c++基础.</p><p> 3、为什么选择php?</p><p> 速度,易上手,模板,等等</p><p> 4、php主要学什么?</p><p> 模板和函数</p><p> 5、支持那些数据设备?</p><p> 你知道那些就有那些</p><p> 6、为什么我要选择access?</p><p> 因为很多情况下access简单,易操作,虽然公认的mysql是no.1,但是鉴于对新手比较陌生,access得了,其实我的mysql水平不怎么样...</p><p> 7、我的特色:</p><p> 简单,实用, 经济 ,xhtml.,没有设计到smarty技术{太复杂,以后说},这次废话极少了。</p><p> 我的这个实例主要实现的功能是:</p><p> 1:发表留言</p><p> 2:分页显示</p><p> 3:可回复</p><p> 4:管理员编辑删除</p><p> 5:支持UBB</p><p> 6:xhtml和一些其他简单技巧</p><p> 7:记起再写</p><p> 先看看文件目录:</p><code>d:webphp<br />--<guest><br />--------<data><br />-----------------db.mdb {数据库}<br />---------<js><br />-----------------common.js{常用的js}<br />-----------------ubbcode.js{UBB点击的使用用的js}<br />--------<images><br />-----------------<ubbimages>{保存ubb的图片的文件夹}<br />--------<style><br />------------------all.css{公用css样式表}<br />--------<inc><br />-------------------config.php{ 整体配置 }<br />-------------------conn.php{ 数据库配置 }<br />-------------------header.php{ 头文件配置 }<br />-------------------footer.php{ 脚文件配置 }<br />-------------------function.php{ 一些简单函数 }<br />--------index.php{首页}<br />--------post.php{发表留言}<br />--------admin.php{管理界面}</code><p> 公用的all.css文件:</p>
<p> </p>
<code>*{margin:0;padding:0;}<br />body{FONT-FAMILY: Tahoma, MS Shell Dlg,betty, female; table-layout:fixed;<br /> word-break:break-all; color: #000;line-height: 1.166;margin:0;padding: 0px;<br />background-color:#401F00;word-wrap: break-word;font-size:12px;}<br />a{color:#008;TEXT-DECORATION:none;font-weight:bold;}<br />a:hover{color:#009;TEXT-DECORATION:none;}<br />h5 {background-color:#00AEEF;padding:3px 10px;font-size:12px}<br />h4 {padding:5px 10px;background-color:#000080;font-size:12px;color:#fff;}<br />h4 a{color:#fff}<br />h4 a:hover{color:#b00;border-bottom:2px solid #fff}<br />#format_all{width:500px;padding:0;margin:auto;float:none;border:2px solid #000080;background-color:#fff}<br />#top_ul{background-color:#BBDDFF}<br />#top_ul p{padding:50px 0 5px 10px;height:30px;color:#b00;font-size:14.6px}<br />#top_ul ul{display:block;clear:both;background-color:#313A97;height:22px}<br />#top_ul ul li{list-style:none;float:left;padding:5px 3px;}<br /> #top_ul ul li a{color:#b00;padding:0 5px;}<br /> #top_ul ul li a:hover{color:#FFF100;border-bottom:2px solid #00AEEF;}<br />#show_c{background-color:#BBfbFF;padding:3px 0;}<br />#show_c h6{background-color:#00AEEF;padding:3px 10px;font-size:12px}<br />#show_c h6 a{color:#313A97}<br />#show_c h6 a:hover{color:#b00;border-bottom:2px solid #b00}<br />#show_c div{padding:5px 10px}<br /> #show_c div sub{font-size:105%;color:#313A97;padding:2px 15px;display:block;float:none}<br />#show_c ul{padding:5px 10px 5px 20px;color:#E82B2B}<br /> #show_c ul li{padding:5px 10px}<br />#show_c ulli a:hover{border-bottom:2px solid #FFF100;}<br />label {padding:2px 0 2px 20px;display:block}<br />#footer{background-color:#BBDDFF;padding:8px;font-weight:bold}<br />#footer a:hover{color:#b00;border-bottom:2px solid #00AEEF;}</code><p> php代码写的时候以 <??>最为长用,注释的时候以单行//这里是注释 ,多行以注释/*这里是注释*/ 都行。</p>
<p> </p>
<p> php主要是以函数和模板著名吧,它支持class的继承。学好数组和模板技术是必须掌握的,但这里牵扯到的函数比较多,以后我5do8慢慢的给新手们介绍,关于php开发,函数那句话,模块化,能很好的于xhtml结合,模板技术,很有钱途的。</p><p> 我在下面提到的深度就是指程序执行的 if..else 层数,一次判断是一个深度。</p><p> 相关php的库函数请查看详尽书籍或者文章介绍,此处只讲"怎么用"</p><p> ----->style/css.all抄上面的也可以,估计速度比较慢,哈哈哈...</p><p> 先说说数据库吧:</p><p> 表 php_guest ,没啥说的,一看图就会了:</p><p> <img src="/content/uploadfile/200805/2008053117451416.gif" onclick="get_larger(this)" alt="PHP+Access设计留言版实战(1)" /></p><p> 表php_admin,也没啥说的look here :</p><p> <img src="/content/uploadfile/200805/2008053117451435.gif" onclick="get_larger(this)" alt="PHP+Access设计留言版实战(1)" /></p><p> 下面看看inc/config.php是怎么设置的:</p><code><?php<br />ob_start();<br />$NowPathArray=explode("inc",str_replace("","/",dirname(__FILE__))) ;<br />@define("root_path", $NowPathArray[0]);<br />@define("confign_path", root_path . "inc/");<br />@define("db_path", root_path."data/db.mdb"); <br />$scriptFullPath = $_SERVER["PHP_SELF"];<br />$scriptArray = split("/",$scriptFullPath);<br />//$myfilename = $scriptArray[sizeof($scriptArray)-2];<br />$myfilename = end($scriptArray);<br />$szd_title="我的留言版";<br />$page_size=5;<br />require_once(confign_path.'conn.php');<br />require_once(confign_path.'function.php');<br />?></code><p> 解释:</p>
<p> </p>
<code><?<br />ob_start();//缓存开始,提高速度<br />$NowPathArray=explode("inc",str_replace("","/",dirname(__FILE__))) ;//强制将windows下"分隔符"转化为/<br />@define("root_path", $NowPathArray[0]);//定义本文件的上一位置,也就是定位到了跟目录下面.<br />@define("confign_path", root_path . "inc/");//定义整体配置文件夹<br />@define("db_path", root_path."data/db.mdb"); //定义数据库路径<br />$scriptFullPath = $_SERVER["PHP_SELF"];//得到引用页文件的url地址.<br />$scriptArray = split("/",$scriptFullPath);//切割成数组<br />$myfilename = end($scriptArray);//得到本页名称<br />$szd_title="我的留言";//留言班的标题<br />$page_size=5; //每页的数目<br />require_once(confign_path.'conn.php'); //包含数据库文件,只一次<br />require_once(confign_path.'function.php');//包含公用函数库文件,只一次<br />?></code><p> 下面是inc/conn.asp的文件:</p><code><?php<br />$conn = new COM('ADODB.Connection');<br />$accessdsn = "Driver={Microsoft Access Driver (*.mdb)};DBQ=".db_path.";Uid=;Pwd=;";<br />$conn->Open($accessdsn);<br />?></code><p> 解释:</p><code><?<br />$conn = new COM('ADODB.Connection'); //--------------->创建对象<br />$accessdsn = "Driver={Microsoft Access Driver(*.mdb)};DBQ=".db_path.";Uid=;Pwd=;";<br />//$accessdsn = "Provider=Microsoft.Jet.OLEDB.4.0; Data Source=".db_path."";<br />//--------------->2中连接mdb数据库的字符串,都行,前者在asp里面不被推荐,在php里面好像经常使用,c-blog是前者,我....<br />$conn->Open($accessdsn);//---------------> 实例<br />?></code><p> inc/function.php函数库用的使用我就一个一个的说到了,下面开始走正路:</p>
<p> </p>
<p> 我看这个东西有3部分比较合理就用了3部分了,呵呵,so创建了</p><p> 1、inc/header.php :</p><code><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3c.org/TR/1999/REC-html401-19991224/loose.dtd"><br /><HTML xmlns="http://www.w3.org/1999/xhtml"><br /><head><title><?=$szd_title?></title><br /><meta http-equiv="Content-Type" content="text/html; charset=gb2312"><br /><link rel="stylesheet" href="style/all.css" type="text/css"><br /></head><br /><body><br /><div id="format_all"><br /><div id="top_ul"><br /><p>老农:PHP留言版</p><br /><ul><li><a href="index.php">首页</a></li><br /><li> <a href="POST.php">发表</a></li><br /><li><a href="FAQ.php">FAQ</a></li><br /><li><a href="admin.php">管理</a></li><br /></ul><br /></div></code><p> 2、inc/footer.php :</p><p> <div id="footer">技术支持:老农,网站:<a href="http://www.cjjer.com">http://www.cjjer.com</a></div></p><p> </div></body></html></p><p> 3、要包含两个文件的这样使用,比方index.php :</p><code><?php<br />require_once('inc/config.php');<br />require_once(confign_path.'header.php');<br />?></code></p>
<p> </p>
<p> 这里你自定义哦,有点模板的味道,我在一下的教程里面都是修改这里面的内容的.,以后替换的就是这行哦,5do8这样说.</p><code><?php<br />require_once(confign_path.'footer.php');<br />?></code><p> index.php</p><code><?<br />$page_sql="select * from php_guest order by id desc";<br />$rs = new COM('ADODB.recordset'); <br />$rs->open($page_sql,$conn,1,1);<br />$pagesize=$rs->Pagesize=$page_size ;<br />if($rs->PageCount<>0){<br />if(!empty($_GET['page'])){<br />if($_GET['page']<=0){<br />$rs->AbsolutePage=1;<br />$nowpage=1;}<br />elseif($_GET['page']>$rs->PageCount){<br />$rs->AbsolutePage=$rs->PageCount;<br />$nowpage=$rs->PageCount;<br />}else{<br />$rs->AbsolutePage=$_GET['page'];<br />$nowpage=$_GET['page'];}<br />}else{<br />$rs->AbsolutePage=1;<br />$nowpage=1;}<br />}else{<br />$nowpage = 1;<br />$pagesize = 0;<br />}<br />for ($m=1; $m<=$pagesize; $m++)<br />{<br />if (!$rs->EOF){<br />?><br /><h6>[<?= $rs->Fields[1] ?>]AT[<?=str2time($rs->Fields[7]) ?>]Title:[<?=htmlspecialchars($rs->Fields[2]) ?>] <?=admin_rep($rs->Fields[0] )?></h6><br /><div><?= ubb($rs->Fields[4]) ?>[<?=$rs->Fields[5] ?>]<br /><sub><?= $rs->Fields[6] ?></sub><br /></div><br /><? $rs->MoveNext();<br />}<br />}<br />if($rs->PageCount==0){<br />echo "没有信息哦";}<br />if($rs->PageCount<>0){<br />echo "<h4>共有".$rs->RecordCount."条记录,每页".$pagesize."条,共".$rs->PageCount."页. ";<br />echo "<a href=".$myfilename."?page=1>首页</a> ";<br />if (!($nowpage<=1)){<br />echo "<a href=".$myfilename."?page=".($nowpage-1).">上一页</a> ";<br />}<br />if (!($nowpage>=$rs->PageCount)){<br />echo "<a href=".$myfilename."?page=".($nowpage+1).">下一页</a> ";<br />}<br />echo "<a href=".$myfilename."?page=".$rs->PageCount.">尾页</a></h4> ";<br /> }<br />$conn->Close();<br />$rs=NULL;<br />$conn =NULL;<br />?></code><p> 这是首页的全部文件,你只要替换我前面说的那个地方就行了,下面开始解释:</p>
<p> </p>
<p> 和asp的分页没啥大的区别,如果您明白asp的分页的话这个也很简单:sql读取记录,如果空的话输出为空的信息,如果不是空的话,读取当前的页数,页数为空或者大于记录总数的话游标定位到第一条,负责定位到 页数 * 每页的数目上.注意else对应和它相邻最近的if.</p><code>$page_sql="select * from php_guest order by id desc";<br />//------------------>创建sql语句<br />$rs = new COM('ADODB.recordset'); <br />//------------------>创建记录对象<br />$rs->open($page_sql,$conn,1,1);<br />//------------------>执行语句,返回记录集<br />$pagesize=$rs->Pagesize=$page_size ;<br />//------------------>设置每页显示条数<br />if($rs->PageCount<>0){<br />//------------------>防止数据库为空,执行深度 1<br /> if(!empty($_GET['page'])){<br />//------------------>如果当前querysting中page不是空,执行这里,定位页数.执行深度 2<br /> if($_GET['page']<=0){<br /> //------------------>如果当前page小于0,定位页数到第一条.执行深度 3<br /> $rs->AbsolutePage=1;<br /> $nowpage=1;}<br /> elseif($_GET['page']>$rs->PageCount){<br /> //------------------>如果当前page大于记录总数,定位页数到第一条.执行深度 4<br /> $rs->AbsolutePage=$rs->PageCount;<br /> $nowpage=$rs->PageCount;<br /> }else{<br /> //------------------>如果当前page不小于0到总数内,定位页数到page页.执行深度 3<br /> $rs->AbsolutePage=$_GET['page'];<br /> $nowpage=$_GET['page'];}<br /> }else{<br />//------------------>如果当前querysting中page是空,执行这里,定位第一条记录.执行深度 2<br /> $rs->AbsolutePage=1;<br /> $nowpage=1;}<br />}else{<br />//------------------>数据库为空的话执行这里,执行深度 1<br />$nowpage = 1;<br />$pagesize = 0;<br />}<br />for ($m=1; $m<=$pagesize; $m++)<br />//------------------>按照每页显示条数的设定进行循环<br />{<br /> if (!$rs->EOF){<br />//------------------>防止达到记录集尾产生错误<br /> ?><br /><h6>[<?= $rs->Fields[1] ?>]AT[<?=str2time($rs->Fields[7]) ?>]Title:[<?=htmlspecialchars($rs->Fields[2]) ?>] <?=admin_rep($rs->Fields[0] )?></h6><br /><div><?= ubb($rs->Fields[4]) ?>[<?=$rs->Fields[5] ?>]<br /><sub><?= $rs->Fields[6] ?></sub><br /></div><br /><? $rs->MoveNext();<br />//------------------>记录转向下一条<br /> }<br />}<br /> if($rs->PageCount==0){<br />//------------------>数据库为空,打印为空的信息<br /> echo "没有信息哦";}<br /> if($rs->PageCount<>0){<br />//------------------>数据不是空的话大于页数信息.<br /> echo "<h4>共有".$rs->RecordCount."条记录,每页".$pagesize."条,共".$rs->PageCount."页. ";<br /> echo "<a href=".$myfilename."?page=1>首页</a> ";<br /> if (!($nowpage<=1)){<br /> echo "<a href=".$myfilename."?page=".($nowpage-1).">上一页</a> ";}<br /> if (!($nowpage>=$rs->PageCount)){<br /> echo "<a href=".$myfilename."?page=".($nowpage+1).">下一页</a> ";}<br /> echo "<a href=".$myfilename."?page=".$rs->PageCount.">尾页</a></h4> ";<br /> }<br />$conn->Close();<br />$rs=NULL;<br />$conn =NULL;<br />//------------------>释放资源,5do8没啥说的了,哈哈哈哈</code></p>
<p> </p>
<p> 上面有个htmlspecialchars函数,相当于server.htmlencode函数,原样输出的函数。<p> admin_rep($ids)函数是判断管理员是否登陆,然后打印2个超链接的,写在inc/function.php里面的:</p><code>//管理员登陆成功时候自动出现的选项,---------------<br />function admin_rep($ids=0)<br />{ session_start();<br /> $thisadmin=$_SESSION["admin"] ;<br />//echo $thisadmin;<br />if ($thisadmin<>1)<br />{return false;}<br />$stradmin="Admin:<a href=admin.php?doaction=editor&id=".$ids.">editor</a> <a href='admin.php?doaction=delete&id=".$ids."' onClick='if(confirm("确定这个[---删除---]操作么?"))window.location.href=this.href;else return false;'>delete</a>";<br />return $stradmin;<br />}</code><p> session 验证的时候首先 session_start(); ,然后 if...else 判断,返回值。</p><p> 首页显示页面:</p><p> <img src="/content/uploadfile/200805/2008053117451556.gif" onclick="get_larger(this)" alt="PHP+Access设计留言版实战(1)" /></p><p> post.php:</p><code><?php<br />require_once('inc/config.php');<br />require_once(confign_path.'header.php');<br />?><br /><div id="show_c"><br /><?<br />if($Submit)<br />{<br /> echo "保存结果:";<br /> if (empty($user)||empty($title)||empty($ly))<br />{echo "<meta http-equiv="Content-Type" content="text/html; charset=gb2312">";<br />echo "<script language=javaScript><br />alert("输入必要的信息")<br /></script>";<br />echo "<script language=javascript>javascript:history.back()</script>";<br />exit();}<br />if (strrpos($user,"<")!==false || strrpos($user,">")!==false || strrpos($title,">")!==false)<br />{echo "<meta http-equiv="Content-Type" content="text/html; charset=gb2312">";<br />echo "<script language=javascript><br />alert("名称有特殊字符")<br /></script>";<br />echo "<script language=javascript>javascript:history.back()</script>";<br />exit();}<br />if (!ereg("^[0-9]{0,}$",$qq))<br />{echo "<meta http-equiv="Content-Type" content="text/html; charset=gb2312">";<br />echo "<script language=javascript><br />alert("OICQ信息有错误")<br /></script>";<br />echo "<script language=javascript>javascript:history.back()</script>";<br />exit();}<br />$user=trim($user);<br />$title=trim($title);<br />$ly=trim($ly);<br />$user_ip=getip();<br />echo $user_ip;<br />//$rs = new COM('ADODB.recordset'); <br />$conn->execute("insert into php_guest (szd_user,szd_title,szd_content,szd_ip) values('$user','$title','$ly','$user_ip')");<br />header("location:index.php");<br />//释放资源<br />$conn->Close();<br />$conn =NULL;<br />}<br />else{<br />require_once('postfunction.php');<br />postfunction();<br />}<br />?><br /></div><br /><?php<br />require_once(confign_path.'footer.php');<br />?></code><p> 下面开始解释:</p>
<p> </p>
<code>if($Submit)<br />{<br />//----------------->,如果页面已经提交,这里写一些入库的判断,深度 1<br /> if (empty($user)||empty($title)||empty($ly))<br />//----------------->如果有空值,输出不能为空的信息,深度 2<br /> echo "<meta http-equiv="Content-Type" content="text/html; charset=gb2312">";<br /> echo "<script language=javaScript><br />alert("输入必要的信息")<br /></script>";<br /> echo "<script language=javascript>javascript:history.back()</script>";<br /> exit();}<br /> if (strrpos($user,"<")!==false || strrpos($user,">")!==false || strrpos($title,">")!==false)<br /> {<br />//----------------->特殊输出字符,报错,深度深度 3<br /> echo "<meta http-equiv="Content-Type" content="text/html; charset=gb2312">";<br /> echo "<script language=javascript><br />alert("名称有特殊字符")<br /></script>";<br /> echo "<script language=javascript>javascript:history.back()</script>";<br /> exit();}<br />if (!ereg("^[0-9]{0,}$",$qq))<br />{<br />//----------------->正则验证错误的,验证失败的话,报错.关于正则用法,ubb里面使用的最多,以后详谈.深度 3<br />echo "<meta http-equiv="Content-Type" content="text/html; charset=gb2312">";<br />echo "<script language=javascript><br />alert("OICQ信息有错误")<br /></script>";<br />echo "<script language=javascript>javascript:history.back()</script>";<br />exit();}<br />$user=trim($user);<br />$title=trim($title);<br />$ly=trim($ly);<br />$user_ip=getip();<br />//----------------->去空格,这里设计到的getip()函数,在inc/function.php里面,本篇最后介绍<br />$conn->execute("insert into php_guest (szd_user,szd_title,szd_content,szd_ip) values('$user','$title','$ly','$user_ip')");<br />//----------------->写入数据库,这里不需要累赘了吧<br />header("location:index.php");<br />//----------------->直接页面跳转,相当于response.redirect,不sleep时间的.<br />$conn->Close();<br />$conn =NULL;<br />else{<br />//----------------->,如果页面没提交,输出表单,深度 1<br />require_once('postfunction.php');<br />postfunction();<br /> }<br />?></code></p></p><p> 上面设计到一个获取ip的函数,在inc/function.php里面,函数名getip,返回ip。请添加到里面。</p><code>// 获取客户端IP<br />function getip() {<br />if (isset($_SERVER)) {<br /> if (isset($_SERVER[HTTP_X_FORWARDED_FOR])) {<br /> $realip = $_SERVER[HTTP_X_FORWARDED_FOR];<br /> } elseif (isset($_SERVER[HTTP_CLIENT_IP])) {<br /> $realip = $_SERVER[HTTP_CLIENT_IP];<br /> } else {<br /> $realip = $_SERVER[REMOTE_ADDR];<br /> }<br />} else {<br /> if (getenv("HTTP_X_FORWARDED_FOR")) {<br /> $realip = getenv( "HTTP_X_FORWARDED_FOR");<br /> } elseif (getenv("HTTP_CLIENT_IP")) {<br /> $realip = getenv("HTTP_CLIENT_IP");<br /> } else {<br /> $realip = getenv("REMOTE_ADDR");<br /> }<br />}<br />return $realip;<br />}</code></p></p>