求大神看看,小弟我做点赞时,限制每个ip只能点赞每篇文章一次,代码要如何实现

WBOY
Lepaskan: 2016-06-13 12:26:42
asal
1214 orang telah melayarinya

求大神看看,我做点赞时,限制每个ip只能点赞每篇文章一次,代码要怎么实现。
//前端ajax提交数据

     <input type="button"  onClick="change_love({$article.article_id})" value="赞一下"/></a><br />      <!--<input type="button" value="点赞" onClick="zan()"/>--><br />      {$article.love}</p><br />    </div><br />  </div><br /></section><br /><script><br />function change_love(article_id)<br />{<br /> //var Lastsend = document.getCookie('ECS_auction_Lastsend_'+article_id);<br /> //alert('点赞成功');<br /> $.ajax({<br />    url:'article.php',//后台处理路径<br />    type:'post',//post提交方式<br />    data:{id:article_id},//点赞的文章id<br />    success:function(data){//数据返回成功      <br />       if(data==1){//成功        <br />      }<br />   }<br /><br />});<br />}<br /></script>
Salin selepas log masuk



//后台更新数据库并判断ip是否存在
$realip=getip();<br />//echo $realip;<br />modifyipcount($realip);<br /><br />@$love=$_POST['id'];<br />if(isset($love)){<br />	$query="SELECT * FROM ecs_article_love where article_id='".$article_id."'";<br />	$result=mysql_query($query);<br />	$row=mysql_fetch_row($result);<br />	//dump($row);<br />	$ip1=$row[2];<br />	$ip2=$realip;<br />	//echo $ip;<br />	if(!empty($row) && strcmp($ip1,$ip2)==0){<br />		echo "<script>alert('ip已存在')</script>";<br />	}else{<br />		//$iptime=time();<br />		//$day=date('Y-m-d');<br />		//if($row[article_id]!=$article_id || $row[ip]!='')<br />		$query="INSERT INTO ecs_article_love (ip,article_id) VALUES ('".$ip2."','".$article_id."')";<br />		mysql_query($query);<br />		echo "<script>alert('点赞成功')</script>";<br />	}<br />}
Salin selepas log masuk


//判断ip的表


------解决思路----------------------
我觉得吧,设计一个表,只有两个字段即可,一个是文章id,一个是用户的ip,两个字段作为联合主键。
每次用户访问,查询,查到了就是点赞过。没查到就可以点赞,由于是联合主键,肯定只能插入一条,因此通过数据库就帮你做了一次限制。查看文章的点赞数,直接where 文章id即可count。

因此,联合主键的顺序是:文章id,用户ip
------解决思路----------------------
前面上现的 html 和 js 代码,表示你向 ajax 返回数据的代码有问题(入口点不对)
下面出现的 php 错误信息,表示你的程序没有做容错处理

先解决了这些再说

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!