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