当前位置: 首页 > article >正文

【信息安全概论 实验报告5】SQL注入实验

上一篇【信息安全概论 实验报告4】CA证书实验目录实验目的二、实验环境三、实验内容四、实验步骤五、问题回答实验目的1、理解SQL注入的原理2、学习手工注入的过程二、实验环境目标机192.168.1.3工具: C:\实验工具集\01_WEB安全\02_注入技术实验工具三、实验内容1、按照实验实施学习SQL注入的工作原理和过程。2、通过实验猜测数据库中是否有password字段并用手工注入获取该字段的内容。把注入过程记录在下面的实验步骤里。四、实验步骤目标站点【http:// 192.168.1.3:8008】,随便选择一个链接【http://192.168.1.3:8008/onews.asp?id45】。测试链接在链接末尾添加【】。在链接末尾添加【 and 11】在链接末尾添加【and 12】返回页面显示该网站存在注入漏洞在链接末尾添加语句【and exists(select * from admin)】页面正常显示说明存在表名【admin】在连接末尾添加语句【and exists(select admin from admin)】页面显示正常即在表中存在admin列。同样的方法在链接末尾添加【and exists(select password from admin)】页面显示正常说明存在列password。猜测字段的长度在连接末尾输入语句【and (select top 1 len (admin) from admin)1】页面显示正常数字依次加1进行测试如【and (select top 1 len (admin) from admin)5】说明字段长度为5。同样的方法在链接末尾添加连接【and (select top 1 asc(mid(admin,1,1)) from admin)97】可猜解出第一条记录的第一位字符的ASCII码为97对应a同样的方法可以得到admin字段内容为【admin】password字段内容为【bfpms】五、问题回答1. SQL注入攻击的原理是什么SQL注入是指web应用程序对用户输入数据的合法性没有判断或过滤不严攻击者可以在web应用程序中事先定义好的查询语句的结尾上添加额外的SQL语句在管理员不知情的情况下实现非法操作以此来实现欺骗数据库服务器执行非授权的任意查询从而进一步得到相应的数据信息。SQL注入可影响任何使用了SQL数据库的网站或应用程序例如常用的数据库有MySQL、Oracle、SQL Server等等。攻击者利用它便能无需授权地访问你的敏感数据比如用户资料、个人数据、商业机密、知识产权等等。SQL注入是一种最古老、最流行、也最危险的网站漏洞。如何确定SQL注入点注释符号测试尝试输入--或/**/看看是否导致错误或页面改变。单引号测试输入看是否产生错误或页面改变。逻辑运算符测试尝试使用ANDOR以及NOT等运算符看看是否能改变查询结果。数据库名称、表名称、列名称检测使用UNION SELECT来查询数据库名称、表名称、列名称等。盲注入测试通过length()、ascii()等函数进行盲注。时间延迟注入测试使用sleep()或benchmark()等函数来判断注入点是否存在。请注意在实际操作中可能需要结合其他技术如SQLmap工具或手动审计代码来确定和验证SQL注入点。SQL语句select top 1 asc(mid(admin,1,1)) from admin的含义是什么这个SQL语句的含义是查询admin表中的某个字段可能也是admin字段但语句没有明确指出然后对这个字段的每一个记录执行以下操作使用mid(admin, 1, 1)函数获取admin字段的每一个值字符串的第一个字符。使用asc()函数将这个字符转换为其ASCII值。使用select top 1选择转换后的ASCII值中的最小的一个。不过这里有几点需要注意asc()函数不是标准的SQL函数。可能是某些数据库特有的函数或者可能是一个笔误。在标准的SQL中你可以使用CAST(char_expression AS INTEGER)或ASCII(char_expression)在某些数据库中来获取字符的ASCII值。mid()函数也是某些数据库特有的例如在SQL Server中这个函数被称为SUBSTRING()。select top 1是SQL Server的语法用于选择查询结果的前一行。在其他数据库中可能需要使用LIMIT 1例如在MySQL中或FETCH FIRST 1 ROWS ONLY在某些支持ANSI SQL的数据库中。所以如果你正在使用SQL Server并且admin字段是一个字符串字段这个查询可能返回admin字段的第一个字符的ASCII值中的最小值。如果admin字段包含不同的字符开头这将帮助你找到字典顺序上最早的字符的ASCII值。但是如果你正在使用其他数据库你需要调整这个查询以使用相应的函数和语法。4. 如何防范SQL注入攻击防止SQL注入攻击的最有效方法是使用参数化查询或预编译语句。这些方法要求数据库接受参数的值而不是将它们视为SQL代码的一部分。这样可以确保即使输入的数据包含SQL指令也不会被数据库执行。import pymssql # 连接到数据库 conn pymssql.connect(serverhostname, userusername, passwordpassword, databasedbname) cursor conn.cursor() # 用户输入 user_input user OR 11 # 参数化查询 cursor.execute(SELECT * FROM users WHERE username username, usernameuser_input) # 获取结果 results cursor.fetchall()

相关文章:

【信息安全概论 实验报告5】SQL注入实验

上一篇:【信息安全概论 实验报告4】CA证书实验 目录 实验目的 二、实验环境 三、实验内容 四、实验步骤 五、问题回答 实验目的 1、理解SQL注入的原理 2、学习手工注入的过程 二、实验环境 目标机:192.168.1.3 工具: C:\实验工具集\01_WEB安全…...

Seedream 5.0图像生成技术与提示工程

如何提示Seedream 5.0 发布于2026年2月24日 by shridharathi 在某平台上尝试Seedream 5.0 某机构的Seedream系列一直在快速发展。投入大量时间对其进行提示测试,以下是发现的结果。 美学 在深入细节之前,先讨论图像的实际观感。Seedream 5.0能生成真正优…...

NCM文件转换终极指南:3分钟解锁网易云音乐加密音频

NCM文件转换终极指南:3分钟解锁网易云音乐加密音频 【免费下载链接】ncmdump 项目地址: https://gitcode.com/gh_mirrors/ncmd/ncmdump 你是一个文章写手,你负责为开源项目写专业易懂的文章。ncmdump是一款专业的NCM格式解密工具,专门…...

PRoot:无需root权限的Linux环境容器化神器

PRoot:无需root权限的Linux环境容器化神器 【免费下载链接】proot An chroot-like implementation using ptrace. 项目地址: https://gitcode.com/gh_mirrors/pro/proot PRoot是一款革命性的开源工具,能在无需root权限的情况下为普通用户提供类似…...

KubeFed最佳实践:多集群应用部署与管理终极指南

KubeFed最佳实践:多集群应用部署与管理终极指南 【免费下载链接】kubefed Kubernetes Cluster Federation 项目地址: https://gitcode.com/gh_mirrors/ku/kubefed Kubernetes Cluster Federation(KubeFed)是实现多Kubernetes集群统一管…...

用Cursor和MCP构建自动化Agent:从零复现Manus工作流

1. 为什么需要自动化Agent工作流 在当今快节奏的开发环境中,手动完成重复性任务已经成为效率的最大瓶颈。想象一下,每次接到新需求都要手动创建项目目录、初始化环境、编写基础代码、部署到GitHub,这个过程不仅耗时,而且容易出错…...

vxe-table主题定制:CSS变量驱动的企业级UI架构解决方案

vxe-table主题定制:CSS变量驱动的企业级UI架构解决方案 【免费下载链接】vxe-table vxe table 支持 vue2, vue3 的表格解决方案 项目地址: https://gitcode.com/gh_mirrors/vx/vxe-table 在企业级应用开发中,表格组件往往需要与品牌设计系统深度集…...

Qwen-Image-Edit-2511-Unblur-Upscale应用场景:证件照、老照片、合影修复全搞定

Qwen-Image-Edit-2511-Unblur-Upscale应用场景:证件照、老照片、合影修复全搞定 1. 引言:图像修复的痛点与解决方案 你是否遇到过这样的困扰?珍贵的家庭老照片已经泛黄模糊,证件照因为拍摄条件限制显得不够清晰,或者…...

GetQzonehistory终极指南:3大核心技巧让你永久保存QQ空间所有记忆

GetQzonehistory终极指南:3大核心技巧让你永久保存QQ空间所有记忆 【免费下载链接】GetQzonehistory 获取QQ空间发布的历史说说 项目地址: https://gitcode.com/GitHub_Trending/ge/GetQzonehistory 你是否曾担心QQ空间那些珍贵的说说、照片和评论会随着时间…...

Go语言的runtime.SetBlockProfile数据

Go语言作为一门高效、简洁的编程语言,其并发模型一直是开发者关注的焦点。并发编程中难免会遇到协程阻塞的问题,这些阻塞可能由锁竞争、通道操作或系统调用等引起。为了帮助开发者定位和优化这些问题,Go语言提供了runtime.SetBlockProfile这一…...

别只盯着大模型!从西电智能软件大作业出发,聊聊那些被忽视的‘软技能’提升

别只盯着大模型!从西电智能软件大作业出发,聊聊那些被忽视的‘软技能’提升 在技术飞速迭代的今天,计算机专业学生往往将全部精力倾注于算法、框架和编程语言等硬技能,却忽略了那些真正决定职业天花板的关键能力。西电智能软件概论…...

Agent Client Protocol 全景解析斗

1. 核心概念 在 Antigravity 中,技能系统分为两层: Skills (全局库):实际的代码、脚本和指南,存储在系统级目录(如 ~/.gemini/antigravity/skills)。它们是“能力”的本体。 Workflows (项目级)&#xff1a…...

Janus-Pro-7B GPU算力优化:梯度检查点+FlashAttention-2显存节省35%

Janus-Pro-7B GPU算力优化:梯度检查点FlashAttention-2显存节省35% 1. 引言:大模型显存优化的迫切需求 Janus-Pro-7B作为DeepSeek推出的统一多模态模型,在图像理解与生成任务上表现出色,但其7B参数的规模对GPU显存提出了极高要求…...

Safe Stable - 高效安全的Ckpt2Safetensors模型转换工具

Safe & Stable - 高效安全的Ckpt2Safetensors模型转换工具 【免费下载链接】Safe-and-Stable-Ckpt2Safetensors-Conversion-Tool-GUI Convert your Stable Diffusion checkpoints quickly and easily. 项目地址: https://gitcode.com/gh_mirrors/sa/Safe-and-Stable-Ckpt…...

AlienFX Tools技术深度解析:解锁Alienware硬件的底层控制权

AlienFX Tools技术深度解析:解锁Alienware硬件的底层控制权 【免费下载链接】alienfx-tools Alienware systems lights, fans, and power control tools and apps 项目地址: https://gitcode.com/gh_mirrors/al/alienfx-tools 在Alienware用户群体中&#xf…...

代码实例看透位运算符 | ^ ~

要先理解(原码,补码,反码,可以看这个文章):https://blog.csdn.net/2301_80428740/article/details/147284230?spm1011.2415.3001.10575&sharefrommp_manage_link 在C语言中,位运算符是直接…...

程序员相亲指南:软件测试从业者的高光自我介绍术

当“软件测试工程师”遇上“相亲局”,如何用三句话破除“点按钮的”“找bug的”刻板印象?本文从专业视角拆解表达策略,助你展现职业价值与人格魅力。一、困境篇:软件测试相亲的三大认知陷阱1. 致命三连问的杀伤力场景还原&#xf…...

万字拆解 LLM 运行机制:Token、上下文与采样参数捶

springboot自动配置 自动配置了大量组件,配置信息可以在application.properties文件中修改。 当添加了特定的Starter POM后,springboot会根据类路径上的jar包来自动配置bean(比如:springboot发现类路径上的MyBatis相关类&#xff…...

把代码写成诗:那些令人拍案叫绝的变量命名

在软件开发的浩瀚海洋中,变量命名常被视为一种基础技能,但对软件测试从业者而言,它却是一门精妙的艺术。优秀的变量命名不仅能提升代码可读性,更能像诗歌一样,赋予逻辑以韵律和美感。尤其在测试领域,清晰的…...

从代码到灶台:测试思维在厨房的降维打击

作为一名软件测试工程师,我习惯于用边界值分析、异常流覆盖和迭代优化思维拆解系统问题。当这种思维迁移到厨房,一场关于“炒菜算法”的重构悄然开始——V1.0基础版:最小可行菜品(MVP)的诞生就像测试需先建立基础用例,我的厨艺从番…...

终极AWDL管理指南:彻底解决Apple Silicon MacBook Wi-Fi卡顿问题

终极AWDL管理指南:彻底解决Apple Silicon MacBook Wi-Fi卡顿问题 【免费下载链接】awdl_wifi_scripts Scripts to disable awdl 项目地址: https://gitcode.com/gh_mirrors/aw/awdl_wifi_scripts 你是否在使用Apple Silicon(M1/M2/M3)…...

LiuJuan Z-Image详细步骤:自定义权重注入全流程(含键名清洗脚本)

LiuJuan Z-Image详细步骤:自定义权重注入全流程(含键名清洗脚本) 1. 引言:为什么需要自定义权重注入? 如果你用过一些开源的图片生成模型,可能会发现一个头疼的问题:好不容易找到一个别人训练…...

MedGemma Medical Vision Lab镜像免配置:Docker一键运行+Web界面自动加载MedGemma权重

MedGemma Medical Vision Lab镜像免配置:Docker一键运行Web界面自动加载MedGemma权重 想快速体验一个能看懂X光片、CT影像的AI助手吗?今天介绍的MedGemma Medical Vision Lab,让你无需任何复杂的模型下载和配置,就能在本地运行一…...

【Kubernetes】从零构建:生产级备份恢复体系的实战指南

1. 为什么Kubernetes备份如此重要? 想象一下这样的场景:凌晨三点,你的手机突然响起警报,生产环境的Kubernetes集群出现了严重故障。可能是某个工程师的误操作删除了关键命名空间,也可能是底层存储系统发生了不可预知的…...

用STM32和US100超声波模块做个智能小车避障:从硬件连接到代码调试全流程

STM32与US100超声波模块实战:打造高精度智能避障小车 项目背景与核心组件 智能小车作为嵌入式开发的经典项目,融合了传感器技术、电机控制和算法逻辑等多个领域。在这个项目中,我们将使用STM32F103C8T6最小系统板作为主控,搭配US1…...

重塑GitHub Desktop中文体验:让版本控制说你的语言

重塑GitHub Desktop中文体验:让版本控制说你的语言 【免费下载链接】GitHubDesktop2Chinese GithubDesktop语言本地化(汉化)工具 【GitHub桌面客户端中文汉化】 项目地址: https://gitcode.com/gh_mirrors/gi/GitHubDesktop2Chinese 你是否曾面对GitHub Desk…...

Cosmos-Reason1-7B实操手册:视频分段处理与长时序物理状态拼接技术

Cosmos-Reason1-7B实操手册:视频分段处理与长时序物理状态拼接技术 1. 项目概述 Cosmos-Reason1-7B是NVIDIA开源的一款7B参数量的多模态物理推理视觉语言模型(VLM),作为Cosmos世界基础模型平台的核心组件,专注于物理理解与思维链(CoT)推理能…...

实战指南:如何为Windows 7 SP2配置现代硬件支持与安全增强方案

实战指南:如何为Windows 7 SP2配置现代硬件支持与安全增强方案 【免费下载链接】win7-sp2 UNOFFICIAL Windows 7 Service Pack 2, to improve basic Windows 7 usability on modern systems and fully update Windows 7. 项目地址: https://gitcode.com/gh_mirror…...

GPT-OSS-20B开箱即用:通过Ollama快速体验开源大模型的魅力

GPT-OSS-20B开箱即用:通过Ollama快速体验开源大模型的魅力 1. 为什么选择GPT-OSS-20B 在当今AI技术飞速发展的时代,能够本地运行的高质量开源大模型变得越来越重要。GPT-OSS-20B作为OpenAI推出的重量级开放模型,为开发者提供了一个强大而灵…...

GME多模态向量模型效果展示:Qwen2-VL-2B在技术标准文档图解条款检索中应用

GME多模态向量模型效果展示:Qwen2-VL-2B在技术标准文档图解条款检索中应用 1. 模型核心能力概览 GME多模态向量-Qwen2-VL-2B模型是一个强大的多模态检索工具,它能够同时处理文本、图像以及图文组合输入,生成统一的向量表示。这种能力让它在…...