%5C暴库原理

news/2024/9/8 4:49:23/

  暴库有两个方法,第一个就是利用%5c,另外一个conn.asp暴库。而且这里的暴库是针对access数据库的,而和access搭配的脚本一般是asp,因此出现暴库的一般为asp类型站点。

  ASP是动态服务器页面(Active Server Pages)的英文缩写,后来也称为经典ASP,是微软公司开发的代替CGI脚本程序的一种应用,也是微软公司的第一个服务器侧的脚本引擎,能够动态产生Web页面。ASP可以与Web数据库以及其它程序进行交互,是一种简单、方便的编程工具。ASP的网页文件的格式是.asp,曾用于各种动态网站中。

ASP使用服务器侧的脚本生成页面内容并发给访问者的页面浏览器。ASP解释器读取并执行所有在<%和%>标签之间的脚本代码,并生成内容。这些脚本使用VBScript, JScript和PerlScript编写。@Language指令,<script language="manu" runat="server" />句法或服务器配置都可用于选择语言。
.asp扩展名的Web页面使用ASP技术,一些Web站点为了安全目的,会通过使用更常见的.htm或.html扩展名来伪装他们对脚本语言的选择。.aspx扩展名的页面使用ASP.NET。但是ASP.NET页面也可以包含一些ASP脚本。当介绍ASP.NET时,往往使用经典ASP这一术语来表示原始的ASP技术。

 %5c暴库

 简单点说,就是在打开页面的时候把网页中的/换成%5c,然后提交就可以得到数据库地址了,但并不是所有页面都可以成功,而需要asp?id=这样的地址。因为这样的网址表示页面调用了数据库

首先,要产生 %5c 暴库漏洞,必须要求访问的网页中有数据库调用。其原因是不言而喻的,只有数据库调用的页面,才会“include”包含数据库连接文件“conn.asp”。

另外,要求使用 %5c 解码提交的页面,至少为二级目录,也就是说,必须形如“http://www.abc.com/2/*.asp”或“http://www.abc.com/2/3/*.asp”之类的链接才可以进行 %5c 暴库。而一级目录是无法暴库成功的,类似“http://www.abc.com/*.asp”之类的链接,都无法进行 %5c 暴库。

在暴库时,并不限于将网址链接中的第二个“/”换成“%5c”,事实上,将多级目录之后的“/”更换为“%5c”,暴库的成功率更高。例如,某网站的链接为三级目录“http://www.abc.com/2/3/test”,提交“http://www.abc.com/2%5c3/test.asp”暴库不成功时,提交“http://www.abc.com/2/3%5ctest.asp”反而有可能成功。

之所以会出现二级目录暴库不成功,但三级目录暴库成功的情况,往往是由于网站采用了虚拟目录。在上面的示例中,网站的子目录“2”可能是一个虚拟目录,“2”并不一定在网站根目录“D:\web”之下。虚拟目录“2”的真实物理目录,有可能是任意的分区路径,位于“E:\2”、“H:\2”都是可以的。


"%5c"暴库法,它不是网页本身的漏洞,而是利用了IIS解码方式中的一个特性,如果IIS安全设置不周全,而网页设计者未考虑IIS错误,就会被人利用。  
  为何要用"%5c"?它实际上是"\"的十六进制代码,也就是"\"的另一种表示法。在电脑中,它们是一个东西。(图2)(十六进制转换图)  

但提交"\"和"%5c"却会产生不同的结果,在ie中,我们把下面第一个地址中的"/"换成"\"提交:  
http://219.237.81.46/yddown/view.asp?id=3  

http://219.237.81.46/yddown\view.asp?id=3  

二者的访问结果是一样的。ie会自动把"\"转变成"/",从而访问到同一地址。  
但是,当我们把"/"换成十六进制写法"%5c"时,ie不会对此进行转换。地址中的"%5c"被原样提交了。这是抓包结果:(图3)  

GET /yddown%5cview.asp?id=3 HTTP/1.1  

当IIS收到后解析时,又会将%5c还原成"\"。这样,iis中网址的相对路径就变成/yddown\view.asp。这一点很重要。问题正是从这里开始的。  

在ASP网页中,凡调用数据库时,都会用到一个连接数据库的网页conn.asp,它会创建一个数据库连接对象,定义要调用的数据库路径  
一个典型的conn.asp如下:  

<%  
 dim conn  
 dim dbpath  
 set conn=server.createobject("adodb.connection")  
 DBPath = Server.MapPath("admin/rds_dbd32rfd213fg.mdb")  
 conn.Open "driver={Microsoft Access Driver (*.mdb)};dbq=" & DBPath  
%> 


大家注意第4句:DBPath = Server.MapPath("admin/rds_dbd32rfd213fg.mdb"),Server.MapPath方法的作用是将网站中的相对路径转变成物理上的绝对路径。为何要这样?因为连接数据库时,须指明它的绝对路径。  
(这里可能有人不明白,什么相对路径、绝对路径?IIS为了不让访问者知道真实的实际路径,并且确保网站不因变换地址而影响使用,它采用了一种相对路径来表示目录与文件之间的关系。也就是网址目录只表示从根目录起的相对位置。  

  比如:上面的网站中,网站:http://219.237.81.46的根目录为:"D:\111\"雨点下载目录则在根目录(D:\111)内的"yddown"下,我们网站访问该站时,就是在访问D:\111\yddown\目录,而http://219.237.81.46/yddown/admin/,它只表明了admin与yddown这个目录的相对关系,把这个网站放在e:盘,也一样不改变admin位于yddown目录下的关系。  

  当Server.MapPath方法将相对路径转为真实路径时,它实际是三部分路径加在一起得到真实路径的:网页目前执行时所在的相对路径,也就是从网站物理根目录起的相对路径,比如上面例子中conn.asp处在从根目录起的"/yddown/"下;然后调用的数据库的相对路径是admin/rds_dbd32rfd213fg.mdb,这样就得到从根目录起的完整相对路径:"/yddown/admin/rds_dbd32rfd213fg.mdb"。  

这些都只是相对的路径,如何变为真实路径呢?  
  设置过iis的人都会知道,每一个网站,都必须指定它在硬盘上的物理目录,比如上例中,网站根目录所在的物理目录为:"D:\111",Server.MapPath方法正是通过把"网站根目录的物理地址+完整的相对路径",从而得到真实的物理路径。这样,数据库在硬盘上的物理路径是:d:\111\yddown\admin\rds_dbd32rfd213fg.mdb。  
 在这里,IIS以"\"表示真实路径的目录关系,而以"/"表示虚拟路径,这可能就是IE会自动把我们地址中的"\"转为"/"的原因吧。  

  明白这些,我们再来理解暴库就不难了,当我们提交http://219.237.81.46/yddown%5cview.asp?id=3时,view.asp调用conn.asp后,得到的网页相对路径是这样的:/yddown\ (见上),再加上"admin/rds_dbd32rfd213fg.mdb",就得到"/yddown\"+admin/rds_dbd32rfd213fg.mdb。在iis中,"/"和"\"代表着不同的意义,遇到了"\"时,认为它已到了根目录所在的物理路径,不再往上解析(为何不再往上解析?后面还会分析的),于是网站的完整相对路径变成了 :"admin/rds_dbd32rfd213fg.mdb",再加上根目录的物理路径,得到的真实路径变成:"D:\111\admin\rds_dbd32rfd213fg.mdb",而这个路径是不存在的,数据库连接当然会失败,于是IIS会报错,并给出错误原因:  
Microsoft JET Database Engine 错误 ’80004005’  

’D:\111\admin\rds_dbd32rfd213fg.mdb’不是一个有效的路径。 确定路径名称拼写是否正确,以及是否连接到文件存放的服务器。  

/yddown/conn.asp,行12  
这就是暴库语句的来历。  

  《再谈%5c暴库的利用》一文中说,必须是网址中的第二个才可以成功,第一个不行。我们从理论上来分析一下,看到底有无规律:  
 还以上面网址为例,如果将第一个"/"换成"%5c",得到的网站相对路径变成\yddows/admin/rds_dbd32rfd213fg.mdb,解析到"\"时,认为已到物理目录,不再往前解析。而事实上,它确实也是根目录,所以得到的物理路径为:"D:\111\dydow\admin\rds_dbd32rfd213fg.mdb"  
这个路径是正确的,所以不会出错,当然不会暴出数据库路径。  

 第二个个"/"换成"%5c"的情况,我们上面已作分析,那是不是真的就第二个可以暴出呢,事实上,它只是因为二级网站较为常见,并不是真理。如果这个下载系统是某一个网站中的三级目录,变第三个也是可以的。有时,变第三个成功的可能性更大。也就是说,最右边第一个成功可能性大。 





【参考】

%5C暴库原理

关于%5C暴库大法

暴库实验环境与步骤


http://www.ppmy.cn/news/343817.html

相关文章

美国语言教学5c标准,美国外语教学(一)——5C目标

文/Yanjun 这是参加美国项目以来就一直在“打算”要写的系列文章,结合我的教学经历,结合中文AP (advanced placement,大学预科) 考试,谈谈在这个项目中学到的相关理论和概念。Can do statement 看完这篇文字之后,我能够了解: 1、5C目标分别是哪五个C? 2、沟通的三个模式…

信用评估5C

5C评估法就是通过“5C”系统来分析顾客或客户的信用标准。 内容&#xff1a; 1&#xff0e;品质(Character)&#xff1a;指顾客或客户履约或违约的可能性&#xff0c;是评估顾客信用品质的首要指标&#xff0c;品质是应收账款的回收速度和回收数额的决定因素。因为每一笔信用交…

RC5

1. 背景与历史 RC5是Ron Rivest开发的对称密钥块加密算法。RC5的主要特性是很快&#xff0c;只是用基本的计算机运算&#xff08;加、异或、移位等&#xff09;&#xff0c;轮数可变&#xff0c;密钥位数可变&#xff0c;从而大大增加灵活性。需要不同安全性的应用程序可以相应…

linux实验5C

以下是从Webmin官网下载并安装tar/gzip格式的Webmin的详细过程&#xff1a; 打开https://www.webmin.com/&#xff0c;点击页面上的“Download”链接。 在“Download Webmin”页面中&#xff0c;找到“Tar file”或“Gzip file”下载链接&#xff0c;并选择适合您操作系统的版…

#5C OJ练习五#

1.空心正方形图案 1题目链接 链接 2思路 找规律 线上的地方打印*加空格 其他地方打印空格 3实现 #include<stdio.h> int main() {int n 0;while (scanf("%d", &n) ! EOF){int i 0;for (i 0; i < n; i){int j 0;for (j 0; j < n; j){if (i 0 …

软件测试的5C标准

软件测试5C标准 Correct(准确)&#xff1a;每个组成部分的描述准确&#xff0c;不会引起误解 Clear(清晰)&#xff1a;每个组成部分的描述清晰&#xff0c;易于理解 Concise(简洁)&#xff1a;只包含必不可少的信息&#xff0c;不包括任何多余的内容&#xff1b; Complete(…

%5C爆库

当我们暴库失败的时候不妨试试利用%5c绕过asp的验证 废话少说&#xff0c;看下面的代码&#xff1a; <!--#INCLUDE file"conn.asp" --> <% guest_usertrim(request("guest_user")) guest_passwordtrim(request("guest_password&qu…

C.5

//1、随机产生20个[10 , 50]的正整数存到数组中&#xff0c;并求数组中的所有元素最大值、最小值、平均值以及各元素之和,及第二大值。 /* int a[20] {0}; for (int i 0; i < 20; i ) { a[i] arc4random() % 41 10; printf("%d ", a[i]); } int max 0, min …

5.c

1.完成猜数字游戏。 代码如下&#xff1a; #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <stdlib.h> #include <time.h> int main() {srand((unsigned int)time(NULL));int a ;int guess 0;guess rand() % 100 1;//printf("%d\n&…

商业竞争算法

前言&#xff1a;为什么会想起来写这块呢&#xff1f;可能与我目前所处的地域城市有关系吧&#xff0c;也可能与我见过的公司差异有关。 商业竞争算法 什么是商业竞争算法呢&#xff1f;简言之&#xff1a;商战&#xff0c;能够在竞争中产生优势的&#xff0c;且不易被替代的算…

【java 基础三 】- 正则表达式、枚举、equals等

一 枚举 1.1 定义 Java枚举是一种特殊的数据类型&#xff0c;用于表示有限个预设的值。它在Java语言中是一种类&#xff08;class&#xff09;类型&#xff0c;但又比普通的类类型多了些特殊的约束&#xff0c;这些约束使得枚举类型更加简洁、安全和便捷。枚举类型的名称必须…

华为网络设备查看风扇状态命令

描述&#xff1a;华为网络设备查看风扇状态命令 命令&#xff1a; display device fan

华为网络设备CPU和内存占用率检查命令方法

描述&#xff1a;华为网络设备CPU和内存占用率检查命令方法 方法&#xff1a; display cpu display memory

华为网络设备查看电源状态检查命令

描述&#xff1a;华为网络设备查看风扇状态电源状态检查命令 命令&#xff1a; display device fan

华为网络设备 display 命令

1. 常用命令 信息项 使用命令基本信息 display diagnostic-information设备信息 display device接口信息 display interface版本信息 display ver…

华为网络设备调试命令(日常总结)

上面这些都是很常见的调试命令&#xff0c;适用于华为&#xff0c;给大家做一下分享

华为网络设备配置子接口

int g0/0/0.1 //配置子接口1 ip address 192.168.1.1 24 //配置ip地址 dot1q terminatiion vid11 //子接口允许vlan11通过 arp brodcast enable //开启arp广播 quit //退出 子接口定义建议定义成跟vlan对应的接口&#xff0c;这样方便记录。

华为网络设备图标库

新公司的资料很匮乏&#xff0c;可以说已经到了让我无法理解的地步&#xff0c;各个部分竟然只靠几个人来支撑&#xff0c;组网图也没几个。我打算如果有机会的话重新整理一套资料&#xff0c;这里给出华为设备VISIO图标库和PPT图标库&#xff0c;方便大家绘制各种拓扑图。 ht…

检测华为网络设备的常用命令

现在逐步在进行网络设备的更换&#xff0c;之前多是CISCO的产品&#xff0c;后面更换为以H3C为主&#xff0c;现在则是以华为的网络产品为主&#xff0c;华为的网络产品的确很好&#xff0c;高效稳定、牢固皮实&#xff0c;真是国货之光&#xff01; 网络入门简单&#xff0c;大…

华为网络设备加固各种基线命令配置

本文章记录自己在加固工作中碰到的华为各类设备命令不一致的问题 ssh相关日志相关攻击防范相关 ssh相关 配置用户连续认证失败次数上限 &#xff1a; 华为交换机S5730S系列&#xff1a;[SW]aaa[SW]local-aaa-user wrong-password retry-interval 5 retry-time 5 block-time 5 …