PHP+Mysql+jQuery实现发布微博程序 php篇


Posted in PHP onOctober 15, 2015

先还是要说明本例的业务流程:
1、前端用户输入内容,并对输入的内容字数进行实时统计。
2、用户提交数据,jQuery实现通过Ajax向后台发送数据。
3、后台PHP接收提交表单的数据,并对数据进行必要的安全过滤。
4、后台PHP连接Mysql数据库,并将提交过来的表单数据写入到相应的数据表中。
5、后台向返回成功结果数据内容,并通过Ajax将返回的数据内容插入到前端页面中。
上述1、2步在前篇文章:jQuery篇已讲解了,本文将完成剩余的散步。

效果图:

PHP+Mysql+jQuery实现发布微博程序 php篇

数据表
首先我们要准备一个数据表,表结构如下:

CREATE TABLE `say` ( 
 `id` int(11) NOT NULL auto_increment, 
 `userid` int(11) NOT NULL default '0', 
 `content` varchar(200) NOT NULL, 
 `addtime` int(10) NOT NULL, 
 PRIMARY KEY (`id`) 
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

注意,本例中将时间字段:addtime的类型设置为int,是为了后续的时间处理方便,在很多应用中(如Discuz论坛)都是将时间类型转成数字型。
时间轴处理函数和格式化输出列表函数:
时间轴处理函数,就是把时间转换成我们看到的诸如“5分钟前”,“昨天 10:21”等形式,代码如下:

/*时间转换函数*/ 
function tranTime($time) { 
 $rtime = date("m-d H:i",$time); 
 $htime = date("H:i",$time); 
 $time = time() - $time; 
 
 if ($time < 60) { 
  $str = '刚刚'; 
 } 
 elseif ($time < 60 * 60) { 
  $min = floor($time/60); 
  $str = $min.'分钟前'; 
 } 
 elseif ($time < 60 * 60 * 24) { 
  $h = floor($time/(60*60)); 
  $str = $h.'小时前 '.$htime; 
 } 
 elseif ($time < 60 * 60 * 24 * 3) { 
  $d = floor($time/(60*60*24)); 
  if($d==1) 
   $str = '昨天 '.$rtime; 
  else 
   $str = '前天 '.$rtime; 
 } 
 else { 
  $str = $rtime; 
 } 
 return $str; 
}

格式化输出函数是将得到的用户信息和发布内容及时间按照一定的格式输出到前端页面的函数,代码如下:

function formatSay($say,$dt,$uid){ 
 $say=htmlspecialchars(stripslashes($say)); 
 
 return' 
 <div class="saylist"><a href="#"><img src="images/'.$uid.'.jpg" width="50" height="50" 
 alt="demo" /></a> 
 <div class="saytxt"> 
 <p><strong><a href="#">demo_'.$uid.'</a></strong> '. 
preg_replace('/((?:http|https|ftp):\/\/(?:[A-Z0-9][A-Z0-9_-]*(?:\.[A-Z0-9][A-Z0-9_-]*)+): 
?(\d+)?\/?[^\s\"\']+)/i','<a href="$1" rel="nofollow" target="blank">$1</a>',$say).' 
 </p><div class="date">'.tranTime($dt).'</div> 
 </div> 
 <div class="clear"></div> 
 </div>'; 
}

将以上两个函数都放入function.php中,准备随时被调用。
submit.php处理表单数据
在之前文章中,我们知道jQuery将前端获得的数据以POST方式,通过Ajax提交给了后台的submit.php。那么submit就是要完成后续的所有一摊子任务。请看代码:

require_once('connect.php'); //数据库连接文件 
require_once('function.php'); //函数调用文件 
 
$txt=stripslashes($_POST['saytxt']); //获取提交的数据 
$txt=mysql_real_escape_string(strip_tags($txt),$link); //过滤HTML标签,并转义特殊字符 
if(mb_strlen($txt)<1 || mb_strlen($txt)>140) 
 die("0"); //判断输入字符数是否符合要求 
$time=time(); //获取当前时间 
$userid=rand(0,4); 
//插入数据到数据表中 
$query=mysql_query("insert into say(userid,content,addtime)values('$userid','$txt','$time')"); 
if(mysql_affected_rows($link)!=1) 
 die("0"); 
echo formatSay($txt,$time,$userid); //调用函数输出结果

注意,本例中为了演示,将用户ID(userid)进行随机处理,实际的应用是获取当前用户的ID。另外数据库连接文件,大家可以自己写一个,在我提供的下载的DEMO里也有这个文件。
最后要回到前端页面index.php来。index.php主要除了提供输入的入口,还要承接后台处理返回的结果,并且要将数据库里已有的数据显示出来。代码如下:

<?php 
define('INCLUDE_CHECK',1); 
require_once('connect.php'); 
require_once('function.php'); 
 
$query=mysql_query("select * from say order by id desc limit 0,10"); 
while ($row=mysql_fetch_array($query)) { 
 $sayList.=formatSay($row[content],$row[addtime],$row[userid]); 
} 
?> 
<form id="myform" action="say.php" method="post"> 
 <h3><span class="counter">140</span>说说你正在做什么...</h3> 
 <textarea name="saytxt" id="saytxt" class="input" tabindex="1" rows="2" cols="40"></textarea> 
 <p> 
 <input type="submit" class="sub_btn" value="提 交" disabled="disabled" /> 
 <span id="msg"></span> 
 </p> 
</form> 
<div class="clear"></div> 
<div id="saywrap"> 
<?php echo $sayList;?> 
</div>

以上就是本文的全部内容,希望对大家的学习有所帮助。

PHP 相关文章推荐
在WIN98下以apache模块方式安装php
Oct 09 PHP
PHP中读写文件实现代码
Oct 20 PHP
php 伪造本地文件包含漏洞的代码
Nov 03 PHP
PHP应用JSON技巧讲解
Feb 03 PHP
如何用php生成扭曲及旋转的验证码图片
Jun 07 PHP
PHP扩展CURL的用法详解
Jun 20 PHP
php常用字符串比较函数实例汇总
Nov 24 PHP
PHP中类的继承和用法实例分析
May 24 PHP
PHP7匿名类用法分析
Sep 26 PHP
php实现多维数组排序的方法示例
Mar 23 PHP
php生成二维码不保存服务器还有下载功能的实现代码
Aug 09 PHP
PHP中迭代器的简单实现及Yii框架中的迭代器实现方法示例
Apr 26 PHP
10个php函数实用却不常见
Oct 13 #PHP
PHP实现连接设备、通讯和发送命令的方法
Oct 13 #PHP
PHP如何通过传引用的思想实现无限分类(代码简单)
Oct 13 #PHP
JavaScript与HTML结合的基本使用方法整理
Oct 12 #PHP
apache和PHP如何整合在一起
Oct 12 #PHP
php实现Mysql简易操作类
Oct 11 #PHP
php实现微信公众平台账号自定义菜单类
Oct 11 #PHP
You might like
php获取服务器信息的实现代码
2013/02/04 PHP
php错误级别的设置方法
2013/06/17 PHP
php微信公众号开发之翻页查询
2018/10/20 PHP
基于jQuery的消息提示插件之旅 DivAlert(三)
2010/04/01 Javascript
jquery(hide方法)隐藏指定元素实例
2013/11/11 Javascript
利用JS进行图片的切换即特效展示图片
2013/12/03 Javascript
教你如何使用PHP输出中文JSON字符串
2014/05/22 Javascript
jquery获取html元素的绝对位置和相对位置的方法
2014/06/20 Javascript
javascript常见操作汇总
2014/09/03 Javascript
详解JavaScript中的Unescape()和String() 函数
2015/11/09 Javascript
解析javascript瀑布流原理实现图片滚动加载
2016/03/10 Javascript
PHP7新特性简述
2017/06/11 Javascript
使用jQuery实现页面定时弹出广告效果
2017/08/24 jQuery
javascript如何用递归写一个简单的树形结构示例
2017/09/06 Javascript
Vue异步加载about组件
2017/10/31 Javascript
Vue文件配置全局变量的实例
2018/09/06 Javascript
[40:53]完美世界DOTA2联赛PWL S3 Magma vs DLG 第二场 12.18
2020/12/20 DOTA
linux系统使用python监测网络接口获取网络的输入输出
2014/01/15 Python
Python实现同时兼容老版和新版Socket协议的一个简单WebSocket服务器
2014/06/04 Python
Python中endswith()函数的基本使用
2015/04/07 Python
在Python中用split()方法分割字符串的使用介绍
2015/05/20 Python
发布你的Python模块详解
2016/09/15 Python
python 2.6.6升级到python 2.7.x版本的方法
2016/10/09 Python
Python中判断子串存在的性能比较及分析总结
2019/06/23 Python
Django多层嵌套ManyToMany字段ORM操作详解
2020/05/19 Python
Python常用库Numpy进行矩阵运算详解
2020/07/21 Python
Python 操作SQLite数据库的示例
2020/10/16 Python
Python实现粒子群算法的示例
2021/02/14 Python
非常震撼的纯CSS3人物行走动画
2016/02/24 HTML / CSS
采用冷却技术的超自然舒适度:GhostBed床垫
2018/09/18 全球购物
农药学硕士毕业生自荐信
2013/09/25 职场文书
公务员四风问题对照检查材料整改措施
2014/09/26 职场文书
考研英语辞职信
2015/05/13 职场文书
2015年服务员个人工作总结
2015/05/27 职场文书
浅谈MySQL 亿级数据分页的优化
2021/06/15 MySQL
JS前端可视化canvas动画原理及其推导实现
2022/08/05 Javascript