JavaWeb | 揭开SQL注入问题的神秘面纱

news2025/1/11 2:45:36

本专栏主要是记录学习完JavaSE后学习JavaWeb部分的一些知识点总结以及遇到的一些问题等,如果刚开始学习Java的小伙伴可以点击下方连接查看专栏
本专栏地址:🔥JDBC
Java入门篇: 🔥Java基础学习篇
Java进阶学习篇(持续更新中):🔑Java进阶学习篇

在这里插入图片描述

文章目录

  • 一、前言
  • 二、模拟SQL注入
    • 1.修改application.properties文件
    • 2.创建数据库
    • 3.运行jar包
    • 4.验证环境
      • 1️⃣浏览器
      • 2️⃣数据库
    • 5.模拟注入
    • 6.揭秘注入
  • 三、结语

一、前言

本文主要是讲解JDBC中的SQL注入问题,也会有模拟注入的实例。同时也会介绍如何使用PreparedStatement来解决这个问题,以此来保证数据库安全性。

本文中所有的资料来源是黑马程序员,大家可以在他们的官方小程序获取资源,本文主要是以个人理解来讲述这个知识点

二、模拟SQL注入

1.修改application.properties文件

在下载完相关资料以后,首先找到 day03-JDBC\资料\2. sql注入演示 中的application.properties 文件,然后修改 其中的用户名和密码(自己数据库的用户名和设置的密码)

2.创建数据库

由于资料包中是新建一个在 test 数据库下的 user 表,所以导入表之前需要先新建test数据库。可以直接创建,也可以在 navicat 中使用下面这条命令来创建

CREATE DATABASE test;

3.运行jar包

这里要特别注意:运行的jar包要和application.properties文件在同一个路径下,如果要移动文件的话一定要将这三个文件一起移动,这样才能保证jar包正常运行

我妈打开PowerShell,可以直接在左下角搜索,为了防止权限不够等问题,所以我点击了“以管理员身份运行”,进入到页面后 要进入jar包所存放的路径(可以用:cd 路径的方法来进入子目录)

在这里插入图片描述
如果能够运行成功的话应该是下面这个页面,是一个简单的spring项目,为了验证是否成功可以在网页上登录网址或者重启navicattest数据库中是否有表格来验证(见下文讲解)
在这里插入图片描述

4.验证环境

1️⃣浏览器

首先打开一个浏览器,在网址栏输入localhost:8080/login.html后看是否有跳转网页,如果打开是一片空白或者报错,那就是搭建环境失败;下图是正确的式样

程序来源:黑马程序员

2️⃣数据库

如果直接刷新的话是没有用的(至少作者本人刷新没有用。。。)所以我们需要重启这个软件,可以关闭navicat再打开,然后就会发现在test数据库下有两张表格:product user
在这里插入图片描述

5.模拟注入

在表格中给出了用户名和密码,也就是说只有用到对应的用户名和密码才能登录成功,否则就登陆失败,但是!随便写一个用户名(不在表中的也行)后只要写一串特殊的字符又能够成功登录上去,这就是SQL注入问题
在这里插入图片描述

我们的密码只要写' or '1' ='1即可登录,下面来验证一下
在这里插入图片描述
在这里插入图片描述
成功登录!

6.揭秘注入

由于我们要判断用户是否输入了正确的用户名和密码,所以我们要从网页上获取用户输入的用户名和密码,再去数据库中查找用户输入的name和pwd,并判断是否在数据库中,所以部分代码如下

由于目前没学到如何从网页捕获用户输入内容,所以代码中就直接定义变量名并赋值来充当接收的数据


	//获取连接
    String url = "jdbc:mysql:///db1?useSSL=false";
    String username = "root";
    String password = "123456";
    Connection c = DriverManager.getConnection(url, username, password);

    // 接收用户输入 用户名和密码
    String name = "fyfgvul8gyu218pyug";
    String pwd = "' or '1' = '1";
    String sql = "select * from tb_user where username = '"+name+"' and password = '"+pwd+"'";
    
    // 获取stmt对象
    Statement stmt = c.createStatement();
    
    // 执行sql
    ResultSet result = stmt.executeQuery(sql);
    
    // 判断登录是否成功
    if(rs.next()){
        System.out.println("登录成功~");
    }else{
        System.out.println("登录失败~");
    }

