PHP+Access设计留言版实战

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:web\php
–<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主要是以函数和模板著名吧,它支持class的继承。学好数组和模板技术是必须掌握的,但这里牵扯到的函数比较多,以后我5do8慢慢的给新手们介绍,关于php开发,函数那句话,模块化,能很好的于xhtml结合,模板技术,很有钱途的。

我在下面提到的深度就是指程序执行的 if..else 层数,一次判断是一个深度。

相关php的库函数请查看详尽书籍或者文章介绍,此处只讲”怎么用”

—–>style/css.all抄上面的也可以,估计速度比较慢,哈哈哈…
先说说数据库吧:

表 php_guest ,没啥说的,一看图就会了:

PHP+Access设计留言版实战

表php_admin,也没啥说的look here :

PHP+Access设计留言版实战

下面看看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’);
?>

解释:

<?
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);
?>

解释:

<?
$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><?=$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

<?
$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>[<?= $rs->Fields[1] ?>]AT[<?=str2time($rs->Fields[7]) ?>]Title:[<?=htmlspecialchars($rs->Fields[2]) ?>]  <?=admin_rep($rs->Fields[0] )?></h6>
<div><?= ubb($rs->Fields[4]) ?>[<?=$rs->Fields[5] ?>]
<sub><?= $rs->Fields[6] ?></sub>
</div>

 <? $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=”.($nowpage+1).”>下一页</a> ”;
}
echo “<a href=”.$myfilename.”?page=”.$rs->PageCount.”>尾页</a></h4> ”;
   }
$conn->Close();
$rs=NULL;
$conn =NULL;

?>

这是首页的全部文件,你只要替换我前面说的那个地方就行了,下面开始解释:

和asp的分页没啥大的区别,如果您明白asp的分页的话这个也很简单:sql读取记录,如果空的话输出为空的信息,如果不是空的话,读取当前的页数,页数为空或者大于记录总数的话游标定位到第一条,负责定位到 页数 * 每页的数目上.注意else对应和它相邻最近的if.

$page_sql=”select * from php_guest order by id desc”;
//——————>创建sql语句
$rs = new COM(‘ADODB.recordset’);    
//——————>创建记录对象
$rs->open($page_sql,$conn,1,1);
//——————>执行语句,返回记录集
$pagesize=$rs->Pagesize=$page_size ;
//——————>设置每页显示条数

if($rs->PageCount<>0){
//——————>防止数据库为空,执行深度 1
    if(!empty($_GET[‘page’])){
//——————>如果当前querysting中page不是空,执行这里,定位页数.执行深度 2
        if($_GET[‘page’]<=0){
        //——————>如果当前page小于0,定位页数到第一条.执行深度 3
            $rs->AbsolutePage=1;
            $nowpage=1;}
        elseif($_GET[‘page’]>$rs->PageCount){
         //——————>如果当前page大于记录总数,定位页数到第一条.执行深度 4
            $rs->AbsolutePage=$rs->PageCount;
            $nowpage=$rs->PageCount;
        }else{
        //——————>如果当前page不小于0到总数内,定位页数到page页.执行深度 3
        $rs->AbsolutePage=$_GET[‘page’];
        $nowpage=$_GET[‘page’];}
        }else{
//——————>如果当前querysting中page是空,执行这里,定位第一条记录.执行深度 2

        $rs->AbsolutePage=1;
        $nowpage=1;}
}else{
//——————>数据库为空的话执行这里,执行深度 1
$nowpage = 1;
$pagesize = 0;
}

for ($m=1; $m<=$pagesize; $m++)
//——————>按照每页显示条数的设定进行循环

{
        if (!$rs->EOF){
//——————>防止达到记录集尾产生错误
        ?>
<h6>[<?= $rs->Fields[1] ?>]AT[<?=str2time($rs->Fields[7]) ?>]Title:[<?=htmlspecialchars($rs->Fields[2]) ?>] <?=admin_rep($rs->Fields[0] )?></h6>
<div><?= ubb($rs->Fields[4]) ?>[<?=$rs->Fields[5] ?>]
<sub><?= $rs->Fields[6] ?></sub>
</div>

<?     $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=”.($nowpage+1).”>下一页</a> ”;}
                    echo “<a href=”.$myfilename.”?page=”.$rs->PageCount.”>尾页</a></h4> ”;
            }

$conn->Close();
$rs=NULL;
$conn =NULL;
//——————>释放资源,5do8没啥说的了,哈哈哈哈



上面有个htmlspecialchars函数,相当于server.htmlencode函数,原样输出的函数。

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 判断,返回值。

首页显示页面:

PHP+Access设计留言版实战

post.php:

<?php
require_once(‘inc/config.php’);
require_once(confign_path.’header.php’);
?>
<div id=”show_c”>
<?
 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> \n alert(\”输入必要的信息\”) \n</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>\n alert(\”名称有特殊字符\”)\n</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>\n alert(\”OICQ信息有错误\”)\n</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’);
?>

下面开始解释:

if($Submit)
{
//—————–>,如果页面已经提交,这里写一些入库的判断,深度 1

     if (empty($user)||empty($title)||empty($ly))
//—————–>如果有空值,输出不能为空的信息,深度 2
    echo “<meta http-equiv=\”Content-Type\” content=\”text/html; charset=gb2312\”>”;
    echo “<script language=javaScript> \n alert(\”输入必要的信息\”) \n</script>”;
    echo “<script language=javascript>javascript:history.back()</script>”;
    exit();}
     if (strrpos($user,”<“)!==false || strrpos($user,”>”)!==false || strrpos($title,”>”)!==false)
    {
//—————–>特殊输出字符,报错,深度深度 3
    echo “<meta http-equiv=\”Content-Type\” content=\”text/html; charset=gb2312\”>”;
    echo “<script language=javascript>\n alert(\”名称有特殊字符\”)\n</script>”;
    echo “<script language=javascript>javascript:history.back()</script>”;
    exit();}
if (!ereg(“^[0-9]{0,}$”,$qq))
{
//—————–>正则验证错误的,验证失败的话,报错.关于正则用法,ubb里面使用的最多,以后详谈.深度 3
echo “<meta http-equiv=\”Content-Type\” content=\”text/html; charset=gb2312\”>”;
echo “<script language=javascript>\n alert(\”OICQ信息有错误\”)\n</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的函数,在inc/function.php里面,函数名getip,返回ip。请添加到里面。

// 获取客户端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;
}

下一页