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

news2024/11/16 0:19:04

🐮博主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.html
    header('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.html
    header('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.coloradmin.cn/o/1549324.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Jenkins--在Linux上使用Docker安装

一、Jenkins 简介 Jenkins是一个流行的开源自动化服务器&#xff0c;用于持续集成和持续交付&#xff08;CI/CD&#xff09;。Jenkins的核心功能主要包括以下几点&#xff1a; 持续集成&#xff1a;Jenkins可以监控版本控制系统&#xff08;如Git、SVN&#xff09;中的代码变…

Django开发复盘

一、URL 对于一个不会写正则表达式的蒟蒻来说&#xff0c;在urls.py中就只能傻傻的写死名字&#xff0c;但是即便这样&#xff0c;还会有很多相对路径和绝对路径的问题&#xff08;相对ip端口的路径&#xff09;&#xff0c;因为我们网页中涉及到页面跳转&#xff0c;涉及到发送…

【LaTeX】7实现章节跳转

使用 LaTeX 实现章节跳转 写在最前面1. 引入 hyperref 包2. 标记章节3. 引用章节示例代码注意 小技巧总结 &#x1f308;你好呀&#xff01;我是 是Yu欸 &#x1f30c; 2024每日百字篆刻时光&#xff0c;感谢你的陪伴与支持 ~ &#x1f680; 欢迎一起踏上探险之旅&#xff0c;…

江协STM32:点亮第一个LED灯和流水灯

很多单片机都是高电平弱驱动&#xff0c;低电平强驱动&#xff0c;所以这里是低电平有效 点亮一个LED灯 操作STM32的GPIO需要三个操作&#xff1a; 第一个使用RCC开启GPIO的时钟 第二步使用GPIO_Init函数初始化GPIO 第三步使用输出或输入函数控制GPIO 1.使用RCC开启GPIO的时…

使用patchelf解决vscode远程连接不支持低版本glibc的问题

使用patchelf解决vscode远程连接不支持低版本glibc的问题 目录 使用patchelf解决vscode远程连接不支持低版本glibc的问题1. 动态链接库下载2. 用 patchelf 修改 vscode-server 依赖的 glibc 版本 VScode 1.86 版本的 remote 要求 glibc 2.28 及以上&#xff0c;于是在各种旧版本…

python--函数的参数问题

1.函数的参数&#xff1a; 默认值参数&#xff1a;通过定义函数时&#xff0c;将可能调用时不怎么变化的参数&#xff0c;给定默认值&#xff0c;在调用时方便调用 注意&#xff1a;位置参数不能写在默认值参数后边 可变参数&#xff08;不定长参数&#xff09;&#xff1a;在开…

阿里云云服务器资源规格推荐指南

资源规格推荐可以根据您的特定业务场景&#xff0c;为您推荐最合适的计算资源规格以及满足您算力需求的资源规模。本文介绍如何根据物理机规格推荐ECS资源和根据总算力推荐ECS资源。 根据物理机规格推荐ECS资源 IDC上云可以帮助您在将线下IDC服务器搬迁上云前&#xff0c;根据…

《深入Linux内核架构》第3章 内存管理(4)

目录 3.4 初始化内存管理 3.4.1 建立数据结构 3.4.2 特定于体系架构的设置 内核在内存中的布局 初始化步骤 分页机制的初始化 3.4.3 启动期间的内存管理 数据结构 初始化 与内核的接口 停用bootmem分配器 释放初始化数据 3.4 初始化内存管理 包括&#xff1a; 显式…

【数字图像处理matlab系列】数组索引

【数字图像处理matlab系列】数组索引 【先赞后看养成习惯】【求点赞+关注+收藏】 MATLAB 支持大量功能强大的索引方案,这些索引方案不仅简化了数组操作,而且提高了程序的运行效率。 1. 向量索引 维数为1xN的数组称为行向量。行向量中元素的存取是使用一维索引进行的。因此…

STM32收发HEX数据包

在实际应用中&#xff0c;STM32的串口通信都是以数据包格式进行收发&#xff0c;这个数据包一般都包含包头和包尾&#xff0c;表示一个数据包。源代码在文末给出 数据包格式&#xff1a; 固定长度&#xff0c;含包头包尾 可变包长&#xff0c;含包头包尾 问题1&#xff1a;当…

Anaconda虚拟环境的介绍与使用

Anaconda虚拟环境介绍 虚拟环境是一种工具&#xff0c;可以让您在同一台计算机上创建多个独立的Python环境&#xff0c;每个环境可以拥有自己的Python解释器版本、包和依赖项。使用虚拟环境有以下几个优点&#xff1a; 隔离项目环境&#xff1a; 在开发中&#xff0c;不同的项…

使用LangChain LCEL生成RAG应用、使用LangChain TruLens对抗RAG幻觉

# 导入LangChain的库 from langchain import *# 加载数据源 loader WebBaseLoader() doc loader.load("https://xxx.html")# 分割文档对象 splitter RecursiveCharacterTextSplitter(max_length512) docs splitter.split(doc)# 转换文档对象为嵌入&#xff0c;并…

3d放上模型为什么渲染不出来---模大狮模型网

如果在3D软件中放置模型后无法正确渲染出来&#xff0c;可能有几个常见的原因导致这种情况发生&#xff1a; 材质设置问题&#xff1a;确保所放置的模型具有正确的材质和纹理&#xff0c;并且材质设置正确。如果材质设置有误&#xff0c;可能会导致模型无法正确显示。 光照设置…

BaseDao封装JavaWeb的增删改查

目录 什么是BaseDao&#xff1f; 为什么需要BaseDao&#xff1f; BaseDao的实现逻辑 什么是BaseDao&#xff1f; Basedao 是一种基于数据访问对象&#xff08;Data Access Object&#xff09;模式的设计方法。它是一个用于处理数据库操作的基础类&#xff0c;负责封装数据库…

大模型论文阅读:ADAPTIVE BUDGET ALLOCATION FOR PARAMETEREFFICIENT FINE-TUNING

大模型论文阅读:ADAPTIVE BUDGET ALLOCATION FOR PARAMETEREFFICIENT FINE-TUNING 论文链接:https://arxiv.org/pdf/2303.10512v1.pdf 当存在大量下游任务时,微调所有预训练模型的参数变得不可行。因此,为了以参数高效的方式学习预训练权重的增量更新,提出了许多微调方法,…

【Linux】进程状态(R运行状态、S睡眠状态、D磁盘休眠状态、T停止状态、X死亡状态)

目录 01.运行状态 02.睡眠状态 03.磁盘睡眠状态 04.停止状态 05.死亡状态 进程的状态会随着操作系统的调度和外部事件的发生而不断地发生转换。例如&#xff0c;一个新创建的进程经过初始化后会进入就绪态&#xff0c;等待被调度执行&#xff1b;当调度器分配处理器资源给…

AI+云平台|全闪云底座迎战

AI融万物之势席卷而来 人工智能&#xff08;Artificial Intelligence&#xff09;&#xff0c;英文缩写为AI。它是研究、开发用于模拟、延伸和扩展人的智能的理论、方法、技术及应用系统的一门新的技术科学。 行业特点 AI场景中80%以上是小文件&#xff0c;以非结构化数据为…

maya导入导出bvh 自动 脚本

目录 maya打开脚本编辑器 运行打开bvh脚本 maya导出bvh脚本 maya打开脚本编辑器 打开Maya软件,点击右下角 “脚本编辑器” 运行打开bvh脚本<

一款比 K8S 更好用的编排工具——Nomod 单机部署

上下文 最近公司需要调研类似 EMCHub 这样支持算力共享的服务。第一直觉是使用 K8S 或 K3S&#xff0c;作为 CNCF 孵化的顶级项目&#xff0c;同时也是当前云原生生态使用最广的编排系统。但是在学习 EMC Hub 源码过程中&#xff0c;偶然发现它是基于 Nomad 做的集群管理。 相…

如何清理释放群晖客户端缓存?

任正菲说&#xff1a;企业最大的浪费&#xff0c;是经验的浪费&#xff01; 而一个一个的经验&#xff0c;又都来自企业的每一个工作者。 因此当我们在工作过程中遇到一些问题时&#xff0c;我们就应该下意识的把解决问题的经验沉淀下来&#xff0c;从而可以与大家进行分享。…