这里的查询语句是

select * from tb_user where username = '"+name+"' and password = '"+pwd+"';

所以当我们把用户名和密码填进去就变成了

select * from tb_user where username = 'fyfgvul8gyu218pyug' and password = '' or '1' = '1';

这里我们解读一下:password = ''显然不对,也就是0,'1' = '1'恒成立,也就是1,0 or 1是或运算,当所有为0时,结果才为0;所以有一个恒成立的条件的话,结果永远为1,即密码是正确的,能够登陆进去

三、结语

知道了SQL注入的原理,接下来将讲述一种可以防止注入的一种方法:预编译,也就是 PreparedStatement 对象

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

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

相关文章

MyEclipse提示过期,MyEclipse Subscription Expired解决方案

一、错误描述 某一天打开MyEclipse,突然发现出现如下提示框: 1.错误日志 Thank you for choosing MyEclipse Your license expired 1091 days ago. To continue use of MyEclipse please choose "Buy" to purchase a MyEclipse license. I…

离散系统的数字PID控制仿真-3

离散PID控制的封装界面如图1所示,在该界面中可设定PID的三个系数、采样时间及控制输入的上下界。仿真结果如图2所示。图1 离散PID控制的封装界面图2 阶跃响应结果仿真图:离散PID控制的比例、积分和微分三项分别由Simulink模块实现。离散PID控制器仿真图&…

【servlet篇】servlet相关类介绍

目录 servlet对象什么时候被创建? 2.servlet接口中各个方法的作用 3.相关类和接口介绍 GenericServlet ServletConfig ServletContext HttpServlet servlet对象什么时候被创建? 1,通常情况下,tomcat启动时,并没有…

高阶数据结构 位图的介绍

作者:学习同学 专栏:数据结构进阶 作者简介:大二学生 希望能和大家一起进步! 本篇博客简介:简单介绍高阶数据结构位图 位图的介绍bitset的介绍位图的引入位图的概念位图的引用bitset的使用bitset定义方式方式一 默认初…

基于BGP技术和防火墙双机热备技术的校园网设计与实现

规划设计描述网络拓扑设计分为三部分进行设计:主校区网络、 运营商骨干网络、分校区网络。总公司网络设计:划分:教学楼区域、宿舍区域、办公楼区域、行政楼区域,图书馆区域、数据中心。并且设有web服务器。出口设置双机热备技术&a…

人工智能在网络犯罪中的应用:5个最重要的趋势

在当今的数字世界中,网络威胁不断演变。 人工智能的使用虽然在网络犯罪中还不是必须的,但无疑是我们将在未来几年看到的具有重大发展的最有前途的技术之一。 随着 AI 技术的进步,攻击者开始尝试新的、越来越复杂和有效的攻击模式和技术。 …

PCL OcTree(二)——点云压缩

文章目录 一、应用背景二、代码解读1、官方源码2、代码解释与扩展3、完整代码三、参考文献一、应用背景 点云由庞大的数据集组成,这些数据集通过距离、颜色、法线等附加信息来描述空间三维点。此外,点云能以非常高的速率被创建出来,因此需要占用相当大的存储资源,一旦点云…

【信管9.3】项目干系人管理

项目干系人管理干系人,这三个字我们已经很早就见过了,相信你对它一定不会陌生。在我们的教材中,它是和项目沟通管理放在一起的,在同一个章节中讲完了,我们也遵循教材的顺序,将它和沟通放在一起。其实&#…

【计算机网络(考研版)】第一站:计算机网络概述(二)

目录 四、OSI参考模型和TCP/IP模型 1.ISO/0SI参考模型 2.TCP/IP模型 3.OSI/RM参考模型和TCP/IP参考模型的区别和联系 4.五层教学模型 5.数据流动示意图 四、OSI参考模型和TCP/IP模型 前面我们已经讨论了体系结构的基木概念,在具体的实施中有两个重要的网络体系…

Qt扫盲-QNetworkReply理论总结

