用 PHP和html做一个简单的注册页面

用 PHP和html做一个简单的注册页面

index.html的设计

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <form action="./in.php" method="post" style="width:220px; margin:300px auto;">
        用户名:<input type="text" name="username" id="" >
        <br>
        密&nbsp;&nbsp;&nbsp;码:<input type="password" name="password" id="">
        <br>
        年&nbsp;&nbsp;&nbsp;龄:<input type="number" name="age" id="">
        <br>
        性&nbsp;&nbsp;&nbsp;别:<select name="gender" id="">
            <option value="0">女</option>
            <option value="1">男</option>
        </select>
        <br>
        <input type="submit" name="" id="">
    </form>
</body>
</html>

in.php

php 复制代码
<?php
header('content-type:text/html;charset=utf-8');
$host = "localhost";
$user = "root";
$pass = "";
$db = "mydb";
$mysqli = mysqli_connect($host, $user, $pass, $db);
if (mysqli_connect_errno()) {
    echo "连接失败" . mysqli_connect_error();
}
$mysqli->set_charset("utf8");

//执行读取用户列表
select($mysqli);

//注册
insert($mysqli);

$mysqli->close();

//自定义函数function
function insert($mysqli)
{
    $sql = "INSERT INTO demo(username,password,age,gender)VALUES(?,?,?,?)";
    $mysqli_stmt = $mysqli->prepare($sql);

    $username = $_POST["username"];
    $password = $_POST["password"];
    $age = $_POST["age"];
    $gender = $_POST["gender"];

    //ssii代表四个字符串,sii代表三个字符串
    $mysqli_stmt->bind_param("ssii", $username, $password, $age, $gender);

    if ($mysqli_stmt->execute()) {
        echo "编号".$mysqli_stmt->insert_id."注册成功";
        echo PHP_EOL;
    } else {
        echo "失败" . $mysqli_stmt->errno;
    }
    //释放结果集
    $mysqli_stmt->free_result();
    $mysqli_stmt->close();
};

//自定义函数function
function select($mysqli)
{
    $sql = "SELECT uid,username,password,age,gender FROM demo";
    $mysqli_stmt = $mysqli->prepare($sql);
    $uid=null;
    $username = null;
    $password = null;
    $age = null;
    $gender = null;
    if ($mysqli_stmt->execute()) {
        $mysqli_stmt->bind_result($uid,$username, $password, $age, $gender);
        while ($mysqli_stmt->fetch()) {
            echo "编号" . $uid . "<br>";
            echo "姓名" . $username . "<br>";
            echo "密码" . $password . "<br>";
            echo "年龄" . $age . "<br>";
            $gender = $gender == 1 ? "男" : "女";
            echo "性别" . $gender . "<br>";
        }
    }else{
        echo"查询失败";
    }
    //释放结果集
    $mysqli_stmt->free_result();
    $mysqli_stmt->close();
};

?>

数据库的设计

sql 复制代码
DROP TABLE IF EXISTS `demo`;
CREATE TABLE IF NOT EXISTS `demo` (
  `uid` int NOT NULL AUTO_INCREMENT COMMENT '用户编号',
  `username` varchar(20) COLLATE utf8mb4_bin NOT NULL COMMENT '用户姓名',
  `password` varchar(18) COLLATE utf8mb4_bin NOT NULL COMMENT '用户密码',
  `age` int NOT NULL COMMENT '用户年龄',
  `gender` int NOT NULL COMMENT '用户性别',
  PRIMARY KEY (`uid`)
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin;

效果

相关推荐
兴趣使然_5 小时前
【笔记】使用 html 创建网址快捷方式
笔记·html·js
OKUNP5 小时前
Docker高级管理--容器通信技术与数据持久化
docker·容器·php
hunzi_15 小时前
搭建商城系统
java·uni-app·php
Zachery Pole10 小时前
BootStrap
前端·bootstrap·html
淮北49411 小时前
最简单的实验室资产管理系统,使用Flask,mysql,html(四、知识补充)
mysql·flask·html
多啦C梦a11 小时前
【前端必修】闭包、`this`、`箭头函数`、`bind`、节流,一篇文章全懂!
前端·javascript·html
Canaan28512 小时前
前端开发-标签
html
夏至春来-美美12 小时前
微信获取access_token授权的两种不同情况
微信·php·微信公众平台
爱编程的喵13 小时前
深入理解JavaScript节流函数:从原理到实战应用
前端·javascript·html
果子⌂14 小时前
Docker-构建镜像并实现LNMP架构
mysql·nginx·docker·容器·架构·php