在PHP中如何做出一个投票系统

在PHP中如何做出一个投票系统,第1张

是一个简单的投票程序,对于刚学PHP和朋友来说是一个很不错的入门程序。在这里给大家介绍一下,希望能对朋友们有所帮助。该系统是由以下四个文件组成的:有HTML调查表单的survey.htm,实现调查功能的survey.php,记录调查项目的data.txt和记录调查结果的survey.txt.其中data.txt和survey.txt我们可以用NOTEPAD分别创建之,并传到程序目录下。文件data.txt中存的是要进行调查的项目,注意每个项目应占一行;而survey.txt则可以是一个什么内容也没有的空文件。Survey.htm的代码可以如如下所示:<html>

<head>

<title>survey</title>

</head>

<盯返旦body>

<form method="POST" action="survey.php">

<p><input type="radio" value="0" name="vote">调查项目一</p>

<p><input type="radio" name="vote" value="1">调查项目二</p>

<p><input type="radio" name="vote" value="2">调查项目三</p>

<p><input type="radio" name="vote" value="3">调查项目四</p>

<p><input type="radio" name="vote" value="4">调查项目五</p>

<p><input type="hidden" name="go" value="1">

<p><input type="submit" value="提交" name="B1"></p>

<a href="survey.php?result=1">查看结果</a>

</form>

</body>

</html>注意文件data.txt中的调查项目与上面的调查项目在个数和排列顺序必须保持一致,否则会出错或调查的结果不准确。同时为了将调查结果显示成条形图形式,应该准备若干种不同颜色的条形图片凯扰。如:0.gif,1.gif,2.gif,3.gif,4.gif等.以下是实现调查功能的survey.php代码:<?

$data="data.txt"

$votes="survey.txt"

$dataf=file($data) /*读出调查项目文件中的项目*/

$file_votes=fopen($votes, "r")

$line_votes=fgets($file_votes, 255)/*读出已经记录的调查结果*/

fclose($file_votes)

$single_vote=explode("|", $line_votes)/* 并将数据按指定的字串切开,再将字串传回到数组变量中 */

if ($result!=1) /*如果已经接受了调查*/

{

$file_votes=file($votes, "r")

if ($REMOTE_ADDR == $file_votes[1]) /*检查是不是同一个人*/

{

echo "<center>世扒<font color=red>您已投过票了,谢谢您的参与!</font></center>"

exit

}

/*如果IP不重复,则执行以下程序*/

$ficdest=fopen($votes, "w")

for ($i=0$i<=count($dataf)-1$i++)

{

if ($i == $vote)

{ /*判断选择了哪个项目*/

$single_vote[$i]+=1

}

fputs($ficdest, "$single_vote[$i]|")/*将数据写回文件*/

}

fputs($ficdest, "\n$REMOTE_ADDR")/* //写入投票者IP*/

fclose($ficdest)

$result=1/*投票成功*/

}

/*写入投票结果后并显示投票结果*/

if ($result==1)

{

echo "<table cellpadding=10>"

for ($i=0$i<=count($dataf)-1$i++)

{

/*取得投票总数*/

$tot_votes+=$single_vote[$i]

}

for ($i=0$i<=count($dataf)-1$i++)

{

$imag=strval($i).".gif"/*判断用哪种条形图片来显示统计结果*/

$stat[$i]=$single_vote[$i]/$tot_votes*100/*计算百分比*/

$scla=$stat[$i]*5/*条形图和放大倍数,这里是安百分数的5倍的相素的宽度来显示的*/

echo "<tr><td><li><font face=Verdana size=2>"

echo "$dataf[$i]</font></td><td align=left><font face=Verdana size=2>"

echo "<img src=\"$imag\" height=20 width=$scla align=middle>"/*输出条形码图*/

printf("%.1f", "$stat[$i]")

echo "%</font></td><td align=center><font face=Verdana size=2>"

/*输出本栏目投票数*/

echo "$single_vote[$i]</font>"

echo "</td></tr>"

}

echo "</table><p>"

echo "<font face=Verdana size=2>总投票数:$tot_votes </font>"

}

?>说明: 在这里为了防止一人多投是采用记录最近的一位投票者的IP的方法来实现的,而最近的一位投票的IP地址是WEB客户机在对服务器发出请求时存储在环境变量REMOTE_ADDR中的。我也是一个初学者,关于这篇文章可能有许多错误和不当之处欢迎各位提出宝贵的意见和建议。谢谢!

投票唯知技术

分为 前端页面交互 用户选择选项,展示投票数

后端php 肯定是要处理投票数据的处理

1 用户唯一标示 用户注册登录 比如微信注册登陆、手机号注册登陆

2 用户点击选项后数据提交服务器端,php处理提交过来的 选项+用户id标示存放到 数据库通常是 mysql 判断是否可以每天投票 还是只能投一票

3 投票结束后 做投票咐山正数据的展示

总衡悔之 php就是结合数据库来做数据的 处理和展示

<?php

header("Content-type: text/html charset=utf-8")

$link = mysql_connect( 'localhost', 'root'乎笑, '') or die('Could not connect to mysql server' )

mysql_select_db('tpxt',$link) or die('Could not select database')

if (isset($_POST['submit'])) {

$sql = "SELECT `id` FROM `table` WHERE `uid` = ".$_POST['uid']

$result = mysql_query($sql)

if ($result && mysql_num_rows($result)) {

$sql = "UPDATE `table` SET `vote`=`vote`+1 WHERE `uid` = ".$_POST['uid']

mysql_query($sql)

}else{

$sql = "INSERT INTO `table`(uid,vote) VALUES('".$_POST['uid']."','1')"

mysql_query($sql)

}

echo "<script>alert('Ok 投票成功!')</script>"

echo "<script>window.location.reload()</script>"

exit()

}else{

$sql = "SELECT `vote` FROM `table` WHERE `uid` = 灶或3"

$result = mysql_query($sql)

if ($result && mysql_num_rows($result)) {

$t3 = mysql_fetch_assoc($result)

}else{

$t3['vote'] = 0 

}

$sql = "SELECT `vote` FROM `table` WHERE `uid` = 4"

$result = mysql_query($sql)

if ($result && mysql_num_rows($result)) {

$t4 = mysql_fetch_assoc($result)

}else{

$t4['vote'] = 0 

}

$sql = "SELECT `vote` FROM `table` WHERE `uid` = 5"岁辩含

$result = mysql_query($sql)

if ($result && mysql_num_rows($result)) {

$t5 = mysql_fetch_assoc($result)

}else{

$t5['vote'] = 0 

}

$sql = "SELECT `vote` FROM `table` WHERE `uid` = 6"

$result = mysql_query($sql)

if ($result && mysql_num_rows($result)) {

$t6 = mysql_fetch_assoc($result)

}else{

$t6['vote'] = 0 

}

$sql = "SELECT `vote` FROM `table` WHERE `uid` = 7"

$result = mysql_query($sql)

if ($result && mysql_num_rows($result)) {

$t7 = mysql_fetch_assoc($result)

}else{

$t7['vote'] = 0 

}

$count = $t3['vote']+$t4['vote']+$t5['vote']+$t6['vote']+$t7['vote']

$t3_b = $t3['vote']/$count

$t4_b = $t4['vote']/$count

$t5_b = $t5['vote']/$count

$t6_b = $t6['vote']/$count

$t7_b = $t7['vote']/$count

}

?>


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/yw/12398825.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-25
下一篇 2023-05-25

发表评论

登录后才能评论

评论列表(0条)

保存