QNetworkReply理论总结一、概述二、使用1. 读取body内容2. 获取head属性值3. 错误处理一、概述 QNetworkReply类包含了与QNetworkAccessManager发送的请求回来的相关的数据和元数据。与QNetworkRequest类似,它包含一个URL和头部(包括解析的和原始的形式)&#xff0…

Java基础语法——运算符与表达式

目录 Eclipse下载 安装 使用 运算符 键盘录入 Eclipse下载 安装 使用 Eclipse的概述(磨刀不误砍柴工)——是一个IDE(集成开发环境)Eclipse的特点描述(1)免费 (2)纯Java语言编写 (3)免安装 &#xff08…

【自然语言处理】情感分析(二):基于 scikit-learn 的 Naive Bayes 实现

情感分析(二):基于 scikit-learn 的 Naive Bayes 实现在上一篇博客 情感分析(一):基于 NLTK 的 Naive Bayes 实现 中,我们介绍了基于 NLTK 实现朴素贝叶斯分类的方法,本文将基于 sci…

阿里云效git仓库的创建与使用

一、为何选用阿里仓库为什么要让同学们什么阿里云git仓库呢?主要是考虑速度、容量、人数限制、功能等因素。阿里的速度较快。代码库不限,人数不限制。gitee等仓库要求人员在5名以下,不方便实操练习。云效的功能还强大。有阿里做后盾&#xff…

微服务必经之路,企业应用架构蓝图,有状态和无状态组件之分

微服务如火如荼,但很多时候是事倍功半,花了大力气,收获很少。怎样实现一键扩展,负载量自然伸缩,高可用呢? 一般公司都有了企业级的应用,我们通常所说的三层架构,即用户界面或者说前台…

“华为杯”研究生数学建模竞赛2005年-【华为杯】D题:仓库容量有限条件下的随机存贮管理问题(附获奖论文和matlab代码)

赛题描述 工厂生产需定期地定购各种原料,商家销售要成批地购进各种商品。无论是原料或商品,都有一个怎样存贮的问题。存得少了无法满足需求,影响利润;存得太多,存贮费用就高。因此说存贮管理是降低成本、提高经济效益的有效途径和方法。 问题2 以下是来自某个大型超市的…

【Android】开发一个简单时钟应用每天看时间起床

有没有想过,家里闲置不用的旧手机可以当时钟闹钟来用,觉得这个想法可以吧,把闲置手机充分利用起来了呢,接下来给大家讲一下如何实现,功能简单,可以当作编程入门课。 在电脑上,打开我们熟悉的An…

【设计模式】结构型模式·享元模式

学习汇总入口【23种设计模式】学习汇总(数万字讲解体系思维导图) 写作不易,如果您觉得写的不错,欢迎给博主来一波点赞、收藏~让博主更有动力吧! 一.概述 定义:运用共享技术来有效地支持大量细粒度对象的复用。通过共享已经存在的对…

厚积薄发打卡Day115:Debug设计模式<简单工厂、工厂方法、抽象工厂>

厚积薄发打卡Day115&#xff1a;Debug设计模式<简单工厂、工厂方法、抽象工厂> 简单工厂 定义 由一个工厂对象决定创建出哪一种产品类的实例&#xff08;严格意义并不是设计模式&#xff0c;更是一种风格&#xff09; 类型&#xff1a;创建型&#xff0c;但不属于GOF…

PyAutoFEP Tutorial--基于Gromacs

PyAutoFEP 自由能微扰计算–基于Gromacs 简介 注意&#xff1a;以下教程假定读者熟悉分子动力学 (MD) 和自由能微扰 (FEP) 理论。此外&#xff0c;了解 GROMACS 工具、拓扑和输入文件也很有用。整个教程都使用 Linux 命令行。最后&#xff0c;建议用户阅读并参考 PyAutoFEP 手…

17种编程语言+10种排序算法

开源地址 https://gitee.com/lblbc/simple-works/tree/master/sort 覆盖语言&#xff1a;C、C、C#、Java、Kotlin、Dart、Go、JavaScript(JS)、TypeScript(TS)、ArkTS、swift、PHP。 覆盖平台&#xff1a;安卓(Java、Kotlin)、iOS(SwiftUI)、Flutter(Dart)、Window桌面(C#)、前…