php制作留言板二[源码]

 更新时间:2016年11月25日 16:12  点击:1328

第三步就是php代码处理留言的信息合法性了,

<?php
require_once("inc/connect.php");
 $myname =get_value('myname',post);
 $mymail =get_value('mymail',post);
 $mytel =get_value('mytel',post);
 $mybook =get_value('mycontent',post);
 //exit($mymail);
 if(strlen($myname)>100 || strlen($myname)<1){alert('用户长度1-100','');}
 if(!@preg_match("/\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*/",$mymail) || strlen($mymail)<6 ){alert('请输入正确的邮箱地址以便我们与你联系!','');}
 if(!@preg_match("/\d{3}-\d{8}|\d{4}-\d{7}/",$mytel)){alert('请输入合法的电话如:0731-******','');}

 $sql ="select * from tbn where gx_object='$myname' and gx_mail='$mymail'";
 $result =mysql_query($sql); 
 if(mysql_num_rows($result)){
  mysql_free_result($result);
  alert('提示,你己提交留言,请不要重复提交!','');
 }
 $sql ="Insert into tbn(gx_content,gx_time,gx_tel,gx_mail,gx_object) value('$mybook','".date('y-m-d')."','$mytel','$mymail','$myname')";
 mysql_query($sql) or die(alert('你的留言中有非法数据!',''));
 alert('提示:留言成功',$_SERVER['HTTP_REFERER']);
  
 ?>

最四步就是显示留言了.

<?php
 include("../inc/connect.php"); 
  ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>无标题文档</title>
<link href="style/admin.css" rel="stylesheet" type="text/css" />

