spider 0.4.4 → 0.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/AUTHORS +12 -0
- data/CHANGES +6 -0
- data/LICENSE +21 -0
- data/{README → README.md} +50 -43
- data/lib/spider.rb +12 -29
- data/lib/spider/included_in_memcached.rb +1 -24
- data/lib/spider/next_urls_in_sqs.rb +6 -29
- data/lib/spider/robot_rules.rb +61 -57
- data/lib/spider/spider_instance.rb +8 -31
- data/spider.gemspec +4 -2
- metadata +33 -124
- data/doc/classes/BeStaticServerPages.html +0 -197
- data/doc/classes/BeStaticServerPages.src/M000030.html +0 -19
- data/doc/classes/BeStaticServerPages.src/M000031.html +0 -19
- data/doc/classes/BeStaticServerPages.src/M000032.html +0 -18
- data/doc/classes/BeStaticServerPages.src/M000033.html +0 -18
- data/doc/classes/IncludedInMemcached.html +0 -199
- data/doc/classes/IncludedInMemcached.src/M000015.html +0 -18
- data/doc/classes/IncludedInMemcached.src/M000016.html +0 -18
- data/doc/classes/IncludedInMemcached.src/M000017.html +0 -18
- data/doc/classes/LoopingServlet.html +0 -137
- data/doc/classes/LoopingServlet.src/M000037.html +0 -23
- data/doc/classes/NextUrlsInSQS.html +0 -204
- data/doc/classes/NextUrlsInSQS.src/M000018.html +0 -19
- data/doc/classes/NextUrlsInSQS.src/M000019.html +0 -22
- data/doc/classes/NextUrlsInSQS.src/M000020.html +0 -19
- data/doc/classes/QueryServlet.html +0 -137
- data/doc/classes/QueryServlet.src/M000038.html +0 -19
- data/doc/classes/RobotRules.html +0 -175
- data/doc/classes/RobotRules.src/M000034.html +0 -19
- data/doc/classes/RobotRules.src/M000035.html +0 -67
- data/doc/classes/RobotRules.src/M000036.html +0 -24
- data/doc/classes/Spider.html +0 -170
- data/doc/classes/Spider.src/M000029.html +0 -21
- data/doc/classes/SpiderInstance.html +0 -345
- data/doc/classes/SpiderInstance.src/M000021.html +0 -18
- data/doc/classes/SpiderInstance.src/M000022.html +0 -22
- data/doc/classes/SpiderInstance.src/M000023.html +0 -22
- data/doc/classes/SpiderInstance.src/M000024.html +0 -24
- data/doc/classes/SpiderInstance.src/M000025.html +0 -18
- data/doc/classes/SpiderInstance.src/M000026.html +0 -18
- data/doc/classes/SpiderInstance.src/M000027.html +0 -18
- data/doc/classes/SpiderInstance.src/M000028.html +0 -18
- data/doc/created.rid +0 -1
- data/doc/files/README.html +0 -223
- data/doc/files/lib/spider/included_in_memcached_rb.html +0 -142
- data/doc/files/lib/spider/next_urls_in_sqs_rb.html +0 -144
- data/doc/files/lib/spider/robot_rules_rb.html +0 -114
- data/doc/files/lib/spider/spider_instance_rb.html +0 -117
- data/doc/files/lib/spider_rb.html +0 -254
- data/doc/files/spec/spec_helper_rb.html +0 -196
- data/doc/files/spec/spec_helper_rb.src/M000001.html +0 -20
- data/doc/files/spec/spec_helper_rb.src/M000002.html +0 -26
- data/doc/files/spec/spec_helper_rb.src/M000003.html +0 -24
- data/doc/files/spec/spec_helper_rb.src/M000004.html +0 -18
- data/doc/files/spec/spec_helper_rb.src/M000005.html +0 -23
- data/doc/files/spec/spider/included_in_memcached_spec_rb.html +0 -142
- data/doc/files/spec/spider/included_in_memcached_spec_rb.src/M000006.html +0 -19
- data/doc/files/spec/spider/included_in_memcached_spec_rb.src/M000007.html +0 -18
- data/doc/files/spec/spider/spider_instance_spec_rb.html +0 -210
- data/doc/files/spec/spider/spider_instance_spec_rb.src/M000008.html +0 -21
- data/doc/files/spec/spider/spider_instance_spec_rb.src/M000009.html +0 -19
- data/doc/files/spec/spider/spider_instance_spec_rb.src/M000010.html +0 -19
- data/doc/files/spec/spider/spider_instance_spec_rb.src/M000011.html +0 -27
- data/doc/files/spec/spider/spider_instance_spec_rb.src/M000012.html +0 -26
- data/doc/files/spec/spider/spider_instance_spec_rb.src/M000013.html +0 -27
- data/doc/files/spec/spider_spec_rb.html +0 -127
- data/doc/files/spec/spider_spec_rb.src/M000014.html +0 -23
- data/doc/fr_class_index.html +0 -34
- data/doc/fr_file_index.html +0 -35
- data/doc/fr_method_index.html +0 -64
- data/doc/index.html +0 -24
- data/doc/rdoc-style.css +0 -208
|
@@ -1,114 +0,0 @@
|
|
|
1
|
-
<?xml version="1.0" encoding="iso-8859-1"?>
|
|
2
|
-
<!DOCTYPE html
|
|
3
|
-
PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
|
|
4
|
-
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
|
5
|
-
|
|
6
|
-
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
|
|
7
|
-
<head>
|
|
8
|
-
<title>File: robot_rules.rb</title>
|
|
9
|
-
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
|
|
10
|
-
<meta http-equiv="Content-Script-Type" content="text/javascript" />
|
|
11
|
-
<link rel="stylesheet" href="../../.././rdoc-style.css" type="text/css" media="screen" />
|
|
12
|
-
<script type="text/javascript">
|
|
13
|
-
// <![CDATA[
|
|
14
|
-
|
|
15
|
-
function popupCode( url ) {
|
|
16
|
-
window.open(url, "Code", "resizable=yes,scrollbars=yes,toolbar=no,status=no,height=150,width=400")
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
function toggleCode( id ) {
|
|
20
|
-
if ( document.getElementById )
|
|
21
|
-
elem = document.getElementById( id );
|
|
22
|
-
else if ( document.all )
|
|
23
|
-
elem = eval( "document.all." + id );
|
|
24
|
-
else
|
|
25
|
-
return false;
|
|
26
|
-
|
|
27
|
-
elemStyle = elem.style;
|
|
28
|
-
|
|
29
|
-
if ( elemStyle.display != "block" ) {
|
|
30
|
-
elemStyle.display = "block"
|
|
31
|
-
} else {
|
|
32
|
-
elemStyle.display = "none"
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
return true;
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
// Make codeblocks hidden by default
|
|
39
|
-
document.writeln( "<style type=\"text/css\">div.method-source-code { display: none }</style>" )
|
|
40
|
-
|
|
41
|
-
// ]]>
|
|
42
|
-
</script>
|
|
43
|
-
|
|
44
|
-
</head>
|
|
45
|
-
<body>
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
<div id="fileHeader">
|
|
50
|
-
<h1>robot_rules.rb</h1>
|
|
51
|
-
<table class="header-table">
|
|
52
|
-
<tr class="top-aligned-row">
|
|
53
|
-
<td><strong>Path:</strong></td>
|
|
54
|
-
<td>lib/spider/robot_rules.rb
|
|
55
|
-
</td>
|
|
56
|
-
</tr>
|
|
57
|
-
<tr class="top-aligned-row">
|
|
58
|
-
<td><strong>Last Update:</strong></td>
|
|
59
|
-
<td>Thu May 21 13:19:06 +0000 2009</td>
|
|
60
|
-
</tr>
|
|
61
|
-
</table>
|
|
62
|
-
</div>
|
|
63
|
-
<!-- banner header -->
|
|
64
|
-
|
|
65
|
-
<div id="bodyContent">
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
<div id="contextContent">
|
|
70
|
-
|
|
71
|
-
<div id="description">
|
|
72
|
-
<p>
|
|
73
|
-
Understand robots.txt.
|
|
74
|
-
</p>
|
|
75
|
-
|
|
76
|
-
</div>
|
|
77
|
-
|
|
78
|
-
<div id="requires-list">
|
|
79
|
-
<h3 class="section-bar">Required files</h3>
|
|
80
|
-
|
|
81
|
-
<div class="name-list">
|
|
82
|
-
uri
|
|
83
|
-
</div>
|
|
84
|
-
</div>
|
|
85
|
-
|
|
86
|
-
</div>
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
</div>
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
<!-- if includes -->
|
|
93
|
-
|
|
94
|
-
<div id="section">
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
<!-- if method_list -->
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
</div>
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
<div id="validator-badges">
|
|
110
|
-
<p><small><a href="http://validator.w3.org/check/referer">[Validate]</a></small></p>
|
|
111
|
-
</div>
|
|
112
|
-
|
|
113
|
-
</body>
|
|
114
|
-
</html>
|
|
@@ -1,117 +0,0 @@
|
|
|
1
|
-
<?xml version="1.0" encoding="iso-8859-1"?>
|
|
2
|
-
<!DOCTYPE html
|
|
3
|
-
PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
|
|
4
|
-
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
|
5
|
-
|
|
6
|
-
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
|
|
7
|
-
<head>
|
|
8
|
-
<title>File: spider_instance.rb</title>
|
|
9
|
-
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
|
|
10
|
-
<meta http-equiv="Content-Script-Type" content="text/javascript" />
|
|
11
|
-
<link rel="stylesheet" href="../../.././rdoc-style.css" type="text/css" media="screen" />
|
|
12
|
-
<script type="text/javascript">
|
|
13
|
-
// <![CDATA[
|
|
14
|
-
|
|
15
|
-
function popupCode( url ) {
|
|
16
|
-
window.open(url, "Code", "resizable=yes,scrollbars=yes,toolbar=no,status=no,height=150,width=400")
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
function toggleCode( id ) {
|
|
20
|
-
if ( document.getElementById )
|
|
21
|
-
elem = document.getElementById( id );
|
|
22
|
-
else if ( document.all )
|
|
23
|
-
elem = eval( "document.all." + id );
|
|
24
|
-
else
|
|
25
|
-
return false;
|
|
26
|
-
|
|
27
|
-
elemStyle = elem.style;
|
|
28
|
-
|
|
29
|
-
if ( elemStyle.display != "block" ) {
|
|
30
|
-
elemStyle.display = "block"
|
|
31
|
-
} else {
|
|
32
|
-
elemStyle.display = "none"
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
return true;
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
// Make codeblocks hidden by default
|
|
39
|
-
document.writeln( "<style type=\"text/css\">div.method-source-code { display: none }</style>" )
|
|
40
|
-
|
|
41
|
-
// ]]>
|
|
42
|
-
</script>
|
|
43
|
-
|
|
44
|
-
</head>
|
|
45
|
-
<body>
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
<div id="fileHeader">
|
|
50
|
-
<h1>spider_instance.rb</h1>
|
|
51
|
-
<table class="header-table">
|
|
52
|
-
<tr class="top-aligned-row">
|
|
53
|
-
<td><strong>Path:</strong></td>
|
|
54
|
-
<td>lib/spider/spider_instance.rb
|
|
55
|
-
</td>
|
|
56
|
-
</tr>
|
|
57
|
-
<tr class="top-aligned-row">
|
|
58
|
-
<td><strong>Last Update:</strong></td>
|
|
59
|
-
<td>Thu May 21 15:38:44 +0000 2009</td>
|
|
60
|
-
</tr>
|
|
61
|
-
</table>
|
|
62
|
-
</div>
|
|
63
|
-
<!-- banner header -->
|
|
64
|
-
|
|
65
|
-
<div id="bodyContent">
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
<div id="contextContent">
|
|
70
|
-
|
|
71
|
-
<div id="description">
|
|
72
|
-
<p>
|
|
73
|
-
Specialized spidering rules.
|
|
74
|
-
</p>
|
|
75
|
-
|
|
76
|
-
</div>
|
|
77
|
-
|
|
78
|
-
<div id="requires-list">
|
|
79
|
-
<h3 class="section-bar">Required files</h3>
|
|
80
|
-
|
|
81
|
-
<div class="name-list">
|
|
82
|
-
open-uri
|
|
83
|
-
uri
|
|
84
|
-
net/http
|
|
85
|
-
net/https
|
|
86
|
-
</div>
|
|
87
|
-
</div>
|
|
88
|
-
|
|
89
|
-
</div>
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
</div>
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
<!-- if includes -->
|
|
96
|
-
|
|
97
|
-
<div id="section">
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
<!-- if method_list -->
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
</div>
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
<div id="validator-badges">
|
|
113
|
-
<p><small><a href="http://validator.w3.org/check/referer">[Validate]</a></small></p>
|
|
114
|
-
</div>
|
|
115
|
-
|
|
116
|
-
</body>
|
|
117
|
-
</html>
|
|
@@ -1,254 +0,0 @@
|
|
|
1
|
-
<?xml version="1.0" encoding="iso-8859-1"?>
|
|
2
|
-
<!DOCTYPE html
|
|
3
|
-
PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
|
|
4
|
-
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
|
5
|
-
|
|
6
|
-
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
|
|
7
|
-
<head>
|
|
8
|
-
<title>File: spider.rb</title>
|
|
9
|
-
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
|
|
10
|
-
<meta http-equiv="Content-Script-Type" content="text/javascript" />
|
|
11
|
-
<link rel="stylesheet" href="../.././rdoc-style.css" type="text/css" media="screen" />
|
|
12
|
-
<script type="text/javascript">
|
|
13
|
-
// <![CDATA[
|
|
14
|
-
|
|
15
|
-
function popupCode( url ) {
|
|
16
|
-
window.open(url, "Code", "resizable=yes,scrollbars=yes,toolbar=no,status=no,height=150,width=400")
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
function toggleCode( id ) {
|
|
20
|
-
if ( document.getElementById )
|
|
21
|
-
elem = document.getElementById( id );
|
|
22
|
-
else if ( document.all )
|
|
23
|
-
elem = eval( "document.all." + id );
|
|
24
|
-
else
|
|
25
|
-
return false;
|
|
26
|
-
|
|
27
|
-
elemStyle = elem.style;
|
|
28
|
-
|
|
29
|
-
if ( elemStyle.display != "block" ) {
|
|
30
|
-
elemStyle.display = "block"
|
|
31
|
-
} else {
|
|
32
|
-
elemStyle.display = "none"
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
return true;
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
// Make codeblocks hidden by default
|
|
39
|
-
document.writeln( "<style type=\"text/css\">div.method-source-code { display: none }</style>" )
|
|
40
|
-
|
|
41
|
-
// ]]>
|
|
42
|
-
</script>
|
|
43
|
-
|
|
44
|
-
</head>
|
|
45
|
-
<body>
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
<div id="fileHeader">
|
|
50
|
-
<h1>spider.rb</h1>
|
|
51
|
-
<table class="header-table">
|
|
52
|
-
<tr class="top-aligned-row">
|
|
53
|
-
<td><strong>Path:</strong></td>
|
|
54
|
-
<td>lib/spider.rb
|
|
55
|
-
</td>
|
|
56
|
-
</tr>
|
|
57
|
-
<tr class="top-aligned-row">
|
|
58
|
-
<td><strong>Last Update:</strong></td>
|
|
59
|
-
<td>Thu May 21 13:19:06 +0000 2009</td>
|
|
60
|
-
</tr>
|
|
61
|
-
</table>
|
|
62
|
-
</div>
|
|
63
|
-
<!-- banner header -->
|
|
64
|
-
|
|
65
|
-
<div id="bodyContent">
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
<div id="contextContent">
|
|
70
|
-
|
|
71
|
-
<div id="description">
|
|
72
|
-
<p>
|
|
73
|
-
Copyright 2007-2008 Mike Burns & John Nagro
|
|
74
|
-
</p>
|
|
75
|
-
<p>
|
|
76
|
-
<a href="../../classes/Spider.html">Spider</a>, a Web spidering library for
|
|
77
|
-
Ruby. It handles the robots.txt, scraping, collecting, and looping so that
|
|
78
|
-
you can just handle the data.
|
|
79
|
-
</p>
|
|
80
|
-
<h2>Examples</h2>
|
|
81
|
-
<h3>Crawl the Web, loading each page in turn, until you run out of memory</h3>
|
|
82
|
-
<pre>
|
|
83
|
-
require 'spider'
|
|
84
|
-
Spider.start_at('http://mike-burns.com/') {}
|
|
85
|
-
</pre>
|
|
86
|
-
<h3>To handle erroneous responses</h3>
|
|
87
|
-
<pre>
|
|
88
|
-
require 'spider'
|
|
89
|
-
Spider.start_at('http://mike-burns.com/') do |s|
|
|
90
|
-
s.on :failure do |a_url, resp, prior_url|
|
|
91
|
-
puts "URL failed: #{a_url}"
|
|
92
|
-
puts " linked from #{prior_url}"
|
|
93
|
-
end
|
|
94
|
-
end
|
|
95
|
-
</pre>
|
|
96
|
-
<h3>Or handle successful responses</h3>
|
|
97
|
-
<pre>
|
|
98
|
-
require 'spider'
|
|
99
|
-
Spider.start_at('http://mike-burns.com/') do |s|
|
|
100
|
-
s.on :success do |a_url, resp, prior_url|
|
|
101
|
-
puts "#{a_url}: #{resp.code}"
|
|
102
|
-
puts resp.body
|
|
103
|
-
puts
|
|
104
|
-
end
|
|
105
|
-
end
|
|
106
|
-
</pre>
|
|
107
|
-
<h3>Limit to just one domain</h3>
|
|
108
|
-
<pre>
|
|
109
|
-
require 'spider'
|
|
110
|
-
Spider.start_at('http://mike-burns.com/') do |s|
|
|
111
|
-
s.add_url_check do |a_url|
|
|
112
|
-
a_url =~ %r{^http://mike-burns.com.*}
|
|
113
|
-
end
|
|
114
|
-
end
|
|
115
|
-
</pre>
|
|
116
|
-
<h3>Pass headers to some requests</h3>
|
|
117
|
-
<pre>
|
|
118
|
-
require 'spider'
|
|
119
|
-
Spider.start_at('http://mike-burns.com/') do |s|
|
|
120
|
-
s.setup do |a_url|
|
|
121
|
-
if a_url =~ %r{^http://.*wikipedia.*}
|
|
122
|
-
headers['User-Agent'] = "Mozilla/5.0 (compatible; Googlebot/2.1; +http://www.google.com/bot.html)"
|
|
123
|
-
end
|
|
124
|
-
end
|
|
125
|
-
end
|
|
126
|
-
</pre>
|
|
127
|
-
<h3>Use memcached to track cycles</h3>
|
|
128
|
-
<pre>
|
|
129
|
-
require 'spider'
|
|
130
|
-
require 'spider/included_in_memcached'
|
|
131
|
-
SERVERS = ['10.0.10.2:11211','10.0.10.3:11211','10.0.10.4:11211']
|
|
132
|
-
Spider.start_at('http://mike-burns.com/') do |s|
|
|
133
|
-
s.check_already_seen_with IncludedInMemcached.new(SERVERS)
|
|
134
|
-
end
|
|
135
|
-
</pre>
|
|
136
|
-
<h3>Track cycles with a custom object</h3>
|
|
137
|
-
<pre>
|
|
138
|
-
require 'spider'
|
|
139
|
-
class ExpireLinks < Hash
|
|
140
|
-
def <<(v)
|
|
141
|
-
self[v] = Time.now
|
|
142
|
-
end
|
|
143
|
-
def include?(v)
|
|
144
|
-
self[v].kind_of?(Time) && (self[v] + 86400) >= Time.now
|
|
145
|
-
end
|
|
146
|
-
end
|
|
147
|
-
|
|
148
|
-
Spider.start_at('http://mike-burns.com/') do |s|
|
|
149
|
-
s.check_already_seen_with ExpireLinks.new
|
|
150
|
-
end
|
|
151
|
-
</pre>
|
|
152
|
-
<h3>Store nodes to visit with Amazon SQS</h3>
|
|
153
|
-
<pre>
|
|
154
|
-
require 'spider'
|
|
155
|
-
require 'spider/next_urls_in_sqs'
|
|
156
|
-
Spider.start_at('http://mike-burns.com') do |s|
|
|
157
|
-
s.store_next_urls_with NextUrlsInSQS.new(AWS_ACCESS_KEY, AWS_SECRET_ACCESS_KEY)
|
|
158
|
-
end
|
|
159
|
-
</pre>
|
|
160
|
-
<h4>Store nodes to visit with a custom object</h4>
|
|
161
|
-
<pre>
|
|
162
|
-
require 'spider'
|
|
163
|
-
class MyArray < Array
|
|
164
|
-
def pop
|
|
165
|
-
super
|
|
166
|
-
end
|
|
167
|
-
|
|
168
|
-
def push(a_msg)
|
|
169
|
-
super(a_msg)
|
|
170
|
-
end
|
|
171
|
-
end
|
|
172
|
-
|
|
173
|
-
Spider.start_at('http://mike-burns.com') do |s|
|
|
174
|
-
s.store_next_urls_with MyArray.new
|
|
175
|
-
end
|
|
176
|
-
</pre>
|
|
177
|
-
<h3>Create a URL graph</h3>
|
|
178
|
-
<pre>
|
|
179
|
-
require 'spider'
|
|
180
|
-
nodes = {}
|
|
181
|
-
Spider.start_at('http://mike-burns.com/') do |s|
|
|
182
|
-
s.add_url_check {|a_url| a_url =~ %r{^http://mike-burns.com.*} }
|
|
183
|
-
|
|
184
|
-
s.on(:every) do |a_url, resp, prior_url|
|
|
185
|
-
nodes[prior_url] ||= []
|
|
186
|
-
nodes[prior_url] << a_url
|
|
187
|
-
end
|
|
188
|
-
end
|
|
189
|
-
</pre>
|
|
190
|
-
<h3>Use a proxy</h3>
|
|
191
|
-
<pre>
|
|
192
|
-
require 'net/http_configuration'
|
|
193
|
-
require 'spider'
|
|
194
|
-
http_conf = Net::HTTP::Configuration.new(:proxy_host => '7proxies.org',
|
|
195
|
-
:proxy_port => 8881)
|
|
196
|
-
http_conf.apply do
|
|
197
|
-
Spider.start_at('http://img.4chan.org/b/') do |s|
|
|
198
|
-
s.on(:success) do |a_url, resp, prior_url|
|
|
199
|
-
File.open(a_url.gsub('/',':'),'w') do |f|
|
|
200
|
-
f.write(resp.body)
|
|
201
|
-
end
|
|
202
|
-
end
|
|
203
|
-
end
|
|
204
|
-
end
|
|
205
|
-
</pre>
|
|
206
|
-
<h2>Author</h2>
|
|
207
|
-
<p>
|
|
208
|
-
John Nagro john.nagro@gmail.com
|
|
209
|
-
</p>
|
|
210
|
-
<p>
|
|
211
|
-
Mike Burns <a href="http://mike-burns.com">mike-burns.com</a>
|
|
212
|
-
mike@mike-burns.com (original author)
|
|
213
|
-
</p>
|
|
214
|
-
<p>
|
|
215
|
-
Many thanks to: Matt Horan Henri Cook Sander van der Vliet John Buckley
|
|
216
|
-
Brian Campbell
|
|
217
|
-
</p>
|
|
218
|
-
<p>
|
|
219
|
-
With `robot_rules’ from James Edward Gray II via <a
|
|
220
|
-
href="http://blade.nagaokaut.ac.jp/cgi-bin/scat.rb/ruby/ruby-talk/177589">blade.nagaokaut.ac.jp/cgi-bin/scat.rb/ruby/ruby-talk/177589</a>
|
|
221
|
-
</p>
|
|
222
|
-
|
|
223
|
-
</div>
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
</div>
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
</div>
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
<!-- if includes -->
|
|
233
|
-
|
|
234
|
-
<div id="section">
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
<!-- if method_list -->
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
</div>
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
<div id="validator-badges">
|
|
250
|
-
<p><small><a href="http://validator.w3.org/check/referer">[Validate]</a></small></p>
|
|
251
|
-
</div>
|
|
252
|
-
|
|
253
|
-
</body>
|
|
254
|
-
</html>
|