渗透测试入门学习——php与mysql数据库连接、使用session完成简单的用户注册、登录

关于cookie、session和sessionid:

cookie是保存在用户浏览器的令牌,在用户访问网站时,网站可取出用户cookie中存放的内容来识别用户身份,用于会话的sessionid就存放其中

session是用户访问网站时,网站服务器为用户生成的会话对象,存储在网站服务器中,在网站多个页面之间跳转时用来识别用户身份以及前保存用户的各种状态信息,例如登录成功的状态、访问各个页面的权限、某个页面某种功能的权限等等

sessionid 相当于一个会话的身份证,用户访问网站在服务器为用户生成 session的同时会生成一个和它对应 的sessionid ,加密后返回给用户浏览器,保存在浏览器的cookie 中,当用户离开网站,也就是结束会话后再次访问网站时,网站就可取出cookie中存放的sessionid查找到对应session,恢复与用户之间的会话

大致流程:
最终效果:
用户不点击注销主动销毁session便可一直访问登录成功页面:
登陆后可在浏览器控制台用document.cookie查看cookie中保存的sessionid:
校验用户session进行登录(文件名为session.php):
php 复制代码
<?php
    session_start();
    if ($_SESSION["login"] == true) {
        echo "您已经成功登陆<a href='logout.php'>点击注销</a>";
    }
    else {
        $_SESSION["login"] == false;
        die("您无权访问,<a href='login.php'>点击跳转登录页面</a>");
    }
?>
销毁用户session进行登出(文件名为logout.php):
php 复制代码
<?php
    session_destroy();
    header('Location:login.php');
?>
与mysql连接(文件名为connect_mysql.php):
php 复制代码
<?php

    $servername = "localhost";
    $username = "root";
    $password = "root";
    $db_name = "test";
    $table_name = "userinfo";

    // 创建连接
    $con_mysql = mysqli_connect($servername, $username, $password);
    $con_db = mysqli_connect($servername, $username, $password, $db_name);

    // 检测连接数据库是否成功
    if (!$con_mysql) {
        die("连接失败: " . mysqli_connect_error());
    }
    else{
        echo "mysql服务器连接成功</br>";
        if(mysqli_connect($servername, $username, $password, $db_name)){
            echo "数据库$db_name"."已经存在";
        }
        else{
            echo "开始自动创建数据库</br>";
            $mysql_exec = "create database ".$db_name;
            mysqli_query($con_mysql, $mysql_exec);
            echo "数据库创建成功</br>";
            $create_table = "create table if not exists `$table_name`(
                `id` INT UNSIGNED AUTO_INCREMENT,
                `user` VARCHAR(10) NOT NULL,
                `password` VARCHAR(10) NOT NULL,
                PRIMARY KEY ( `id` )
            )ENGINE=InnoDB DEFAULT CHARSET=utf8;";
            $con_db = mysqli_connect($servername, $username, $password, $db_name);
            mysqli_query($con_db, $create_table);
            echo "数据表创建成功</br>";
        }
    }
?>
登录页面(文件名为login.php):
php 复制代码
<?php
    include("connect_mysql.php");
    $username = $_POST['username'];
    $password = $_POST['password'];
    $select = "select user,password from $table_name where user='$username' and password='$password';";
    $reslust = mysqli_query($con_db, $select);


    if(mysqli_num_rows($reslust)){
        session_start();
        $_SESSION['login'] = true;
        $_SESSION['username'] = $username;
        header('Location:welcome.php');
    }
    else{
        session_start();
        $_SESSION['login'] = false;
        if(!(empty($username) && empty($password))){
            $login_msg = "登陆失败";
        }
    }
?>

<html>
<head>
    <meta charset=utf-8>
</head> 
<h1>欢迎访问!请输入账号密码登录</h1> 
<form action="#" method="post" ></br>
    <input type="text" name="username"> </br>
    <input type="password" name="password"> </br>
    <input type="submit"> 
</form>
<a href="signup.php">点击注册</a></br>
<?php echo $login_msg ?>
</html>
登录成功页面(文件名为welcome.php):
php 复制代码
<?php
    include('session.php');
?>

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>登陆成功页面</title>
</head>
<body>
    <h1>欢迎您的到来!</h1>
    <?php echo "当前登录用户:".$_SESSION['username'] ?>
</body>
</html>
注意:

单纯的拼接sql语句存在sql注入漏洞,在网站无回显的情况下可用盲注手法对网站进行渗透测试

网站的警告信息最好不要输出,避免被猜测出业务逻辑

相关推荐
p&f°1 分钟前
PostgreSQL 执行计划控制参数详解
数据库·postgresql·oracle
航Hang*1 分钟前
第3章:复习篇——第1节:创建和管理数据库
开发语言·数据库·笔记·sql·sqlserver
小魏的马仔3 分钟前
【elementui】el-date-picker日期选择框,获取焦点后宽度增加问题调整
前端·vue.js·elementui
铉铉这波能秀4 分钟前
正则表达式从入门到精通(字符串模式匹配)
java·数据库·python·sql·正则表达式·模式匹配·表格处理
sc.溯琛6 分钟前
MySQL 进阶实验:数据库与数据表管理完全指南
数据库·oracle
步步为营DotNet6 分钟前
深度剖析.NET中HttpClient的请求重试机制:可靠性提升与实践优化
开发语言·php·.net
羑悻的小杀马特6 分钟前
LRU Cache:高频访问数据的“智能保鲜舱”与经典淘汰艺术
c++·后端·lru cache·热点数据与冷数据
JarvanMo6 分钟前
想让你的 Flutter UI 更上一层楼吗?
前端
好记忆不如烂笔头abc8 分钟前
oracle迁移到sqlserver的注意点
数据库·oracle·sqlserver
YJlio11 分钟前
ZoomIt 学习笔记(11.11):休息计时器与演讲节奏控制——倒计时、番茄钟与现场掌控力
数据库·笔记·学习