重庆分公司,新征程启航

为企业提供网站建设、域名注册、服务器等服务

php数据库点赞功能 php点赞的代码

php用数据库怎么实现赞功能?

就应该数据库进行数据存储,安全!赞功能很简单,既然是要对文章做功能,那么互动角色就是会员,考虑一个问题,会员需要不需要登录才能点赞,如果不需要登录也可以点赞,你需要有个匿名会员。

网站建设哪家好,找成都创新互联公司!专注于网页设计、网站建设、微信开发、成都小程序开发、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了夏河免费建站欢迎大家使用!

那么表方面三个:一个文章表,一个赞表,一个会员表

数据存储:

会员点击了赞,相应的数据存到赞的表里面,这个三个表怎么关联的呢?其核心是赞表,这个表里面存有文章的id号和会员的id号,形成关系。

数据读取:

文章内容读取时候,根据文章的id,从赞的表调取相关数据统计,ok。

Php点赞效果的制作代码+解析

数据库设计

先准备两张表,pic表保存的是图片信息,包括图片对应的名称、路径以及图片“赞”总数,pic_ip则记录用户点击赞后的IP数据。

CREATE TABLE IF NOT EXISTS `pic` ( 

`id` int(11) NOT NULL AUTO_INCREMENT, 

`pic_name` varchar(60) NOT NULL, 

`pic_url` varchar(60) NOT NULL, 

`love` int(11) NOT NULL DEFAULT '0', 

PRIMARY KEY (`id`) 

) ENGINE=MyISAM  DEFAULT CHARSET=utf8; 

CREATE TABLE IF NOT EXISTS `pic_ip` ( 

`id` int(11) NOT NULL AUTO_INCREMENT, 

`pic_id` int(11) NOT NULL, 

`ip` varchar(40) NOT NULL, 

PRIMARY KEY (`id`) 

) ENGINE=MyISAM  DEFAULT CHARSET=utf8

index.php

在index.php中,我们通过PHP读取pic表中的图片信息并展示出来,结合CSS,提升页面展示效果。

?php 

include_once("connect.php"); 

$sql = mysql_query("select * from pic"); 

while($row=mysql_fetch_array($sql)){ 

$pic_id = $row['id']; 

$pic_name = $row['pic_name']; 

$pic_url = $row['pic_url']; 

$love = $row['love']; 

liimg src="images/?php echo $pic_url;?" alt="?php echo $pic_name;?"pa href="#"  

title="赞"class="img_on" rel="?php echo $pic_id;?"?php echo $love;?/a/p/li 

?php }?

CSS中,我们将定义鼠标滑向和离开红心按钮的动态效果,并定位按钮的位置。

.list{width:760px; margin:20px auto} 

.list li{float:left; width:360px; height:280px; margin:10px; position:relative} 

