nmap学习之用户名和密码爆破NSE实战(三)

–引用常用API
local brute = require “brute”
local creds = require “creds”
local nmap = require “nmap”
local shortport = require “shortport”
local stdnse = require “stdnse”
local string = require “string”
–nse 描述信息
description = [[
Performs brute force password auditing against FTP servers.

Based on old ftp-brute.nse script by Diman Todorov, Vlatko Kosturjak and Ron Bowes.
]]
–作者信息
author = “Aleksandar Nikolic”

–许可协议
license = “Same as Nmap–See http://nmap.org/book/man-legal.html

–NSE脚本分类

categories = {“intrusive”, “brute”}

–扫描的端口和协议

portrule = shortport.port_or_service(21, “ftp”)

–Driver 对象定义

Driver = {

–new 方法定义,用于实例化Driver对象

new = function(self, host, port)
local o = {}
setmetatable(o, self)
self.__index = self
o.host = host
o.port = port
return o
end,

–connect 方法定义

connect = function( self )
self.socket = nmap.new_socket()
local status, err = self.socket:connect(self.host, self.port)
self.socket:set_timeout(arg_timeout)
if(not(status)) then
return false, brute.Error:new( “Couldn’t connect to host: ” .. err )
end
return true
end,
–login方法定义
login = function (self, user, pass)
local status, err
local res = “”

status, err = self.socket:send(“USER ” .. user .. “\r\n”)
if(not(status)) then
return false, brute.Error:new(“Couldn’t send login: ” .. err)
end

status, err = self.socket:send(“PASS ” .. pass .. “\n\n”)
if(not(status)) then
return false, brute.Error:new(“Couldn’t send login: ” .. err)
end

– Create a buffer and receive the first line
local buffer = stdnse.make_buffer(self.socket, “\r?\n”)
local line = buffer()

– Loop over the lines
while(line)do
stdnse.print_debug(“Received: %s”, line)
if(string.match(line, “^230”)) then
stdnse.print_debug(1, “ftp-brute: Successful login: %s/%s”, user, pass)
return true, brute.Account:new( user, pass, creds.State.VALID)
elseif(string.match(line, “^530”)) then
return false, brute.Error:new( “Incorrect password” )
elseif(string.match(line, “^220”)) then
elseif(string.match(line, “^331”)) then
else
stdnse.print_debug(1, “ftp-brute: WARNING: Unhandled response: %s”, line)
local err = brute.Error:new(“Unhandled response”)
err:setRetry(true)
return false, err
end

line = buffer()
end

return false, brute.Error:new(“Login didn’t return a proper response”)
end,

–disconnect 方法定义

disconnect = function( self )
self.socket:close()
return true
end

}

–action 回调函数定义,需要返回result 扫描结果

–通过new方法,实例化Driver对象
action = function( host, port )
local status, result
local engine = brute.Engine:new(Driver, host, port)
engine.options.script_name = SCRIPT_NAME
status, result = engine:start()
return result
end

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值