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

44 lines
869 B
Ruby
Raw Normal View History

2010-06-06 03:48:25 +00:00
##
# 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: 9212 $
require 'rubygems'
require 'pathname'
require 'hpricot'
require 'uri'
class CrawlerLink < BaseParser
2013-09-30 13:47:53 -05:00
def parse(request,result)
2010-06-06 03:48:25 +00:00
2013-09-30 13:47:53 -05:00
if !result['Content-Type'].include? "text/html"
return
end
2010-06-06 03:48:25 +00:00
2013-09-30 13:47:53 -05:00
doc = Hpricot(result.body.to_s)
doc.search('link').each do |link|
2010-06-06 03:48:25 +00:00
2013-09-30 13:47:53 -05:00
hr = link.attributes['href']
2010-06-06 03:48:25 +00:00
2013-09-30 13:47:53 -05:00
if hr and !hr.match(/^(\#|javascript\:)/)
begin
hreq = urltohash('GET',hr,request['uri'],nil)
2010-06-06 03:48:25 +00:00
2013-09-30 13:47:53 -05:00
insertnewpath(hreq)
2010-06-06 03:48:25 +00:00
2013-09-30 13:47:53 -05:00
rescue URI::InvalidURIError
#puts "Parse error"
#puts "Error: #{link[0]}"
end
end
end
end
2010-06-06 03:48:25 +00:00
end