Files
metasploit-gs/data/msfcrawler/basic.rb
T

44 lines
936 B
Ruby
Raw Normal View History

2010-05-03 17:13:09 +00:00
##
# $Id$
##
##
# This file is part of the Metasploit Framework and may be subject to
# redistribution and commercial restrictions. Please see the Metasploit
# Framework web site for more information on licensing and terms of use.
# http://metasploit.com/framework/
##
# $Revision$
2010-01-26 04:21:07 +00:00
require 'rubygems'
2010-02-06 05:16:29 +00:00
require 'pathname'
2014-07-17 00:14:07 +02:00
require 'nokogiri'
2010-01-26 04:21:07 +00:00
require 'uri'
2010-03-21 00:13:12 +00:00
class CrawlerSimple < BaseParser
2010-01-26 04:21:07 +00:00
2013-09-30 13:47:53 -05:00
def parse(request,result)
2010-05-03 17:13:09 +00:00
2013-09-30 13:47:53 -05:00
if !result['Content-Type'].include? "text/html"
return
end
2010-05-03 17:13:09 +00:00
2014-07-17 00:14:07 +02:00
# doc = Hpricot(result.body.to_s)
doc = Nokogiri::HTML(result.body.to_s)
doc.css('a').each do |anchor_tag|
hr = anchor_tag['href']
if hr && !hr.match(/^(\#|javascript\:)/)
begin
hreq = urltohash('GET', hr, request['uri'], nil)
insertnewpath(hreq)
rescue URI::InvalidURIError
#puts "Parse error"
#puts "Error: #{link[0]}"
end
2013-09-30 13:47:53 -05:00
end
end
end
2010-01-26 04:21:07 +00:00
end