【网安小白成长之路】2.PHP与MySQL交互

🐮博主syst1m 带你 acquire knowledge!

✨博客首页——syst1m的博客💘

🔞 《网安小白成长之路(我要变成大佬😎!!)》真实小白学习历程,手把手带你一起从入门到入狱🚭

😘《CTF专栏》超级详细的解析,宝宝级教学让你从蹒跚学步到健步如飞🙈

😎《大数据专栏》大数据从0到秃头👽,从分析到决策,无所不能❕

🔥 《python面向对象(人狗大战)》突破百万的阅读量,上过各种各样的官方大型专栏,python面向对象必学之一!🐽

🎉希望本文能够给读者带来帮助,更好地理解这个问题或解决你的困惑🐾

前言

学习PHP与MySQL交互可以更好的为后续的学习做铺垫,可以知道前端与后端之间的一个基本交互原理。

PHP与MySQL交互

文章目录

  • 前言
  • PHP与MySQL交互
    • 一、phpMyAdmin安装
    • 二、PHPMyAdmin的使用
      • 1.打开phpMyAdmin
      • 2.新建表数据库
      • 3.添加内容
    • 三.编写代码
      • 1.HTML代码
      • 2.PHP代码
        • 开头的代码
        • 获取表单内容
        • 连接数据库
        • 判断是否成功连接到数据库
        • 与数据进行匹配
        • 判断返回值是否成功
        • PHP的全部代码
    • 四、测试是否能成功登录
    • 五、总结

一、phpMyAdmin安装

由于现在还没有学习怎么使用指令创建数据,这里我们就用可视化去操作

在小皮面板中点击软件管理找到PHPMyAdmin,安装到网站
在这里插入图片描述

在这里插入图片描述

二、PHPMyAdmin的使用

1.打开phpMyAdmin

打开 Apache 和 MySQL

再用浏览器访问 127.0.0.1/phpMyAdimn4.8.5

在这里插入图片描述

登录数据库,用户名是 root 密码默认是root

2.新建表数据库

点击左侧列表的新建,进行创建数据库,名称随意,我写的test

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

创建完成之后就会在左侧的列表中啦
在这里插入图片描述

3.添加内容

创建一个表,名字随意,我这是test_1

在这里插入图片描述

添加userName和userPasd字段,类型选择 TEXT 可以限制一下长度 点击保存

插入数据,输入你想要的用户名和密码

执行之后点击浏览就会出现刚刚添加的内容

在这里插入图片描述

三.编写代码

1.HTML代码

写一个简单的登录界面,就两个输入框和一个提交按钮

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>用户登录</title></head><body><!-- action 选择提交的php文件  method 提交方式 --><form action="login.php" method="post"><!-- labael 点击跳转到input的输入框 --><label for="userName">用户名:</label><!-- type 文本类型 --><input type="text" id="userName" name="userName" /><br /><label for="userPasd">密码:</label><input type="password" id="userPasd" name="userPasd" /><br /><!-- submit 提交 --><input type="submit" value="提交" /></form></body>
</html>

2.PHP代码

开头的代码
<?php
// 告诉浏览器这是一个html页面,使用uft-8解码
header("Content-type:text/html; Charset=utf-8");
// 开启session
session_start();
获取表单内容

使用$_POST获取传过来的表单内容

// 获取输入的内容
// trim去除掉两侧的空白或者预定字符
$userName = trim($_POST['userName']);
$userPasd = trim($_POST['userPasd']);
// 判断是否填写了信息
if ($userName == '' || $userPasd == '') {// 三秒后刷新到login.htmlheader('refresh:3; url=login.html');echo '用户名或密码不能为空,将在三秒后跳转回登录页面,请重新登录';
}

if里面的判断不要只写一个 = 号,我之前写的时候漏了给我找了好久才发现

连接数据库
// mysqli_connect('数据库地址', '用户名', '密码', '数据库');
$con = mysqli_connect('localhost', 'root', '123456', 'test');
判断是否成功连接到数据库
// 检查连接状态
if (mysqli_connect_errno()) {echo '连接数据库失败' . mysqli_connect_error();// 停止执行后面的代码exit();
}

mysqli_connect_errno() 检查连接状态

mysqli_connect_error() 可以返回连接失败的原因

与数据进行匹配

翻译一下 选择 * 来自 test_1里面的 userName是否等于提交的用户名 和 userPasd是否等于提交的密码

*是通配符就是选择所有,也可以写成 select userName,userPasd 只选择两个

$sql = "select * from test_1 where userName = '$userName' and userPasd = '$userPasd'";
// 返回的结果
$result = mysqli_query($con, $sql);

mysqli_query(数据库,MySQL语句)

判断返回值是否成功

mysqli_num_rows() 查看内容的行数

如果匹配成功的话返回值的行数就有很多数据,匹配失败的话就是空的

if (mysqli_num_rows($result) > 0) {echo "登录成功";
} else {header('refresh:3; url=login.html');echo '用户名或密码错误,将在三秒后跳转回登录页面,请重新登录';
}
PHP的全部代码
<?php
// 告诉浏览器这是一个html页面,使用uft-8解码
header("Content-type:text/html; Charset=utf-8");
// 开启session
session_start();
// 获取输入的内容
// trim去除掉两侧的空白或者预定字符
$userName = trim($_POST['userName']);
$userPasd = trim($_POST['userPasd']);
// 判断是否填写了信息
if ($userName == '' || $userPasd == '') {// 三秒后刷新到login.htmlheader('refresh:3; url=login.html');echo '用户名或密码不能为空,将在三秒后跳转回登录页面,请重新登录';
}
// 连接数据库
//                     数据库地址   用户名    密码     数据库
$con = mysqli_connect('localhost', 'root', '123456', 'test');
// 检查连接状态
if (mysqli_connect_errno()) {echo '连接数据库失败' . mysqli_connect_error();// 停止执行后面的代码exit();
}
// 查看传入的数据是否与数据库中的相同
$sql = "select * from test_1 where userName = '$userName' and userPasd = '$userPasd'";
// 返回的结果
$result = mysqli_query($con, $sql);
if (mysqli_num_rows($result) > 0) {echo "登录成功";
} else {header('refresh:3; url=login.html');echo '用户名或密码错误,将在三秒后跳转回登录页面,请重新登录';
}

四、测试是否能成功登录

输入开始时自己在数据库中添加的用户名和密码

在这里插入图片描述

成功返回的页面

在这里插入图片描述

失败返回的页面

在这里插入图片描述

五、总结

代码量稍稍有些多,但是跟着文章一步一步的来,还是很简单易懂的,大体就是使用php接收前端传来的数据,与数据库连接后使用MySQL语句进行数据匹配。如果你还有什么问题的话,可以私信我哦!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/573016.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JVM(五)——类加载阶段

一、类加载阶段 一个类型从被加载到虚拟机内存中开始&#xff0c;到卸载出内存为止&#xff0c;它的整个生命周期将会经历加载 &#xff08;Loading&#xff09;、验证&#xff08;Verification&#xff09;、准备&#xff08;Preparation&#xff09;、解析&#xff08;Resol…

循环神经网络之序列模型

自回归模型 自回归模型&#xff1a; 只与x 有关 &#xff0c;对自己执行回归隐变量自回归&#xff1a;与X 和过去观测总结h 都有关 案例 %matplotlib inline import torch from torch import nn from d2l import torch as d2lT 1000 # 总共产生1000个点 time torch.aran…

Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单实战案例 之七 简单水彩画效果

Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单实战案例 之七 简单水彩画效果 目录 Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单实战案例 之七 简单水彩画效果 一、简单介绍 二、简单图像浮雕效果实现原理 三、简单水彩画效果案例实现简单步骤 四、注意事项…

【搜索引擎2】实现API方式调用ElasticSearch8接口

1、理解ElasticSearch各名词含义 ElasticSearch对比Mysql Mysql数据库Elastic SearchDatabase7.X版本前有Type&#xff0c;对比数据库中的表&#xff0c;新版取消了TableIndexRowDocumentColumnmapping Elasticsearch是使用Java开发的&#xff0c;8.1版本的ES需要JDK17及以上…

五、Elasticsearch 集成

目录 5.1 Spring Data 框架集成5.1.1 Spring Data 框架介绍5.1.2 Spring Data Elasticsearch 介绍5.1.3 Spring Data Elasticsearch 版本对比5.1.4 集成步骤 5.1 Spring Data 框架集成 5.1.1 Spring Data 框架介绍 Spring Data 是一个用于简化数据库开发的开源框架。其主要目…

springboot+vue考试管理系统

基于springboot和vue的考试管理系统 001 springboot vue前后端分离项目 本文设计了一个基于Springbootvue的前后端分离的在线考试管理系统&#xff0c;采用M&#xff08;model&#xff09;V&#xff08;view&#xff09;C&#xff08;controller&#xff09;三层体系结构&…

[2021]Zookeeper getAcl命令未授权访问漏洞概述与解决

今天在漏洞扫描的时候蹦出来一个zookeeper的漏洞问题&#xff0c;即使是非zookeeper的节点&#xff0c;或者是非集群内部节点&#xff0c;也可以通过nc扫描2181端口&#xff0c;获取极多的zk信息。关于漏洞的详细描述参考apache zookeeper官方概述&#xff1a;CVE-2018-8012: A…

服务器呀服务器,一个虚拟专用服务器的使用教程

目前刚接触服务器这一块的学习&#xff0c;这里记录一下解如何获取自己的第一台虚拟云服务器&#xff0c;给刚入行服务器开发的小伙伴做一个参考。 具体的步骤如下&#xff1a; 一、服务器的注册和获取 1、打开bwg88服务器平台地址&#xff1a;点击进入 https://bwh88.net/a…

自动生成测试位置吸附脚本设计思路

前言 计算一个异质结需要测试对比不同吸附位置之间的能量差异&#xff0c;可以直接手动建模&#xff0c;但是人太懒了&#xff0c;能交给机器的自己就别动手 问题描述 如图上所示是我计算吸附用的衬底&#xff0c;当原子在上面吸附时我考虑了25个&#xff08;可以随便取&…

Xilinx IDDR及ODDR使用和仿真

平台&#xff1a;Vivado2018 官方相关文档&#xff0c;ug471_7Series_SelectIO.pdf 关于IDDR与ODDR Input DDR Resource(IDDR) 外部的数据在时钟的上下沿同时传输数据&#xff0c;我们可以使用IDDR原语将输入的单bit数据转化为2bit的数据输出。同时数据速率变为原来的二分之一…

hadoop 查询hdfs资源信息的方式

hdfs dfsadmin -report &#xff3b;-live&#xff3d;&#xff3b;-dead&#xff3d;&#xff3b;-decommissioning&#xff3d;

OSCP靶场--GLPI

OSCP靶场–GLPI 考点(CVE-2022-35914 php执行函数绕过ssh端口转发jetty xml RCE) 1.nmap扫描(ssh端口转发) ## ┌──(root㉿kali)-[~/Desktop] └─# nmap 192.168.194.242 -sV -sC --min-rate 2500 Starting Nmap 7.92 ( https://nmap.org ) at 2024-03-26 22:22 EDT Nmap…