ホームページ >バックエンド開発 >PHPの問題 >PHPデータベースからフォームデータを取得する方法

PHPデータベースからフォームデータを取得する方法

尚
オリジナル
2019-10-26 16:17:393768ブラウズ

PHPデータベースからフォームデータを取得する方法

php データベースを使用してフォームのコンテンツを取得します:

例:

<?php
// 创建连接
$conn = new mysqli("localhost", "uesename", "password");
// 检测连接
if ($conn->connect_error)
{ 
 die("连接失败: " . $conn->connect_error);}
 // 创建数据库
 $sql = "CREATE DATABASE test";
  if ($conn->query($sql) === TRUE)
  { 
  echo "数据库创建成功";
  } else { 
  echo "Error creating database: " . $conn->error;
  }
 $conn->close();
?>

次に、CREATE TABLE ステートメントを使用して MySQL テーブルを作成し、次のように設定します。田畑。

  • id ​​: これは、 int 型の一意であり、主キーを選択します。

  • #uesrname: ユーザー名、タイプは varchar、長さは 30。

  • password: パスワード、タイプは varchar、長さは 30。

  • confirm: パスワードを確認します。タイプは varchar、長さは 30 です。

  • email: 電子メール、タイプは varchar、長さは 30。

次に、SQL ステートメントを使用してデータベース テーブルを作成します。コードは次のようになります:

<?php
 // 创建连接
 $conn = new mysqli("localhost", "uesename", "password","test");
 // 检测连接
 if ($conn->connect_error)
 { 
 die("连接失败: " . $conn->connect_error);
 }
 // 使用 sql 创建数据表
 $sql = "CREATE TABLE login (
 id INT(10) UNSIGNED AUTO_INCREMENT PRIMARY KEY,
 username VARCHAR(30) NOT NULL,
 password VARCHAR(30) NOT NULL,
 confirm VARCHAR(30) NOT NULL,
 email VARCHAR(30) NOT NULL,
 )ENGINE=InnoDB DEFAULT CHARSET=utf8 ";
 if ($conn->query($sql) === TRUE)
 { 
 echo "Table MyGuests created successfully";
 } else { 
 echo "创建数据表错误: " . $conn->error;
 }
 $conn->close();
?>

上記でデータベースとテーブルを作成しました。シンプルなフォーム登録 フロントエンド ページのフォーム ページは非常にシンプルで、ユーザー名、パスワード、パスワード確認、登録電子メールなどの単純なテキスト ボックスがいくつかあります。コードは次のとおりです:

<!DOCTYPE html>
<html>
<head>
 <title>用户注册页面</title>
 <meta charset="UTF-8"/>
 <style type="text/css">
 *{margin:0px;padding:0px;}
 ul{
  width:400px;
  list-style:none;
  margin:50px auto;
 }
 li{
  padding:12px;
  position:relative;
 }
 label{
  width:80px;
  display:inline-block;
  float:left;
  line-height:30px;
 }
 input[type=&#39;text&#39;],input[type=&#39;password&#39;]{
  height:30px;
 }
 img{
  margin-left:10px;
 }
 input[type="submit"]{
  margin-left:80px;
  padding:5px 10px;
 }
 </style>
</head>
<body>
<form action="zhuce.php" method="post">
 <ul>
 <li>
  <label>用户名:</label>
  <input type="text" name="username" placeholder="请输入注册账号"/>
 </li>
 <li>
  <label>密 码:</label>
  <input type="password" name="password" placeholder="请输入密码" />
 </li>
 <li>
  <label>确认密码:</label>
  <input type="password" name="confirm" placeholder="请再次输入密码" />
 </li>
 <li>
  <label>邮 箱:</label>
  <input type="text" name="email" placeholder="请输入邮箱"/>
 </li>
 <li>
  <input type="submit" value="注册" />
 </li>
 </ul>
</form>
</body>
</html>

次に、PHP コードを使用して、新しいユーザーによって送信された情報をデータベースに送信する必要があります。 POST メソッドを使用して値を転送し、取得します。

まず、以前に作成したデータベースとテーブルに接続する必要があります。これは、新しいユーザーが登録したユーザー名、パスワード、その他の情報をテーブルの対応するフィールドに保存する必要があるためです。 。データをデータベーステーブルに保存する前に、送信されたデータに対して、要件を満たしていないユーザー名やメールアドレスなどをフィルタリングしたり、エラープロンプトを表示したりする必要があるなど、いくつかの判断と検証を行ってください。この名前が他のユーザーによって登録されている場合、このユーザー名を再度使用することはできないというメッセージが表示されます。これは、まずデータベースにすでに存在するユーザー名を読み取ってから判断することです。

簡単に言うと フォームに入力されたすべてのデータを変数に格納し、パスワードと認証コードを判定し、正しい場合は、ユーザー情報をデータベースに格納し、ユーザー情報のテーブルを格納しますファイルから抽出されたすべてのデータが に出力されます。端的に言えば、文の後半はデータの保存と取得についてです。具体的なコードは次のとおりです:

<?php
session_start();
header("Content-type:text/html;charset=utf-8");
$link = mysqli_connect(&#39;localhost&#39;,&#39;root&#39;,&#39;root&#39;,&#39;test&#39;);
if (!$link) {
 die("连接失败:".mysqli_connect_error());
}
$username = $_POST[&#39;username&#39;];
$password = $_POST[&#39;password&#39;];
$confirm = $_POST[&#39;confirm&#39;];
$email = $_POST[&#39;email&#39;];
if($username == "" || $password == "" || $confirm == "" || $email == "")
{
 echo "<script>alert(&#39;信息不能为空!重新填写&#39;);window.location.href=&#39;zhuce.html&#39;</script>";
} elseif ((strlen($username) < 3)||(!preg_match(&#39;/^\w+$/i&#39;, $username))) {
 echo "<script>alert(&#39;用户名至少3位且不含非法字符!重新填写&#39;);window.location.href=&#39;zhuce&#39;</script>";
 //判断用户名长度
}elseif(strlen($password) < 5){
 echo "<script>alert(&#39;密码至少5位!重新填写&#39;);window.location.href=&#39;zhuce.html&#39;</script>";
 //判断密码长度
}elseif($password != $confirm) {
 echo "<script>alert(&#39;两次密码不相同!重新填写&#39;);window.location.href=&#39;zhuce.html&#39;</script>";
 //检测两次输入密码是否相同
} elseif (!preg_match(&#39;/^[\w\.]+@\w+\.\w+$/i&#39;, $email)) {
 echo "<script>alert(&#39;邮箱不合法!重新填写&#39;);window.location.href=&#39;zhuce.html&#39;</script>";
 //判断邮箱格式是否合法
} elseif(mysqli_fetch_array(mysqli_query($link,"select * from login where username = &#39;$username&#39;"))){
 echo "<script>alert(&#39;用户名已存在&#39;);window.location.href=&#39;zhuce.html&#39;</script>";
} else{
 $sql= "insert into login(username, password, confirm, email)values(&#39;$username&#39;,&#39;$password&#39;,&#39;$confirm&#39;,&#39;$email&#39;)";
 //插入数据库
 if(!(mysqli_query($link,$sql))){
 echo "<script>alert(&#39;数据插入失败&#39;);window.location.href=&#39;zhuce.html&#39;</script>";
 }else{
 echo "<script>alert(&#39;注册成功!)</script>";
 }
}
?>

推奨: php サーバー

以上がPHPデータベースからフォームデータを取得する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。