検索
ホームページバックエンド開発PHPチュートリアル[php] 投票システム管理者の一部、投票の追加と削除

[php] 投票システム管理者パート、投票の追加と削除

卒業制作ではないので投票システムの導入については多くは語りません

主にphpの使い方について話します投票システムは、他の通常のシステムと同様に、管理者部分と一般ユーザー部分の 2 つの部分に分かれています

投票システムの管理部分に関しては、非常に簡単です投票を増やすための 2 つの部分の機能を提供します。投票

を削除するための鍵は、データベース テーブルを設計することです。

は、次のように投票を格納するように計画されています。投票が削除されたかどうかの説明。votechildren テーブルには、選択肢と投票の数


1。 >

まず、投票システムは次のようなものです:

3 つのリンクをクリックすると、この記事の関連機能を直接操作できます。主に管理者部分を書き、一般ユーザー部分は jpgraph を使って別の章を開いて説明します。
中間はログインシステムがあるべきだと言われています。 ここでは重要ではありません。以前の「[php] ログイン システムと出力ビューア情報」を参照してください (クリックしてリンクが開きます)

クリックして投票オプションを追加すると、次のインターフェイスが表示され、投票オプションを追加および削除できます。投票オプションは最大 10 個、アバター オプションは少なくとも 2 個あります。超過または不足している場合は、次のメッセージが表示されます。

プレビュー画像は IE6 を使用しています。したがって、オプションの追加と削除の応答が遅くなります。
管理者が投票情報を入力すると、投票は正常に追加できるようになります。

送信すると、管理者は誤操作を防ぐためにそれを追加するかどうか尋ねられます
ここのシステムは実際に xajax を使用して投票データに何かがあるかどうかを調査する必要があり、オプションが空の場合は追加すべきではありませんはい、

詳しくは、「[php] 登録システムと Xajax を使用してユーザー名が占有されているかどうかを即座に確認する」を参照してください (クリックするとリンクが開きます)。この記事では、主に投票システムのコア実装について説明します。以下の詳細をお見逃しなく。

次に、投票システムの削除投票部分をクリックし、それぞれの最後にある


投票 削除ボタンがあります。
各投票タイトルをクリックして投票を表示します:

削除ボタンをクリックすると、 「確認」をクリックすると、投票が正常に削除されます。

上の図では、前に 4 つの投票があることがはっきりとわかります。 1 つの投票

2. 基本的な考え方

投票システムの管理者部分は削除しません。新しいテクノロジーやデータベース操作がある場合は、まず、voteparent テーブルの構造は次のとおりです。

id は自動です。 -increment 列。タイトルは、「私はハンサムです」の上に「ハンサムではありません」など、この投票のタイトルです。次のテキストは、この投票の説明を保存するために使用されます。自動インクリメント列は切断されません。削除方法が使用され、削除ビット isdel が設定され、削除ビットが 0 の投票が表示されます。
votechildren テーブルは次のとおりです。id は自動インクリメント列で、text は各サブオプションの説明を格納するために使用され、count はこのサブオプションの投票数を格納するために使用されます。 parentid は、このサブオプションがどの投票に属するかを保存するために使用されます。 voteparent テーブルには参照制約があることは明らかですが、操作時のトラブルを避けるために外部キーを設定する必要はありません

は注目に値します2 つのテーブルを作成したら、文字化けを避けるために必ずテーブル オプション タブに移動し、両方のテーブルのエンコードを utf-8 に設定してください


サイトのディレクトリ構造は次のとおりです:


この記事では、createvote.html、createvote.php、delvote.php のみについて説明します。 、delvotehandle.php、Index.html 5 ページのコンテンツ

3. 制作プロセス

1. > まず、最も基本的な、

という 3 つのリンクだけを持つ、index.html ですが、ここでは説明しません。HTML を学習したばかりの人ならわかるでしょう。コードは次のとおりです:

2. createvote.html

独自の js 関数を使用して投票ページを追加します。投票ページの追加は大きなフォームです。

<meta http-equiv="Content-Type" content="text/html; charset=utf-8"><title>投票系统</title><a href="createvote.html">添加投票(管理员部分)</a><br><a href="delvote.php">删除投票(管理员部分)</a><br><a href="voteindex.php">投票(普通用户部分)</a>
もあり、現在存在するオプションの数を記録するために使用されます。
投票操作ページ createvote を追加するための操作基盤を提供します。

ここでは、Web ノードでの JavaScript の基本的な操作について説明します。以前の記事「[JavaScript] Web ページ ノードの追加、削除、変更、検査」を参照してください。クリックしてリンクを開きます)

