基于文本的留言簿


Posted in PHP onOctober 09, 2006

固然基数据库的留言簿可以作得很漂亮,而且也更好管理。 但是对于那些没有数据库空间的朋友们来说,基于文本的留言簿也完成可以适用于个人站来使用。而且只要我们努力去做同样可以做得很好,甚至可以说丝毫不比基于数据库的留言簿差。在这里我向介绍一个基于文本的留言簿。在下面这个地址你可以看到它的演示:http://bamboo.oso.com.cn/note.htm,它具有以下两个特点:
1.    用不同的颜我显示不同人发表的留言;
2.    每个留言者具有选择小图标的功能。
本留言簿要由以下四个文件组成:记录留言内容的note.txt文件;记录留言文字显示颜色的color.txt文件;这两个文件都可以有notepad来创建。反应留言表单的note.htm文件;最终处理留言信息的note.php文件。以下是它们的源代码:
note.htm:
<html>
<head>
<title>===留言簿===</title>
</head>
<body>
  <form method="POST" action="note.php">       
          你的大名:<input type="text" name="name" size="44"><br>       
          你的邮件地址:<input type="text" name="email" size="40"><br>       
          你的个人主页:<input type="text" name="webname" size="40"><br>       
          你的个人主页地址:<input type="text" name="webadd" size="35"><br>       
          你的留言:<br>       
                          
    <textarea rows="2" name="note" cols="50"></textarea>        
      请选择你喜欢的图标:        
       <input type="radio" value="1" checked name="icon">  <img border="0" src="n1.gif" width="19" height="18">         
    <input type="radio" name="icon" value="2">  <img border="0" src="n2.gif" width="16" height="16">      
    <input type="radio" name="icon" value="3">  <img border="0" src="n3.gif" width="16" height="16">     
    <input type="radio" name="icon" value="4">  <img border="0" src="n4.gif" width="19" height="18">       
    <input type="radio" name="icon" value="5">  <img border="0" src="n5.gif" width="19" height="18">       
    <input type="radio" name="icon" value="6">   <img border="0" src="n6.gif" width="19" height="18">      
    <input type="radio" name="icon" value="7">   <img border="0" src="n7.gif" width="15" height="15">       
    <input type="radio" name="icon" value="8">   <img border="0" src="n8.gif" width="19" height="18">        
       <input type="radio" name="icon" value="9">  <img border="0" src="n9.gif" width="19" height="18">         
    <input type="radio" name="icon" value="10">  <img border="0" src="n10.gif" width="18" height="18">     
    <input type="radio" name="icon" value="11">  <img border="0" src="n11.gif" width="18" height="18">     
    <input type="radio" name="icon" value="12">  <img border="0" src="n12.gif" width="18" height="18">       
    <input type="radio" name="icon" value="13">  <img border="0" src="n13.gif" width="15" height="15">        
    <input type="radio" name="icon" value="14">   <img border="0" src="n14.gif" width="18" height="18">      
    <input type="radio" name="icon" value="15">    <img border="0" src="n15.gif" width="15" height="15">               
    </div>     
  <div align="left">      
            
    <input type="submit" value="发送" name="B1"><input type="reset" value="重写" name="B2">       
    <a href="note.php?primsg=1">查看留言</a><br>      
    </div>     
  </form>      
  </body>                   
</html>                   
其中:nx.gif是小图标图片,你自己可以更换。
Note.php:
<?
    if($primsg==1){
       $f = fopen("note.txt","r");
       $msg = fread($f,filesize("note.txt"));
       fclose($f);
       print "$msg";  }
    else{
          if ($name=="") {
            print "你总得给我留下的你的大名吧!否则我如何称呼你?<br>";}
            else if  ($note=="") {
            print "你总得说点什么吧?否则点发送干什么?不会是点错了吧?想查看留言??<br>";
              }
          else{
             if  ($email=="") {
            print "连电子邮件地址也不给留?我如何跟你联系?<br>";
                }
             else if  ($webname==""||$webadd="") {
             print "你没有个人主页?如果有还是希望你给我留下的地址,当作是宣传也可以嘛!<br>";
                }
              $t = date(Y年m月d日);
              $note = str_replace ( "<",  "<", $note);
              $note = str_replace ( ">",  ">", $note);
              $note = str_replace ( "\n",  "<br>", $note);
              $f = fopen("color.txt","r+");
              $color1=fread($f,filesize("color.txt"));
              if($color1==0){
                $color=ff0000;}
              else if($color1==1){
                $color="0000ff";}
              else if($color1==2){
                $color="00ff00";
              }
              else if($color1==3){
                $color="000000";
              }
              if($color1>=3){
                 $color1=0;}
              else{
                 $color1+=1;
              }
              fseek($f,0);
              fputs($f,$color1);
              fclose($f);
              for($I=1;$I<=15;$I++){
                 if($I==$icon){
                   $pic=$I;
                   }
                 }
              $str=strval($pic);
              $strhtml="<img src='n".$str.".gif'>";
              $add="<a href=".$webadd."></a>";
              $main = "$strhtml<br><font color=$color><a href=\"mailto:$email\">$name</a>    个人主页: $add$webname</a>      ($t)<br>
              说:$note <br>";
              $f = fopen("note.txt","a");
              fwrite($f,$main);
              fclose($f);
               $f = fopen("note.txt","r");
              $msg = fread($f,filesize("note.txt"));
              fclose($f);
               echo"$msg";
              }
}
?>

PHP 相关文章推荐
PHP+AJAX实现无刷新注册(带用户名实时检测)
Jan 02 PHP
php获取mysql版本的几种方法小结
Mar 25 PHP
PHP中的session永不过期的解决思路及实现方法分享
Apr 20 PHP
PHP curl_setopt()函数实例代码与参数分析
Jun 02 PHP
php 删除目录下N分钟前创建的所有文件的实现代码
Aug 10 PHP
php安装xdebug/php安装pear/phpunit详解步骤(图)
Dec 22 PHP
php计划任务之ignore_user_abort函数实现方法
Jan 08 PHP
php远程下载类分享
Apr 13 PHP
PHP实现路由映射到指定控制器
Aug 13 PHP
基于php实现的php代码加密解密类完整实例
Oct 12 PHP
PHP并发查询MySQL的实例代码
Aug 09 PHP
php通过pecl方式安装扩展的实例讲解
Feb 02 PHP
图书管理程序(一)
Oct 09 #PHP
图书管理程序(二)
Oct 09 #PHP
改进的IP计数器
Oct 09 #PHP
聊天室php&amp;mysql(五)
Oct 09 #PHP
聊天室php&amp;mysql(四)
Oct 09 #PHP
一个简单的PHP入门源程序
Oct 09 #PHP
PHP学习之PHP表达式
Oct 09 #PHP
You might like
PHP 分页类(模仿google)-面试题目解答
2009/09/13 PHP
PHP 设置MySQL连接字符集的方法
2011/01/02 PHP
PHP设计模式之结构模式的深入解析
2013/06/13 PHP
php教程之魔术方法的使用示例(php魔术函数)
2014/02/12 PHP
PHP迭代与递归实现无限级分类
2017/08/28 PHP
Laravel框架实现调用百度翻译API功能示例
2019/05/30 PHP
DOM精简教程
2006/10/03 Javascript
web 页面分页打印的实现
2009/06/22 Javascript
JavaScript入门之事件、cookie、定时等
2011/10/21 Javascript
拉动滚动条加载数据的jquery代码
2012/05/03 Javascript
ExtJs中gridpanel分组后组名排序实例代码
2013/12/02 Javascript
JavaScript获取网页表单提交方式的方法
2015/04/02 Javascript
JavaScript实现倒计时代码段Item1(非常实用)
2015/11/03 Javascript
多个js毫秒倒计时同时进行效果
2016/01/05 Javascript
浅谈JS之iframe中的窗口
2016/09/13 Javascript
js日期相关函数dateAdd,dateDiff,dateFormat等介绍
2016/09/24 Javascript
JS使用正则表达式找出最长连续子串长度
2017/10/26 Javascript
JavaScript面试出现频繁的一些易错点整理
2018/03/29 Javascript
浅谈layer弹出层按钮颜色修改方法
2019/09/11 Javascript
Javascript ParentNode和ChildNode接口原理解析
2020/03/16 Javascript
js实现抽奖的两种方法
2020/03/19 Javascript
vue 基于abstract 路由模式 实现页面内嵌的示例代码
2020/12/14 Vue.js
[09:31]2016国际邀请赛中国区预选赛Yao赛后采访 答题送礼
2016/06/27 DOTA
[00:52]DOTA2国际邀请赛
2020/02/21 DOTA
python在linux中输出带颜色的文字的方法
2014/06/19 Python
Python实现竖排打印传单手机号码易撕条
2015/03/16 Python
Python cv2 图像自适应灰度直方图均衡化处理方法
2018/12/07 Python
python 进程 进程池 进程间通信实现解析
2019/08/23 Python
Python Pillow(PIL)库的用法详解
2020/09/19 Python
巴西女装购物网站:Eclectic
2018/04/24 全球购物
会计岗位职责模板
2014/03/12 职场文书
给老师的一封感谢信
2015/01/20 职场文书
实践论读书笔记
2015/06/29 职场文书
交通安全教育主题班会
2015/08/12 职场文书
七年级英语教学反思
2016/02/15 职场文书
Nginx配置80端口访问8080及项目名地址方法解析
2021/03/31 Servers