<style type="text/css">
<!--
.STYLE1 {color: #000000}
.STYLE2 {color: #0000FF}
-->
</style>
<script>
<!--
function all_(str){


 var box_l = document.getElementsByName("box_x[]").length;


 for(var j = 0 ; j < box_l ; j++){


  document.getElementsByName("box_x[]")[j].checked = str;


 }


}
--></script>
</head>

<body>
<table width="95%" border="0" align="center" cellpadding="1" cellspacing="1" style="margin-top:20px; border:1px solid #9abcde;">
 <tr>
    <td height="25" colspan="3" background="skins/top_bg.gif"><table width="98%" border="0" align="center" cellpadding="0" cellspacing="0">
       <form id="form2" name="form2" method="post" action="?"> <tr>
          <td width="100%">你正在管理留言信息... </td>
          <td width="0%" align="right">
            <label></label><label></label></td>
        </tr></form>
      </table></td>
    </tr> <form id="form1" name="form1" method="post" action="menu_sava.php?action=allbook">
     <td width="4%"></tr>
 
    <?php
 
  $result =mysql_query("select * from tbn");
  $pagecount=1;
  $order=1;
  if(isset($_POST['key'])){
  $key=str_replace("'","*",$_POST['key']);
  }else if(isset($_GET['key'])){
  $key=str_replace("'","*",$_GET['key']);
  }else{
   $key='';
  }
  $total="select * from tbn";
  $sql="select * from tbn";
  if(!empty($key) && !is_null($key) && strlen($key)>2 && strlen($key)<50 ){
   $total.=" where gx_title like '%$key%' ";
 $sql.=" where gx_title like '%$key%' ";

  } 
  $result=mysql_query($total) or die('fail1'.mysql_error());
  $rs=mysql_fetch_array($result);
  $rdcount=mysql_num_rows($result);
  if($rdcount){
  $pagesize=15;
  $pagecount=($rdcount % $pagesize)?(int)($rdcount / $pagesize)+1:$rdcount/$pagesize;//统计总页面
  $page=isset($_GET['page'])?$_GET['page']:1;//取得当前页面
  $start=($page>=1 && $page<=$pagecount)?$start=$pagesize*($page-1):$start=1;//取得超始记录
  $order=isset($_GET['order'])?$_GET['order']:4;
   $sql.=" order by id desc limit $start,$pagesize";
   $resulte=mysql_query($sql) or die('fail'.mysql_error());
 while ($rs =mysql_fetch_array($resulte) ){
?>  <tr>
      <td height="25" colspan="3" align="left" valign="middle" background="images/main_bg.gif" class="td_heng" style="padding-right:5px;">
      &nbsp;
      <input type="checkbox" name="box_x[]" id="box_x[]" value="<?php echo $rs[0];?>" />
     
      标题:<?php echo $rs['gx_title']?>
      作者:<?php echo $rs['gx_object']?>
      电话:<?php echo $rs['gx_tel']?>
      时间:<?php echo $rs['gx_time']?>
      邮箱:<?php echo $rs['gx_mail']?></td>
  
    <tr onMouseOver="this.style.background='#d7ebff'" onMouseOut="this.style.background='#ffffff'">
      <td height="27" colspan="2" align="left" valign="middle" class="td_heng" style="padding:15px;">
   &nbsp;<?php echo $rs['gx_content']?>      </td>
      <td width="7%" align="center" valign="bottom" class="td_heng"><a href="menu_sava.php?action=delguest&id=<?php echo $rs[0];?>" onclick="javascript:return confirm('确认删除?删除后无法恢复','','');">删除</a></td>
    </tr>
    <tr>
     <td height="32" colspan="3">&nbsp;</td>
   </tr>
   <?php
   }
   }
   ?>
  
   <tr>
    <td height="32" colspan="3" background="skins/top_bg.gif"><table width="98%" border="0" align="center" cellpadding="0" cellspacing="0">
        <tr>
          <td width="34%"><input type="button" onclick="javascript:all_(true);" name="Submit" value="全选" />
            &nbsp;
            <input type="button"  onclick="all_(false);" name="Submit" value="反选" />
            &nbsp;
            <input type="submit" onclick="javascript:return confirm('确认提醒:删除后无法还原!','','');" value='删除所选项' /></td>
          <td width="66%" align="right" style="word-spacing:5px;">
    <?php
    $url ="?key=".rawurlencode($key)."&orderby=$order&page=";
    pagelist(@$page,$pagecount,$rdcount,$url,@$pagesize);
    ?></td>
        </tr>
      </table></td>
  </tr> </form>
</table>
</body>
</html>

 

注:原创文章转载请注明:www.111cn.net

 

function cnSubStr($string,$sublen

if(
$sublen>=strlen($string
)) 

return 
$string


$s=""

for(
$i=0;$i<$sublen;$i
++) 

if(
ord($string{$i})>127


$s.=$string{$i}.$string{++$i
}; 
continue; 
}else{ 
$s.=$string{$i
}; 
continue; 


return 
$s

}

 

<?PHP
$str="这个字^_^符好长呀,^_^";
$Short_Str=showShort($str,5);//截取前面4个汉字,结果为:这个字符...
Echo   "$Short_Str";
Function csubstr($str,$start,$len)
{
$strlen=strlen($str);
$clen=0;
for($i=0;$i<$strlen;$i++,$clen++)
{
if ($clen>=$start+$len)
break;
if(ord(substr($str,$i,1))>0xa0) //ord取首字符的ascii码
{
if ($clen>=$start)
$tmpstr.=substr($str,$i,2);
$i++;
}
else
{
if ($clen>=$start)
$tmpstr.=substr($str,$i,1);
}
}

return $tmpstr;
}
Function showShort($str,$len)
{
$tempstr = csubstr($str,0,$len);
if ($str<>$tempstr)
$tempstr .= "...";

return $tempstr;
}
?>

今天我们来讲一下用php制作简单的留言板,首先来分析一下留言板,

第一步:设计数据库.

第二步:设置html页面,就是留言页面,

第三步:php处理页面,保存到数据库.

第四步:留言显示页面.

好了我们先来看看第一步:

CREATE TABLE IF NOT EXISTS `gx_guestbook` (
  `id` int(4) NOT NULL auto_increment,
  `gx_title` varchar(200) default NULL,
  `gx_content` mediumtext,
  `gx_time` datetime default NULL,
  `gx_tel` varchar(20) default NULL,
  `gx_mail` varchar(50) default NULL,
  `gx_object` varchar(100) default NULL,
  PRIMARY KEY  (`id`)
) ENGINE=InnoDB  DEFAULT CHARSET=gb2312 AUTO_INCREMENT=10 ;

上面是创建数据库这里就没什么好说了.

再来看第二步设置html留言页面

<div id="guest">
<h4 class="top_line">客户留言</h4>
<ul>
<form action="guest_sava.php"  enctype="multipart/form-data" method="post">
<li><span><input name="myname" type="text" id="myname" size="22" />
</span>你的昵称:</li>
<li><span><input name="mymail" type="text" id="mymail" size="22" />
</span>你的电邮:</li>
<li><span><input name="mytel" type="text" id="mytel" size="22" />
</span>联系电话:</li>
<li><span>
  <textarea name="mycontent" cols="22" rows="7" class="case_matter" id="mycontent"></textarea>
</span>你的留言:</li>
<div style="clear:both; text-align:right; height:30px; padding-top:8px;"><input name="提交" type="submit" value="提交" />&nbsp; &nbsp;&nbsp; &nbsp; <input name="" type="reset" value="重置" />
</div>
</form>
</ul>
</div>

上面就是留言的页面了,效果图

很多朋友都在问题这个问题,大我都初学者了,今天我就把我自己的写的发出来吧,各位看了别笑啊.先看看php与js混合代码.

<script>
function GetObjId(ObjName)
{
//alert(document.all.tags('select')[i].name);
for(i = 0; i < document.all.tags('select').length; i++)
{
  if (document.all.tags('select')[i].name == ObjName) {return(i);  break;}
}
return(-1);
}

function Do_ToDo_Change(ObjName1, ObjName2, StatInt)
{
//document.forms[0].elements[0].name
var id1, id2, tempstr, tempint
var my_array = new Array();
<?php
$list='';
for($i=1;$i<=12;$i++){
 $osql ="Select * from gx_newtype where gx_masterid=$i";
 $resul =mysql_query($osql) or die(mysql_error());
 while($res =mysql_fetch_array($resul)){  
  $list=$list.$res['id'].'|'.$res['gx_typename'].',';
 }
 ?>
 my_array[<?php echo $i-1; ?>] = '<?php echo $list;?>';
 <?php
 $list='';
}
?>


id1 = GetObjId(ObjName1);
id2 = GetObjId(ObjName2);
tempint = document.all.tags('select')[id2].length;
for(i = 1; i < tempint; i++) {document.all.tags('select')[id2].options[1] = null}
if (document.all.tags('select')[id1].selectedIndex > StatInt - 1)
{
  tempstr = my_array[document.all.tags('select')[id1].selectedIndex - 1].split(",");
  for(i = 1; i <= tempstr.length; i++) {document.all.tags('select')[id2].options[i] = new Option(tempstr[i - 1].substr(tempstr[i - 1].indexOf("|") + 1), tempstr[i - 1].substr(0,tempstr[i - 1].indexOf("|")))}
}
}
</script>

看了上面的代码后有些朋友可能会有些问号?就是这样怎么行呢?js怎么能和php这样放在一起呢,我想如果你真的提出这个问题了,我想你大概不明白,服务器端脚本在客户端脚本之前执行吧?现在明白了吗?

下面来看我们是怎么让它们级联的.

 

<select name="select" id="select" onchange=Do_ToDo_Change('select','select2','1')>
            <?php
    $sql="Select * from fff order by master_order asc";
    $result=mysql_query($sql);
    while($rs =mysql_fetch_array($result)){
     echo("<option value=".$rs['id'].">".$rs['master_name']."</option>");
  }
   ?>
    </select>//这里是一级

<select name="select2"  value="" id="select2">
      <option value="0">--选择子类--</option>
    </select> //这里是子菜单 ,

我们来看看效果图吧:

 

注:原创文章,转载请注明:www.111cn.net

<?php
/*
 * 长文章分页类
 * @package cutpage
 * @author  yytcpt(无影)
 * @version 2008-03-27
 * @copyrigth http://www.d5s.cn/
 */
 class cutpage{
  var $pagestr;  //被切分的内容
  var $pagearr;  //被切分文字的数组格式
  var $sum_word;  //总字数(UTF-8格式的中文字符也包括)
  var $sum_page;  //总页数
  var $page_word;  //一页多少字
  var $cut_tag;  //自动分页符
  var $cut_custom; //手动分页符
  var $ipage;   //当前切分的页数,第几页
  var $url;
  function __construct(){
   $this->page_word = 1000;
   $this->cut_tag = array("</table>", "</div>", "</p>", "<br/>", "”。", "。", ".", "!", "……", "?", ",");
   $this->cut_custom = "{nextpage}";
   $tmp_page = intval(trim($_GET["ipage"]));
   $this->ipage = $tmp_page>1?$tmp_page:1;
  }
  //统计总字数
  function get_page_word(){
   $this->sum_word = $this->strlen_utf8($this->pagestr);
   return $this->sum_word;
  }
  /* 统计UTF-8编码的字符长度
   * 一个中文,一个英文都为一个字
   */
  function strlen_utf8($str){
     $i = 0;
     $count = 0;
     $len = strlen ($str);
     while ($i < $len){
      $chr = ord ($str[$i]);
      $count++;
      $i++;
      if ($i >= $len)
       break;
      if ($chr & 0x80){
       $chr <<= 1;
       while ($chr & 0x80) {
        $i++;
        $chr <<= 1;
       }
      }
     }
     return $count;
  }
  //设置自动分页符号
  function set_cut_tag($tag_arr=array()){
   $this->cut_tag = $tag_arr;
  }
  //设置手动分页符
  function set_cut_custom($cut_str){
   $this->cut_custom = $cut_str;
  }
  function show_cpage($ipage=0){
   $this->cut_str();
   $ipage = $ipage ? $ipage:$this->ipage;
   return $this->pagearr[$ipage];
  }
  function cut_str(){
   $str_len_word = strlen($this->pagestr);  //获取使用strlen得到的字符总数
   $i = 0;
   if ($str_len_word<=$this->page_word){ //如果总字数小于一页显示字数
    $page_arr[$i] = $this->pagestr;
   }else{
    if (strpos($this->pagestr, $this->cut_custom)){
     $page_arr = explode($this->cut_custom, $this->pagestr);
    }else{
     $str_first = substr($this->pagestr, 0, $this->page_word); //0-page_word个文字 cutStr为func.global中的函数
     foreach ($this->cut_tag as $v){
      $cut_start = strrpos($str_first, $v);  //逆向查找第一个分页符的位置
      if ($cut_start){
       $page_arr[$i++] = substr($this->pagestr, 0, $cut_start).$v;
       $cut_start = $cut_start + strlen($v);
       break;
      }
     }
     if (($cut_start+$this->page_word)>=$str_len_word){ //如果超过总字数
      $page_arr[$i++] = substr($this->pagestr, $cut_start, $this->page_word);
     }else{
      while (($cut_start+$this->page_word)<$str_len_word){
       foreach ($this->cut_tag as $v){
        $str_tmp = substr($this->pagestr, $cut_start, $this->page_word);  //取第cut_start个字后的page_word个字符
        $cut_tmp = strrpos($str_tmp, $v);  //找出从第cut_start个字之后,page_word个字之间,逆向查找第一个分页符的位置
        if ($cut_tmp){
         $page_arr[$i++] = substr($str_tmp, 0, $cut_tmp).$v;
         $cut_start = $cut_start + $cut_tmp + strlen($v);
         break;
        }
       } 
      }
      if (($cut_start+$this->page_word)>$str_len_word){
       $page_arr[$i++] = substr($this->pagestr, $cut_start, $this->page_word);
      }
     }
    }
   }
   $this->sum_page = count($page_arr);  //总页数
   $this->pagearr = $page_arr;
  }
  //显示上一条,下一条
  function show_prv_next(){
   $this->set_url();
   if ($this->sum_page>1 and $this->ipage<$this->sum_page){
    $str = "<a href='".$this->url.($this->ipage+1)."'>下一页</a> ";
   }
   if ($this->sum_page>1 and $this->ipage>1){
    $str.= "<a href='".$this->url.($this->ipage-1)."'>上一页</a>";
   }
   return $str;
  }
  function show_page_select(){
   if ($this->sum_page>1){
    $str = " &nbsp; <select onchange=\"location.href=this.options[this.selectedIndex].value\">";
    for ($i=1; $i<=$this->sum_page; $i++){
     $str.= "<option value='".$this->url.$i."' ".(($this->ipage)==$i ? " selected='selected'":"").">第".$i."页</option>";
    }
    $str.= "</select>";
   }
   return $str;
  }
  function show_page_select_wap(){
   if ($this->sum_page>1){
    $str = "<select ivalue='".($this->ipage-1)."'>";
    for ($i=1; $i<=$this->sum_page; $i++){
     $str.= "<option onpick='".$this->url.$i."'>第".$i."节</option>";
    }
    $str.= "</select>";
   }
   return $str;
  }
  function set_url(){
   parse_str($_SERVER["QUERY_STRING"], $arr_url);
   unset($arr_url["ipage"]);
   if (empty($arr_url)){
    $str = "ipage=";
   }else{
    $str = http_build_query($arr_url)."&ipage=";
   }
   $this->url = "http://".$_SERVER["HTTP_HOST"].$_SERVER["PHP_SELF"]."?".$str;
  }
 }
?>

 

如果您加了新功能,或者是有改进,请与大家一起分享。

长文章分页类,可以手工指定分页符,也可以让程序自动分页。

实例代码:请以UTF-8的文件编码进行测试。

代码:
<?php
    include('cutpage.php');
    header("content-type:text/html;charset=utf-8");//设置页面编码
    //自定义的长文章字符串,可以包含 html 代码,若字符串中有手动分页符 {nextpage} 则优先按手动分页符进行分页
    $content = file_get_contents('text.txt');
    $ipage = $_GET["ipage"]? intval($_GET["ipage"]):1;
    $CP = new cutpage();
    $CP->pagestr = $content;
    $CP->cut_str();
    echo $CP->pagearr[$ipage-1]."<hr/>";
    echo $CP->show_prv_next();
?>
[!--infotagslink--]

相关文章

  • 源码分析系列之json_encode()如何转化一个对象

    这篇文章主要介绍了源码分析系列之json_encode()如何转化一个对象,对json_encode()感兴趣的同学,可以参考下...2021-04-22
  • jQuery 2.0.3 源码分析之core(一)整体架构

    拜读一个开源框架,最想学到的就是设计的思想和实现的技巧。废话不多说,jquery这么多年了分析都写烂了,老早以前就拜读过,不过这几年都是做移动端,一直御用zepto, 最近抽出点时间把jquery又给扫一遍我也不会照本宣科的翻译...2014-05-31
  • node.js+express留言板功能实现示例

    本文介绍基于nodejs+express+art-template的留言板功能。包含列表界面、添加界面和发送留言功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-09-21
  • php实现网站留言板功能

    我要实现的就是下图的这种样式,可参考下面这两个网站的留言板,他们的实现原理都是一样的畅言留言板样式:网易跟帖样式:原理 需要在评论表添加两个主要字段 id 和 pid ,其他字段随意添加,比如文章id、回复时间、回复内容、...2015-11-08
  • php+ajax制作无刷新留言板

    本文就是和大家分享一款由php结合ajax实现的无刷新留言板,先给大家看一下最后的效果图:数据库连接代码如下: <&#63;php$conn = @mysql_connect("localhost","root","root") or die ("MySql连接错误");mysql_select_db("d...2015-10-30
  • vue3源码剖析之简单实现方法

    源码的重要性相信不用再多说什么了吧,特别是用Vue 框架的,一般在面试的时候面试官多多少少都会考察源码层面的内容,下面这篇文章主要给大家介绍了关于vue3源码剖析之简单实现的相关资料,需要的朋友可以参考下...2021-09-07
  • Underscore源码分析

    Underscore 是一个 JavaScript 工具库,它提供了一整套函数式编程的实用功能,但是没有扩展任何 JavaScript 内置对象。这篇文章主要介绍了underscore源码分析相关知识,感兴趣的朋友一起学习吧...2016-01-02
  • Vue实现简单的留言板

    这篇文章主要为大家详细介绍了Vue实现简单的留言板,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2020-10-22
  • Android Studio如何查看源码并调试的方法步骤

    这篇文章主要介绍了Android Studio如何查看源码并调试的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-05-15
  • Go语言实现简单留言板的方法

    这篇文章主要介绍了Go语言实现简单留言板的方法,涉及数据库、模板页面元素等留言板相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下...2020-05-03
  • 个人网站留言页面(前端jQuery编写、后台php读写MySQL)

    这篇文章主要为大家介绍了个人网站的留言页面,前端使用jQuery编写、后台利用php简单读写MySQL数据库,感兴趣的小伙伴们可以参考一下...2016-05-05
  • javascript实现简单留言板案例

    这篇文章主要为大家详细介绍了javascript实现简单留言板案例,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-02-09
  • php简易留言板程序代码

    这是一个最基础的留言板程序了,但是己经有了留言板程序基本功能,很适合于php初学者用用,学习用啊,当然也可以用于企业网站也是很不错的哦。 代码如下 复...2016-11-25
  • ASP.NET使用HttpWebRequest读取远程网页源代码

    本文分享了一个使用HttpWebRequest读取远程网页的案例,供大家参考学习。...2021-09-22
  • 用C#获取硬盘序列号,CPU序列号,网卡MAC地址的源码

    privatestring[]GetMoc() { string[]str=newstring[3]; ManagementClassmcCpu=newManagementClass("win32_Processor"); ManagementObjectCollectionmocCpu=mcCpu.GetInstan...2020-06-25
  • php留言板制作教程

    本文章给各位php入门者提供一篇从数据库的创建到最后的读写留言板过程全部分享给各位朋友,有需要了解的可参考参考。 创建一个数据表 代码如下 复制代码...2016-11-25
  • PHP结合Mysql数据库实现留言板功能

    这篇文章主要介绍了PHP结合Mysql数据库实现留言板功能的相关资料,需要的朋友可以参考下...2016-03-07
  • Php经典分页源码

    #********************************************************* #文件名称: function.php #功能描述: 新闻添加修改处理模块 #程序制作:留印(adleyliu) #联系qq :143...2016-11-25
  • php 简单留言板教程三

    好了,其它的都快完了我们就来看看index.php文件显示留方的页面吧. <?php @session_start(); include("global.php"); if(isset($_GET['act']) && $_GET['act'...2016-11-25
  • .NET Core 源码编译的问题解析

    这篇文章主要介绍了.NET Core 源码编译的问题解析,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2021-04-06