追加されたサブオプション ノードが opt1、opt2、opt3... の順序で規則的に配置されることに注意してください。これは、次の操作を容易にするためです

3. createvote.php

<meta http-equiv="Content-Type" content="text/html; charset=utf-8"><title>创建投票</title><h1 id="增加投票">增加投票</h1><button onclick="createbtn()">增加选项</button> <button onclick="delbtn()">删除选项</button><!--onsubmit属性是为了下面脚本能够顺利弹出确认框,用户确认之后才提交这个表单-->
投票主题:
投票描述:
选项1:
选项2:
返回<script>//脚本部分,是现实的关键//开始先记录当前的选项数是2,并存入hidden域,到时候随表单一起提交var nodenum=2;document.getElementById("nodetotal").value=nodenum;//下面是“增加选项”“删除选项”的按钮操作function createbtn(){ //如果选项少于10个才操作 if(nodenum<10){ nodenum++; var node=document.createElement("div"); //操作节点如果涉及html文本,写成单引号就不用写\"这么难看的双引号的转义字符 node.innerHTML="选项"+nodenum+":<input type=&#39;text&#39; name=&#39;opt"+nodenum+"&#39; style=&#39;width:70%&#39; />"; document.getElementById("createform").appendChild(node); //记得增加完每个节点,要更新以下hidden域里面的节点数哦! document.getElementById("nodetotal").value=nodenum; } else{ alert("最多10个选项"); }}//逻辑跟上面一样function delbtn(){ if(nodenum>2){ nodenum--; d=document.getElementById("createform"); d.removeChild(d.lastChild); document.getElementById("nodetotal").value=nodenum; } else{ alert("至少2个选项"); }}//表单确认框的脚本,表单onsubmit为true才能够提交嘛,confirm点确定则返回true反之为falsefunction check(){ return confirm("确定提交?");}</script>投票処理ページを追加します。

这里插入数据库要注意,先插入voteparent,再找出刚插入voteparent的那条记录的id,插入votechildren表的parentid,

这里找parentid需要注意,不要通过寻找最后一条插入记录的方法,找到parentid,因为这样如果多个管理员在操作数据库的并发时,会产生混乱

由于这里有中文,

操作数据库之前,记得加上mysql_query("set names utf8");这句话,详情请看代码:

<meta http-equiv="Content-Type" content="text/html; charset=utf-8"><title>添加投票处理中……</title><?php //首先取出刚才要添加投票的title与text,隐藏域中的选项数$ptitle=$_REQUEST["title"];$ptext=$_REQUEST["text"];$nodetotal=$_REQUEST["nodetotal"];$con=mysql_connect("localhost","root","root");//连接数据库if(!$con){	die("连接失败!");	}mysql_select_db("test",$con);mysql_query("set names utf8");//把title与text插入到voteparent表,设定删除位是0之后,系统会自动生成idmysql_query("insert into voteparent(title,text,isdel) values (&#39;".$ptitle."&#39;,&#39;".$ptext."&#39;,0);");//再通过title找到刚才系统生成的id$pid;$result=mysql_query("select id as pid from voteparent where title=&#39;".$ptitle."&#39;;");while($row=mysql_fetch_array($result)){	$pid=$row["pid"];}//建立一个php数组,里面存放每一个子选项$optarr=array();//选项的多少决定了我们的循环次数for($i=1;$i<$nodetotal+1;$i++){	$optarr[$i]=$_REQUEST["opt${i}"];	mysql_query("insert into votechildren(text,count,parentid) values (&#39;".$optarr[$i]."&#39;,0,&#39;".$pid."&#39;);");	};	mysql_close($con);	?><script>alert("添加成功");window.location.href="index.html";</script>

以上,管理员添加投票功能做完,下面是管理员删除投票功能


4、delvote.php

先把voteparent中所有的删除位不为1的投票查询出来,然后降序排列,因为人们希望先看到最新添加的投票

生成节点的时候设置好每一个投票的删除按钮id,这个id就是在数据库中的voteparent的id,方便后续操作

删除按钮的脚本不用写什么,就是把这个id传到delvotehandle.php,删除处理页中就可以了

<meta http-equiv="Content-Type" content="text/html; charset=utf-8"><title>删除投票</title><h1 id="删除投票">删除投票</h1><?php $con=mysql_connect("localhost","root","root");if(!$con){	die("连接失败!");}mysql_select_db("test",$con);mysql_query("set names utf8");$result=mysql_query("SELECT * FROM voteparent where isdel=0 order by id desc;");$i=1;while($row=mysql_fetch_array($result)){	echo "<div style=&#39;margin-right:10px;float:left&#39;>投票${i}:<a href="'vote.php?id=%24%7Brow%5B%22id%22%5D%7D'">${row["title"]}</a><div style="'float:left'"><button id="'${row["id"]}'" onclick="'deljs(this.id)'">删除</button></div><div style="'clear:both'"></div>";	$i++;}mysql_close($con);?><p><a href="index.html">返回</a></p><script>function deljs(id){	if(confirm("确认删除?")){		window.location.href="delvotehandle.php?id="+id;		}	}</script>
基本思想就是这样,其中这个页面采用了div布局,而不是table,详情可以参考我之前的《【CSS】关于div的对齐与网页布局》(点击打开链接)


5、delvotehandle.php

取到刚才传过来的id,根据这个id把相应的isdel删除位设定为1即可

<meta http-equiv="Content-Type" content="text/html; charset=utf-8"><title>删除投票处理中……</title><?php $pid=$_REQUEST["id"];$con=mysql_connect("localhost","root","root");if(!$con){	die("连接失败!");	}mysql_select_db("test",$con);mysql_query("set names utf8");mysql_query("update voteparent set isdel=1 where id=".$pid.";");mysql_close($con);	?><script>alert("删除成功");window.location.href="index.html";</script>

以上就是投票系统管理员部分,增加投票与删除投票的过程,按理说相关的处理页面,还需要进行session的保护,

避免直接输入网址就能够访问,这里没写

可以参考我之前的《【php】登录系统与输出浏览者信息》(点击打开链接)

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
PHPでインターフェイスをどのように作成して使用しますか?PHPでインターフェイスをどのように作成して使用しますか?Apr 30, 2025 pm 03:40 PM

この記事では、PHPでインターフェイスを作成、実装、および使用する方法について説明し、コード組織と保守性の利点に焦点を当てています。

crypt()とpassword_hash()の違いは何ですか?crypt()とpassword_hash()の違いは何ですか?Apr 30, 2025 pm 03:39 PM

この記事では、PHPのCrypt()とpassword_hash()の違いについて、パスワードハッシュの違いについて説明し、最新のWebアプリケーションの実装、セキュリティ、および適合性に焦点を当てています。

PHPのクロスサイトスクリプト(XSS)をどのように防ぐことができますか?PHPのクロスサイトスクリプト(XSS)をどのように防ぐことができますか?Apr 30, 2025 pm 03:38 PM

記事では、入力検証、出力エンコード、およびOWASP ESAPIやHTML浄化器などのツールを使用して、PHPのクロスサイトスクリプト(XSS)を防止します。

PHPの自動装置は何ですか?PHPの自動装置は何ですか?Apr 30, 2025 pm 03:37 PM

PHPでのオートローディングは、必要に応じてクラスファイルを自動的にロードし、メモリの使用を削減し、コード組織を強化することでパフォーマンスを向上させます。ベストプラクティスには、PSR-4の使用とコードを効果的に整理することが含まれます。

PHPストリームとは何ですか?PHPストリームとは何ですか?Apr 30, 2025 pm 03:36 PM

PHPストリームは、一貫したAPIを介したファイル、ネットワークソケット、圧縮形式などのリソースの処理を統合し、複雑さを抽象化し、コードの柔軟性と効率を高めます。

PHPを使用してアップロードできるファイルの最大サイズはどれくらいですか?PHPを使用してアップロードできるファイルの最大サイズはどれくらいですか?Apr 30, 2025 pm 03:35 PM

この記事では、PHPでファイルアップロードサイズの管理を管理し、2MBのデフォルト制限とPHP.ini設定を変更してそれを増やす方法に焦点を当てています。

PHPのめまいの種類とは何ですか?PHPのめまいの種類とは何ですか?Apr 30, 2025 pm 03:34 PM

この記事では、PHP 7.1で導入されたPHPのヌル可能なタイプについて説明し、変数またはパラメーターが指定されたタイプまたはnullのいずれかを可能にします。読みやすさの改善、タイプの安全性、明示的な意図などの利点を強調し、宣言する方法を説明します

unset()とlink()関数の違いは何ですか?unset()とlink()関数の違いは何ですか?Apr 30, 2025 pm 03:33 PM

この記事では、プログラミングのunset()とlink()関数の違いについて説明し、目的とユースケースに焦点を当てています。 unset()はメモリから変数を削除しますが、link()はファイルシステムからファイルを削除します。どちらもEFFECにとって重要です

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール