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

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

index.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
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();
};

?>

数据库的设计

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;

效果
在这里插入图片描述
在这里插入图片描述

  • 10
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个简单的示例代码: HTML 登录页面: ```html <!DOCTYPE html> <html> <head> <title>登录页面</title> </head> <body> <form action="login.php" method="post"> <label for="username">用户名:</label> <input type="text" id="username" name="username" required><br><br> <label for="password">密码:</label> <input type="password" id="password" name="password" required><br><br> <input type="submit" value="登录"> </form> <br> <a href="register.html">没有账号?点击注册</a> </body> </html> ``` HTML 注册页面: ```html <!DOCTYPE html> <html> <head> <title>注册页面</title> </head> <body> <form action="register.php" method="post"> <label for="username">用户名:</label> <input type="text" id="username" name="username" required><br><br> <label for="password">密码:</label> <input type="password" id="password" name="password" required><br><br> <label for="confirm_password">确认密码:</label> <input type="password" id="confirm_password" name="confirm_password" required><br><br> <input type="submit" value="注册"> </form> <br> <a href="login.html">已有账号?点击登录</a> </body> </html> ``` PHP 存储用户密码: login.php 文件: ```php <?php session_start(); // 获取用户提交的用户名密码 $username = $_POST['username']; $password = $_POST['password']; // 假设这里是从数据库中取出用户信息,这里我就直接判断用户名密码了 if ($username == 'admin' && $password == '123456') { // 登录成功,将用户信息保存到 session 中 $_SESSION['username'] = $username; header('Location: index.php'); } else { // 登录失败,跳转回登录页面 header('Location: login.html'); } ?> ``` register.php 文件: ```php <?php session_start(); // 获取用户提交的用户名密码 $username = $_POST['username']; $password = $_POST['password']; $confirm_password = $_POST['confirm_password']; // 假设这里是将用户信息保存到数据库中,这里我就直接判断用户名密码了 if ($password == $confirm_password) { // 注册成功,将用户信息保存到 session 中 $_SESSION['username'] = $username; header('Location: index.php'); } else { // 注册失败,跳转回注册页面 header('Location: register.html'); } ?> ``` 注意:以上代码只是一个简单的示例,实际应用中需要进行更严格的数据校验和安全处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值