.list li p{position:absolute; top:0; left:0; width:360px; height:24px; line-height:24px;  

background:#000; opacity:.8;filter:alpha(opacity=80);} 

.list li p a{padding-left:30px; height:24px; background:url(images/heart.png) no-repeat  

4px -1px;color:#fff; font-weight:bold; font-size:14px} 

.list li p a:hover{background-position:4px -25px;text-decoration:none}

jQuery代码

当用户点击自己喜欢的图片上的红心按钮时,向后台love.php发送ajax请求,请求响应成功后,更新原有的数值

$(function(){ 

$("p a").click(function(){ 

var love = $(this); 

var id = love.attr("rel"); //对应id 

love.fadeOut(300); //渐隐效果 

$.ajax({ 

type:"POST", 

url:"love.php", 

data:"id="+id, 

cache:false, //不缓存此页面 

success:function(data){ 

love.html(data); 

love.fadeIn(300); //渐显效果 

}); 

return false; 

}); 

});

love.php

后台love.php接收前端的ajax请求,根据提交的图片id值,查找IP表中是否已有该用户ip的点击记录,如果有则告诉用户已“赞过了”,反之,则进行一下操作:

1、更新图片表中对应的图片love字段值,将数值加1。

2、将该用户IP信息写入到pic_ip表中,用以防止用户重复点击。

3、获取更新后的赞值,即赞该图片的用户总数,并将该总数输出给前端页面。

include_once("connect.php"); //连接数据库 

$ip = get_client_ip(); //获取用户IP 

$id = $_POST['id']; 

if(!isset($id) || empty($id)) exit; 

$ip_sql=mysql_query("select ip from pic_ip where pic_id='$id' and ip='$ip'"); 

$count=mysql_num_rows($ip_sql); 

if($count==0){ //如果没有记录 

$sql = "update pic set love=love+1 where id='$id'"; //更新数据 

mysql_query( $sql); 

$sql_in = "insert into pic_ip (pic_id,ip) values ('$id','$ip')"; //写入数据 

mysql_query( $sql_in); 

$result = mysql_query("select love from pic where id='$id'"); 

$row = mysql_fetch_array($result); 

$love = $row['love']; //获取赞数值 

echo $love; 

}else{ 

echo "赞过了.."; 

}

我上传的附件中 数据库SQL 你可以直接建立test 数据库UTF8编码的,然后把SQL文件导入进去。修改一下connect.php中数据库的连接信息即可。

【新手求助】PHP点赞功能,急!!!

html:

head

script src="common/js/jquery.js" type="text/javascript"/script

script language="JavaScript" type="text/javascript"

jQuery(function($) {

//这两个是鼠标放上去的效果

$(".zhan").hover(function(){

$(this).children("b").toggle();

}); 

$(".cai").hover(function(){

  $(this).children("b").toggle();

}); 

}); 

/script

script type="text/javascript"

!--这两个点击事件可以改进的,因为事件问题,所以就弄了两个点击事件

$(document).ready(function(e) {

//点赞(给力)

$('.zhan').click(function(){

var zhan=$(this);

var left = parseInt($(this).offset().left)+10, top =  parseInt($(this).offset().top)-10, obj=$(this);

$(this).append('div id="zhan"b+1\/b/\div');

$('#zhan').css({'position':'absolute','z-index':'1', 'color':'#C30','left':left+'px','top':top+'px'}).animate({top:top-10,left:left+10},'slow',function(){

$(this).fadeIn('fast').remove();

var Num = parseInt(obj.find('span').text());

Num++;

obj.find('span').text(Num);

});

$.ajax({

url:"ajax.php?action=zan",

type:"post",

data:"answer_id="+$(this).attr("alt"),

success:function(datas){

zhan.unbind('click');

zhan.parent().parent().siblings().children().children().unbind('click');

zhan.parent().parent().siblings().children().children().attr("class","evaluate-inner");

zhan.attr("class","evaluate-inner");

}

});

});

//踩(不给力)

$('.cai').click(function(){

var cai=$(this);

var left = parseInt($(this).offset().left)+10, top =  parseInt($(this).offset().top)-10, obj=$(this);

$(this).append('div id="cai"b-1\/b/\div');

$('#cai').css({'position':'absolute','z-index':'1', 'color':'#7DAAD5','left':left+'px','top':top+'px'}).animate({top:top-10,left:left+10},'slow',function(){

$(this).fadeIn('fast').remove();

var Num = parseInt(obj.find('span').text());

Num--;

obj.find('span').text(Num);

});

$.ajax({

url:"ajax.php?action=cai",

type:"post",

data:"answer_id="+$(this).attr("alt"),

success:function(datas){

cai.unbind('click');

cai.parent().parent().siblings().children().children().unbind('click');

cai.parent().parent().siblings().children().children().attr("class","evaluate-inner");

cai.attr("class","evaluate-inner");

}

});

});

});

//--

/script

/head

body

!--给力开始--

span data-evaluate="0" id="evaluate-1908165795" class="evaluate" alog-action="qb-zan-btn" span  class="evaluate-outer"

!-----判断对应的回答的id是否在自己创建的存储赞和踩数据的php文件,如果赞或者踩存在一个的话就不能再单击----

span class="evaluate-inner {if $answer_datas.ans_id|in_array:$zan_list or $answer_datas.ans_id|in_array:$cai_list/}{else/}zhan{/if/}" alt="{$answer_datas.ans_id/}" b  style="display:none" class="evaluate-tip evaluate-num-fixed"给力/b b  class="evaluate-num evaluate-num-fixed" span{$answer_datas.goods/}/span/b /span /span /span

!--不给力开始--

span data-evaluate="0" id="evaluate-bad-1908165795" class="evaluate evaluate-bad" alog-action="qb-evaluate-outer" span class="evaluate-outer" span class="evaluate-inner {if $answer_datas.ans_id|in_array:$zan_list or $answer_datas.ans_id|in_array:$cai_list/}{else/}cai{/if/}" alt="{$answer_datas.ans_id/}" b  style="display: none;" class="evaluate-tip evaluate-num-fixed"不给力/b b  class="evaluate-num evaluate-num-fixed" style="display: inline-block;"span{$answer_datas.bads/}/span/b /span /span /span

/div

/div

!--评论回答开始--

/body

/html

php

?php

$action=$_GET['action'];//获取get方式传过来的action

require_once("array/ovovsys_zan.php");

switch($action){

case 'detail':

/*****赞开始****/

$zan_list = json_decode(str_replace("'",'"',$zan_json),true);

$zan_lists=array();

foreach($zan_list as $key=$value){

if($value['uid']==$uid){

  $zan_lists[]=$value['answer_id'];

}

}

$smarty-assign('zan_list',$zan_lists);//查询当前登录的会员的uid对应的点赞的回答

/*****赞结束****/

/*****踩开始****/

$cai_list = json_decode(str_replace("'",'"',$cai_json),true);

$cai_lists=array();

foreach($cai_list as $key=$value){

if($value['uid']==$uid){

  $cai_lists[]=$value['answer_id'];

}

}

$smarty-assign('cai_list',$cai_lists);//查询当前登录的会员的uid对应的踩的回答

/*****踩结束****/

$smarty-display('自己的静态页面');

exit();

break;

}

?

ajax

?php 

require_once("array/ovovsys_zan.php");//这里引用array文件夹中的数组文件

$action=trim($_GET['action']);

if(empty($action)){

echo 'font color=red参数错误!/font';exit();

}

switch($action){

 case 'zan'://点赞(给力)

//$zan_json是数组文件中设置的数组变量,存的是json数据----1

$zan_array = json_decode(str_replace("'",'"',$zan_json),true);

//获取当前的会员的uid-----2

$user_answer['uid']=$uid;

//获取对应的赞的回答的id----2

$user_answer['answer_id']=$_POST['answer_id'];

//将会员的uid和答案的id一块的数组放到指定的数组中----3

$zan_array[]=$user_answer;

$config_path = 'shuzu/ovovsys_zan.php';

if(!file_exists($config_path)){

$Base-ErrorMsg('文件错误:shuzu/ovovsys_zan.php 不存在!');exit();

}

//将指定的数组转换成json数据,并且将双引号转换成单引号,不然放到数组文件中后会出错----4

$zan_new_json = str_replace('"',"'",json_encode($zan_array));

$fp = @fopen($config_path,'r+');

if(!$content = @fread($fp,filesize($config_path))){

$Base-ErrorMsg('无法读取shuzu/ovovsys_zan.php文件!');exit();

}

//执行替换,将数组文件中对应的json数据----5

$content = str_replace("\$zan_json = \"{$zan_json}\"","\$zan_json = \"{$zan_new_json}\"",$content);

$fp = @fopen($config_path,'w+'); 

@fwrite($fp,$content); 

//修改对应的数据表中的数据----5

$Db-ThisQuery("update `".$db_prefix."ask_answers` set `goods`=`goods`+1 where `ans_id`=".$user_answer['answer_id']."");

exit();

break;

 case 'cai'://踩(不给力)

$cai_array = json_decode(str_replace("'",'"',$cai_json),true);

$user_answer['uid']=$uid;

$user_answer['answer_id']=$_POST['answer_id'];

$cai_array[]=$user_answer;

$config_path = 'shuzu/ovovsys_zan.php';

if(!file_exists($config_path)){

$Base-ErrorMsg('文件错误:shuzu/ovovsys_zan.php 不存在!');exit();

}

$cai_new_json = str_replace('"',"'",json_encode($cai_array));

$fp = @fopen($config_path,'r+');

if(!$content = @fread($fp,filesize($config_path))){

$Base-ErrorMsg('无法读取shuzu/ovovsys_zan.php文件!');exit();

}

$content = str_replace("\$cai_json = \"{$cai_json}\"","\$cai_json = \"{$cai_new_json}\"",$content);

$fp = @fopen($config_path,'w+'); 

@fwrite($fp,$content); 

$Db-ThisQuery("update `".$db_prefix."ask_answers` set `bads`=`bads`-1 where `ans_id`=".$user_answer['answer_id']."");

exit();

break;

}

?

对应的数据文件(因为创建数据库时没有创建踩和赞的再断,所以这里就用php文件存变量的方式保存了一下答案对应的赞和踩的数据,其中包含用户的id和答案的id):

?php

$zan_json = "";

$cai_json = "";

?

你没看错,就是两个变量

PHP点赞和踩功能的怎么实现,代码怎么写

这个问题应该属于javascript类,你这样提问会导致知道分类分到php里去了。

实际上应该是前端控制的,有人说了,可以用jquery的$.post,如果你要用两个form, 那就不能用$('form')这种方式提交,因为会选到两个Form,可以分别加标示区分

form id='good'

/form

form id='bad'

/form

script

$('#good').submit();

/script

而且点赞和踩,这种功能,不需要用到form, 两个Button就可以了


本文名称:php数据库点赞功能 php点赞的代码
转载源于:http://cqcxhl.com/article/dopjgje.html

其他资讯

在线咨询
服务热线
服务热线:028-86922220
TOP