php如何把表单内容提交到数据库
⼀般朋友们逛⼀些⽹站的时候,想使⽤⽹站或者看到更多⽹站⾥的内容,⽹站会要求⽤户进⾏新⽤户的注册,⽹站会把新⽤户的注册信息存⼊数据库中,需要的时候再进⾏提取。
这样⽹站就会⾸先创建⾃⼰的数据库和对应的表,我们这⾥使⽤php创建⼀个简单的数据库和表,使⽤phpMyAdmin来创建MySql数据库和表。例如创建⼀个test数据库,其⽰例的代码如下所⽰:
<?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;}
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='text'],input[type='password']{
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('localhost','root','root','test');
if (!$link) {
die("连接失败:".mysqli_connect_error());
}
$username = $_POST['username'];
$password = $_POST['password'];
$confirm = $_POST['confirm'];
$email = $_POST['email'];
if($username == "" || $password == "" || $confirm == "" || $email == "")
echo "<script>alert('信息不能为空!重新填写');window.location.href='zhuce.html'</script>";
} elseif ((strlen($username) < 3)||(!preg_match('/^\w+$/i', $username))) {
echo "<script>alert('⽤户名⾄少3位且不含⾮法字符!重新填写');window.location.href='zhuce'</script>";
//判断⽤户名长度
}elseif(strlen($password) < 5){
echo "<script>alert('密码⾄少5位!重新填写');window.location.href='zhuce.html'</script>";
//判断密码长度
}elseif($password != $confirm) {
echo "<script>alert('两次密码不相同!重新填写');window.location.href='zhuce.html'</script>";
//检测两次输⼊密码是否相同
} elseif (!preg_match('/^[\w\.]+@\w+\.\w+$/i', $email)) {
echo "<script>alert('邮箱不合法!重新填写');window.location.href='zhuce.html'</script>";
//判断邮箱格式是否合法
} elseif(mysqli_fetch_array(mysqli_query($link,"select * from login where username = '$username'"))){
echo "<script>alert('⽤户名已存在');window.location.href='zhuce.html'</script>";
} else{php修改数据库内容
$sql= "insert into login(username, password, confirm, email)values('$username','$password','$confirm','$email')";
//插⼊数据库
if(!(mysqli_query($link,$sql))){
echo "<script>alert('数据插⼊失败');window.location.href='zhuce.html'</script>";
}else{
echo "<script>alert('注册成功!)</script>";
}
}
>
朋友们可以⾃⼰动⼿进⾏各种操作和尝试,熟练以后就会对表单操作,数据库的操作有⼀定深⼊的理解,为以后的开发打下良好的基础。
以上就是本⽂的全部内容,希望对⼤家的学习有所帮助,也希望⼤家多多⽀持。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。