Design- und Implementierungsfreigabe des Abstimmungssystems PHP plus MySQL

不言
Freigeben: 2023-03-23 12:12:02
Original
3451 Leute haben es durchsucht

In diesem Artikel erfahren Sie mehr über das Design und die Implementierung des PHP-Plus-MySQL-Abstimmungssystems. Freunde in Not können sich auf das Design und die Implementierung des PHP-Abstimmungssystems beziehen Unten mit dem Datenbank-Ergebnisdesign stellte Script House endlich den Quellcode zum Download bereit

Das System ist nicht groß, daher habe ich den Prozess der Fertigstellung dieses Systems in drei Schritte unterteilt

•Datenbankdesign

•System-Framework-Design
•Front-End-Verschönerung


Datenbankdesign
Entwerfen Sie drei Tabellen: Abstimmungsergebnisstatistiktabelle (count_voting), Wählerdatensatztabelle (ip_votes), Benutzertabelle (Benutzer) Die Abstimmungsergebnis-Statistiktabelle wird verwendet, um die endgültigen Abstimmungsdatensätze zu zählen. Ich habe 4 Felder dafür: den Namen des abgestimmten Elements (SelectName), den Labelnamen des abgestimmten Elements (LabelName) (das abgespielt wird eine Rolle bei der Klassifizierung) und die Anzahl der Stimmen (CountVotes).

Die Wählerdatensatztabelle wird verwendet, um die IP (IP), den geografischen Standort (Location), die Abstimmungszeit (VoteTime) und den Namen des abgestimmten Elements (SelectName) des Wählers zu registrieren. Dann füge ich auch eine ID hinzu.

Die Benutzertabelle wird hauptsächlich für Administratoren verwendet, einschließlich Benutzername (name) und Passwort (passwd).

Das SQL-Skript zum Generieren der Tabelle lautet wie folgt:


Kopieren Sie den Code

Der Code lautet wie folgt:

Wie aus dem Skript hervorgeht, wird ein Trigger erstellt, der 1 zum Feld CountVotes in der Tabelle count_voting hinzufügt, wenn Daten in die Tabelle ip_votes eingefügt werden. Der letzte Satz kann auch zum Setzen externer verwandter Wörter verwendet werden.
-- 
-- 表的结构 `count_voting` 
-- 
DROP TABLE IF EXISTS `count_voting`; 
CREATE TABLE IF NOT EXISTS `count_voting` ( 
`SelectName` varchar(40) NOT NULL, 
`LabelName` varchar(40) NOT NULL, 
`CountVotes` bigint(20) unsigned NOT NULL, 
UNIQUE KEY `SelectName` (`SelectName`), 
KEY `CountVotes` (`CountVotes`), 
KEY `CountVotes_2` (`CountVotes`), 
KEY `CountVotes_3` (`CountVotes`) 
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='投票统计表'; 
-- -------------------------------------------------------- 
-- 
-- 表的结构 `ip_votes` 
-- 
DROP TABLE IF EXISTS `ip_votes`; 
CREATE TABLE IF NOT EXISTS `ip_votes` ( 
`ID` bigint(20) unsigned NOT NULL auto_increment COMMENT '投票人序号:自增', 
`IP` varchar(15) NOT NULL COMMENT '投票人IP', 
`Location` varchar(40) NOT NULL COMMENT '投票人位置', 
`VoteTime` datetime NOT NULL, 
`SelectName` varchar(40) NOT NULL, 
PRIMARY KEY (`ID`), 
KEY `ID` (`ID`), 
KEY `SelectName` (`SelectName`) 
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=4 ; 
-- 
-- 触发器 `ip_votes` 
-- 
DROP TRIGGER IF EXISTS `vote_count_after_insert_tr`; 
DELIMITER // 
CREATE TRIGGER `vote_count_after_insert_tr` AFTER INSERT ON `ip_votes` 
FOR EACH ROW UPDATE count_voting SET CountVotes = CountVotes + 1 WHERE SelectName = NEW.SelectName 
// 
DELIMITER ; 
-- -------------------------------------------------------- 
-- 
-- 表的结构 `user` 
-- 
DROP TABLE IF EXISTS `user`; 
CREATE TABLE IF NOT EXISTS `user` ( 
`name` varchar(10) NOT NULL COMMENT '管理员用户名', 
`passwd` char(32) NOT NULL COMMENT '登录密码MD5值' 
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用户表'; 
-- 
-- 转存表中的数据 `user` 
-- 
INSERT INTO `user` (`name`, `passwd`) VALUES 
('ttxi', '700469ca1555900b18c641bf7b0a1fa1'), 
('jitttanwa', 'adac5659956d68bcbc6f40aa5cd00d5c'); 
-- 
-- 限制导出的表 
-- 
-- 
-- 限制表 `ip_votes` 
-- 
ALTER TABLE `ip_votes` 
ADD CONSTRAINT `ip_votes_ibfk_1` FOREIGN KEY (`SelectName`) REFERENCES `count_voting` (`SelectName`) ON DELETE CASCADE ON UPDATE CASCADE;
Nach dem Login kopieren
Framework-Design

Die OperatorDB-Klasse wird zum Betreiben der Datenbank verwendet, und die OperatorVotingDB-Klasse wird für den systemspezifischen Satz von Operationen verwendet.
Verwenden Sie PDO, um die Datenbank zu betreiben, ich kapsele sie einfach:


Kopieren Sie den Code

Der Code lautet wie folgt:

/** 
* 操作数据库 
* 封装PDO,使其方便自己的操作 
*/ 
class OperatorDB 
{ 
//连接数据库的基本信息 
private $dbms='mysql'; //数据库类型,对于开发者来说,使用不同的数据库,只要改这个. 
private $host='localhost'; //数据库主机名 
private $dbName='voting'; //使用的数据库 
private $user='voting'; //数据库连接用户名 
private $passwd='voting'; //对应的密码 
private $pdo=null; 
public function __construct() 
{ 
//dl("php_pdo.dll"); 
//dl("php_pdo_mysql.dll"); 
$this->dsn="$this->dbms:host=$this->host;dbname=$this->dbName"; 
try 
{ 
$this->conn=new PDO($this->dsn,$this->user,$this->passwd);//初始化一个PDO对象,就是创建了数据库连接对象$db 
} 
catch(PDOException $e) 
{ 
die("<br/>数据库连接失败(creater PDO Error!): ".$e->getMessage()."<br/>"); 
} 
} 
public function __destruct() 
{ 
$this->pdo = null; 
} 
public function exec($sql) 
{ 
} 
public function query($sql) 
{ 
} 
}
Nach dem Login kopieren
Herstellen einer Verbindung zur Datenbank. Die Informationen werden gekapselt, um nachfolgende Vorgänge zu erleichtern.



Code kopieren

Der Code lautet wie folgt:

<?php 
require_once &#39;OperatorDB.php&#39;; 
class OperatorVotingDB 
{ 
private $odb; 
public function __construct() 
{ 
$this->odb = new OperatorDB(); 
} 
public function __destruct() 
{ 
$this->odb = null; 
} 
/** 
* 清空Voting数据中的所有表 
* 
* 调用数据库操作类,执行clear数据库的操作 
*/ 
public function clearTables() 
{ 
$sqls = array("TRUNCATE ip_votes;","TRUNCATE count_voting;"); 
$this->odb->exec($sqls[0]); 
$this->odb->exec($sqls[1]); 
} 
/** 
* 重置count_voting表中的CountValues字段为0 
* 
*/ 
public function resetCountValues() 
{ 
$sql = "UPDATE count_voting SET CountVotes = 0;"; 
$this->odb->exec($sql); 
} 
/** 
* 投票 
* 将信息写入ip_votes表 
* @param type $ip 
* @param type $loc 
* @param type $time 
* @param type $name 
*/ 
public function vote($ip,$loc,$name) 
{ 
$sql = "INSERT INTO ip_votes VALUES (NULL, &#39;$ip&#39;, &#39;$loc&#39;, NOW(), &#39;$name&#39;)"; 
$subsql = "SELECT MAX(to_days(VoteTime)) FROM ip_votes WHERE IP=&#39;$ip&#39;"; 
$stm = $this->odb->query($subsql); 
if (count($row=$stm->fetchAll())==1) 
{ 
$now = date("Y-m-d H:i:s"); 
$subsql = "SELECT to_days(&#39;$now&#39;);"; 
$stm = $this->odb->query($subsql)->fetch(); 
$time = $stm[0];//使用mysql计算出的today时间 
// echo $time."<br>"; 
// echo $row[0][0]; 
if ($time-$row[0][0]<1)//表中最大的时间和现在的时间$time比较 
{ 
echo "投票失败,相同ip需要隔一天才能投票"; 
return; 
} 
} 
// echo $sql; 
echo "投票成功!"; 
$this->odb->exec($sql); 
} 
/** 
* 添加SelectName字段的行 
* 
* @param string $name 
* @param string $label 
* @param int $count 
*/ 
public function addSelectName($name, $label, $count=0) 
{ 
$sql = "INSERT INTO count_voting VALUES (&#39;$name&#39;, &#39;$label&#39;, $count);"; 
$this->odb->exec($sql); 
} 
/** 
* 获取总投票情况,按票数排序的结果 
* 
* 按CountVotes字段排序,返回count_voting表 
* 
* @param int $n 
* 
*/ 
public function getVotesSortByCount($n=-1) 
{ 
$sql = "SELECT * FROM count_voting ORDER BY CountVotes DESC LIMIT 0 , $n;"; 
if (-1 == $n) 
{ 
$sql = "SELECT * FROM count_voting ORDER BY CountVotes DESC;"; 
} 
// echo $sql; 
return $this->odb->query($sql); 
} 
/** 
* 获取投票情况,按票数排序并按标签分组的结果 
* 
* 按CountVotes字段排序并按LabelName字段分组,返回count_voting表 
*/ 
public function getVotesGroupByLabel() 
{ 
$sql = "SELECT * FROM count_voting ORDER BY LabelName DESC;"; 
// echo $sql; 
return $this->odb->query($sql); 
} 
} 
?> 

下面还有需要的函数 
复制代码 代码如下:

<?php 
/** 
* 页面跳转函数 
* 使用js实现 
* @param string $url 
*/ 
function goToPgae($url) 
{ 
echo "<script language=&#39;javascript&#39; type=&#39;text/javascript&#39;>"; 
echo "window.location.href=&#39;$url&#39;"; 
echo "</script>"; 
} 
function jsFunc($fun, $arg=null) 
{ 
echo "<script language=&#39;javascript&#39; type=&#39;text/javascript&#39;>"; 
echo $fun."(&#39;$arg&#39;);"; 
echo "</script>"; 
} 
function jsFunc3($fun, $arg1=null,$arg2=null,$arg3=null) 
{ 
echo "<script language=&#39;javascript&#39; type=&#39;text/javascript&#39;>"; 
echo $fun."(&#39;$arg1&#39;,&#39;$arg2&#39;,&#39;$arg3&#39;);"; 
echo "</script>"; 
//echo $fun."(&#39;$arg1&#39;,&#39;$arg2&#39;,&#39;$arg3&#39;);"; 
} 
function isLoginNow() 
{ 
if ($_COOKIE["user"]==&#39;&#39;) 
{ 
return false; 
} 
return true; 
} 
function getClientIP() 
{ 
if ($_SERVER["HTTP_X_FORWARDED_FOR"]) 
{ 
if ($_SERVER["HTTP_CLIENT_IP"]) 
{ 
$proxy = $_SERVER["HTTP_CLIENT_IP"]; 
} 
else 
{ 
$proxy = $_SERVER["REMOTE_ADDR"]; 
} 
$ip = $_SERVER["HTTP_X_FORWARDED_FOR"]; 
} 
else 
{ 
if ($_SERVER["HTTP_CLIENT_IP"]) 
{ 
$ip = $_SERVER["HTTP_CLIENT_IP"]; 
} 
else 
{ 
$ip = $_SERVER["REMOTE_ADDR"]; 
} 
} 
return $ip; 
} 
//从123查获取ip 
function getIpfrom123cha($ip) { 
$url = &#39;http://www.123cha.com/ip/?q=&#39;.$ip; 
$content = file_get_contents($url); 
$preg = &#39;/(?<=本站主数据:<\/li><li style=\"width:450px;\">)(.*)(?=<\/li>)/isU&#39;; 
preg_match_all($preg, $content, $mb); 
$str = strip_tags($mb[0][0]); 
//$str = str_replace(&#39; &#39;, &#39;&#39;, $str); 
$address = $str; 
if($address == &#39;&#39;) { 
$address = &#39;未明&#39;; 
} 
return $address; 
} 
//从百度获取ip所在地 
function getIpfromBaidu($ip) { 
$url = &#39;http://www.baidu.com/s?wd=&#39;.$ip; 
$content = file_get_contents($url); 
$preg = &#39;/(?<=<p class=\"op_ip_detail\">)(.*)(?=<\/p>)/isU&#39;; 
preg_match_all($preg, $content, $mb); 
$str = strip_tags($mb[0][1]); 
$str = str_replace(&#39; &#39;, &#39;&#39;, $str); 
$address = substr($str, 7); 
if($address == &#39;&#39;) { 
$address = &#39;未明&#39;; 
} 
return $address; 
} 
?>
Nach dem Login kopieren
Dann erfahren Sie, wie die Vorgänge des Hintergrundadministrators ausgeführt werden, hauptsächlich die Funktion zum Hinzufügen von Abstimmungselementen. Die Betriebsdatenbank wurde oben implementiert. Im Folgenden erfahren Sie im Wesentlichen, wie Sie die Seite einrichten, die sich auf js bezieht. Die Seite zum Hinzufügen von Abstimmungselementen ist wie folgt dynamisch:



Code kopieren

Der Code lautet wie folgt:

Effekt:
function addVote() 
{ 
right.innerHTML="<h2>添加投票项</h2>"; 
right.innerHTML+="<label>投票项标签<label>"; 
addInput("right","cLabelName","地区名"); 
right.innerHTML+="<br><label>投票项名称<label>"; 
addInput("right","cSelectName","学校名"); 
right.innerHTML+="<br>"; 
var args = &#39;\&#39;./add.php\&#39;,\&#39;cSelectName\&#39;,\&#39;cLabelName\&#39;&#39;; 
var str = &#39;<input type=button value="\u6dfb加" onclick="goToPage(&#39;+args+&#39;);"/>&#39;; 
right.innerHTML+=str; 
} 
//添加文本框 
function addInput(parent,id,pla) 
{ 
//创建input 
var input = document.createElement("input"); 
input.type = "text"; 
input.id = id; 
input.placeholder = pla; 
document.getElementById(parent).appendChild(input); 
}
Nach dem Login kopieren


Design- und Implementierungsfreigabe des Abstimmungssystems PHP plus MySQLDas Löschen der Abstimmungselemente erfolgt ähnlich wie folgt:

Design- und Implementierungsfreigabe des Abstimmungssystems PHP plus MySQLUm Abstimmungselemente hinzuzufügen, werden Variablen an das Add übergeben .php-Seite über die URL.


Code kopieren

Der Code lautet wie folgt:

Das Folgende sind zwei Funktionen zum Springen zur Seite, js (der Sprung in func. php oben Seitenfunktionen werden auch über js implementiert).
<?php 
require_once &#39;../api/func.php&#39;; 

if (!isLoginNow()) 
{ 
goToPgae("./index.php"); 
} 

$name = $_GET["cSelectName"]; 
$label = $_GET["cLabelName"]; 
//echo $name."<br>".$label; 
require_once &#39;../api/OperatorVotingDB.php&#39;; 
$ovdb=new OperatorVotingDB(); 
$ovdb->addSelectName($name,$label); 
require &#39;./header.htm&#39;; 
goToPgae("./admin.php?page=add&auto="."$label"."&id=cLabelName&foc=cSelectName&msg=添加成功"); 
?>
Nach dem Login kopieren


Code kopieren

Der Code lautet wie folgt:

//js 
function goToPage(url,arg1,arg2) 
{ 
var a = document.getElementById(arg1).value; 
var b = document.getElementById(arg2).value; 
url += &#39;?&#39;+arg1+&#39;=&#39;+a; 
url += &#39;&&#39;+arg2+&#39;=&#39;+b; 
window.location.href=url; 
} 

function goToPage1(url) 
{ 
window.location.href=url; 
}
Nach dem Login kopieren
Die Änderungs- und Löschfunktion ist nicht implementiert. Ich werde das wahrscheinlich nicht umsetzen können, es ist fast dasselbe wie das Hinzufügen von Funktionalität in js.


Über das Login-Modul gibt es im Internet viele Nachahmungen. Senden Sie einfach das Formular ab, durchsuchen Sie die Datenbank und senden Sie die Ergebnisse zurück. Bei Erfolg werden Cookies gesetzt und die Funktion zur Erkennung von Cookies im Hintergrund auf jeder Seite hinzugefügt.

Front-End-Verschönerung
Die Seite index.php betreibt zunächst die Datenbank, um die Abstimmungselemente und die Anzahl der Stimmen zu erhalten, und zeigt sie dann an (verwenden Sie CSS + P, um die Rahmenschnittstelle oder ähnliches zu verschönern). Klicken Sie abschließend auf die Schaltfläche „Abstimmen“, um das Formular abzusenden und zur Seite „vote.php“ zu gelangen.

Für CSS habe ich es aus dem Internet kopiert. Der Effekt, den ich erzielt habe, ist wie folgt:


Design- und Implementierungsfreigabe des Abstimmungssystems PHP plus MySQLDieses Ding gilt als ein sehr kleines Informationsverwaltungssystem. Ich habe den Quellcode dieses Dings auf Github (https : //github.com/hanxi/voting) wird hochgeladen. Sie können es nach Belieben herunterladen und ändern oder von Script Home herunterladen (zum Herunterladen klicken). Leser können gerne antworten und mitteilen. Dieser Aspekt ist nicht meine Stärke und ich hoffe, Sie können mir einige Ratschläge geben.

Autor: Han Xi (Han Xi’s Technology Blog – Blog Park)
Weibo: t.qq.com/hanxi1203
Quelle: hanxi.cnblogs.com

Verwandte Empfehlung:

PHP-Konfiguration PHP-FPM-Startparameter und Konfigurationsdetails

Debugging-Zusammenfassung für PHP-Programmierer

Das obige ist der detaillierte Inhalt vonDesign- und Implementierungsfreigabe des Abstimmungssystems PHP plus MySQL. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage