PHPを使用して簡単な投票システムを開発する方法
PHP を使用して簡単な投票システムを開発する方法、具体的なコード例が必要です
はじめに:
インターネットの発展に伴い、投票のアプリケーションも増加しています。市場調査、選挙、イベント投票のいずれにおいても、システムの普及がますます高まっており、使いやすく効率的な投票システムが不可欠です。人気のあるプログラミング言語として、PHP は、シンプルで完全に機能する投票システムを迅速に開発するのに役立ちます。この記事では、PHP を使用した簡単な投票システムの開発方法と具体的なコード例を紹介します。
1. システムの機能要件の分析:
コードを書き始める前に、システム要件と機能を明確にする必要があります。基本的な投票システムには次の機能が必要です:
- ユーザー登録およびログイン機能。
- 投票のトピックとオプションを作成します。
- ユーザーは閲覧して投票に参加できます。
- 投票結果を表示します。
2. データベース設計:
ユーザー情報、投票トピックとオプション、投票結果を保存するには、データベース テーブルを設計する必要があります。以下は簡単なデータベース設計の例です:
-
Users テーブル (ユーザー):
- id: ユーザー ID、整数型、主キー
- username: ユーザー名、文字列型
- password: パスワード、文字列型
- created_at: 作成時刻、日付と時刻の型
-
投票トピックテーブル (投票):
- id: 投票トピック ID、整数型、主キー
- title: 投票トピックのタイトル、文字列型
- created_by: 作成済みユーザー ID、整数タイプ (ユーザー テーブルに関連付けられています)
- created_at: 作成時刻、日時タイプ
-
投票オプション テーブル (オプション):
- id: オプション ID、整数タイプ、主キー
- poll_id: 投票トピック ID、整数タイプ (投票トピック テーブルに関連付けられています)
- option_text: オプション テキスト、文字列type
-
投票結果テーブル(票):
- id: 投票結果ID、整数型、主キー
- poll_id : vote トピック ID、整数型 (投票トピック テーブルに関連付けられています)
- option_id: オプション ID、整数型 (投票オプション テーブルに関連付けられています)
- user_id: ユーザー ID、整数型 (ユーザー テーブルに関連付けられています))
3. システム開発手順:
-
データベースを作成して接続します:
最初に「voting_system」データベースという名前のデータベースを作成し、データベースに接続する必要があります:$conn = mysqli_connect("localhost", "root", "", "voting_system"); if (!$conn) { die("数据库连接失败:" . mysqli_connect_error()); }
ログイン後にコピー ユーザー登録とログイン機能:
ユーザーは登録してログインできる必要があります。システムに。簡単なコード例:a. ユーザー登録:
$username = $_POST['username']; $password = $_POST['password']; $hashed_password = password_hash($password, PASSWORD_DEFAULT); $sql = "INSERT INTO users (username, password) VALUES ('$username', '$hashed_password')"; if (mysqli_query($conn, $sql)) { echo "注册成功!"; } else { echo "注册失败:" . mysqli_error($conn); }
ログイン後にコピーb. ユーザー ログイン:
$username = $_POST['username']; $password = $_POST['password']; $sql = "SELECT * FROM users WHERE username='$username'"; $result = mysqli_query($conn, $sql); if (mysqli_num_rows($result) > 0) { $row = mysqli_fetch_assoc($result); if (password_verify($password, $row['password'])) { echo "登录成功!"; } else { echo "密码错误!"; } } else { echo "用户不存在!"; }
ログイン後にコピーポーリング トピックとオプションの作成:
投票トピックとオプションを作成するには、ユーザーがログインし、対応する権限を持っている必要があります。以下は簡単なコード例です:a. 投票トピックの作成:
$title = $_POST['title']; $created_by = $_SESSION['user_id']; $sql = "INSERT INTO polls (title, created_by) VALUES ('$title', '$created_by')"; if (mysqli_query($conn, $sql)) { echo "投票主题创建成功!"; } else { echo "投票主题创建失败:" . mysqli_error($conn); }
ログイン後にコピーb. 投票オプションの作成:
$poll_id = $_POST['poll_id']; $option_text = $_POST['option_text']; $sql = "INSERT INTO options (poll_id, option_text) VALUES ('$poll_id', '$option_text')"; if (mysqli_query($conn, $sql)) { echo "投票选项创建成功!"; } else { echo "投票选项创建失败:" . mysqli_error($conn); }
ログイン後にコピーユーザー参加投票中:
ユーザーは投票トピックを参照し、投票する投票オプションを選択する必要があります。簡単なコード例を次に示します:a. 投票トピックとオプションの表示:
$sql = "SELECT * FROM polls"; $result = mysqli_query($conn, $sql); while ($row = mysqli_fetch_assoc($result)) { echo "投票主题:" . $row['title'] . "<br>"; $poll_id = $row['id']; $sql_options = "SELECT * FROM options WHERE poll_id='$poll_id'"; $result_options = mysqli_query($conn, $sql_options); while ($row_option = mysqli_fetch_assoc($result_options)) { echo "<input type='checkbox' name='option_ids[]' value='" . $row_option['id'] . "'>" . $row_option['option_text'] . "<br>"; } echo "<hr>"; }
ログイン後にコピーb. ユーザー投票の処理:
$option_ids = $_POST['option_ids']; foreach ($option_ids as $option_id) { $sql = "INSERT INTO votes (poll_id, option_id, user_id) VALUES ('$poll_id', '$option_id', '$user_id')"; if (mysqli_query($conn, $sql)) { echo "投票成功!"; } else { echo "投票失败:" . mysqli_error($conn); } }
ログイン後にコピー投票結果の表示:
投票結果は、各選択肢の投票数をカウントすることで得られます。以下は簡単なコード例です:a. 統計的投票結果:
$poll_id = $_GET['poll_id']; $sql = "SELECT option_id, COUNT(*) AS vote_count FROM votes WHERE poll_id='$poll_id' GROUP BY option_id"; $result = mysqli_query($conn, $sql); while ($row = mysqli_fetch_assoc($result)) { $option_id = $row['option_id']; $vote_count = $row['vote_count']; $sql_option = "SELECT option_text FROM options WHERE id='$option_id'"; $result_option = mysqli_query($conn, $sql_option); $row_option = mysqli_fetch_assoc($result_option); echo $row_option['option_text'] . ": " . $vote_count . " 票<br>"; }
ログイン後にコピー
結論:
この記事では、PHP を使用して単純な投票を開発する方法を紹介します。システムを説明し、具体的なコード例を提供します。上記の手順により、ユーザーの登録とログイン、投票トピックとオプションの作成、ユーザーの投票への参加、投票結果の表示などの基本的な投票システム機能を実装できます。実際のニーズに応じて、さらなる最適化や拡張も行うことができます。この記事がお役に立てば幸いです!
以上がPHPを使用して簡単な投票システムを開発する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

記事では、PHP 5.3で導入されたPHPの後期静的結合(LSB)について説明し、より柔軟な継承を求める静的メソッドコールのランタイム解像度を可能にします。 LSBの実用的なアプリケーションと潜在的なパフォーマ

記事では、入力検証、認証、定期的な更新など、脆弱性から保護するためのフレームワークの重要なセキュリティ機能について説明します。

この記事では、フレームワークにカスタム機能を追加し、アーキテクチャの理解、拡張ポイントの識別、統合とデバッグのベストプラクティスに焦点を当てています。

PHP開発でPHPのCurlライブラリを使用してJSONデータを送信すると、外部APIと対話する必要があることがよくあります。一般的な方法の1つは、Curlライブラリを使用して投稿を送信することです。

PHP開発における固体原理の適用には、次のものが含まれます。1。単一責任原則(SRP):各クラスは1つの機能のみを担当します。 2。オープンおよびクローズ原理(OCP):変更は、変更ではなく拡張によって達成されます。 3。Lischの代替原則(LSP):サブクラスは、プログラムの精度に影響を与えることなく、基本クラスを置き換えることができます。 4。インターフェイス分離原理(ISP):依存関係や未使用の方法を避けるために、細粒インターフェイスを使用します。 5。依存関係の反転原理(DIP):高レベルのモジュールと低レベルのモジュールは抽象化に依存し、依存関係噴射を通じて実装されます。

システムが再起動した後、UnixSocketの権限を自動的に設定する方法。システムが再起動するたびに、UnixSocketの許可を変更するために次のコマンドを実行する必要があります:sudo ...
