Redirect to relative path not working without appending '/'
elakamarcus opened this issue · 19 comments
Snippet from lines 652-655. When i use the script to some sites that will send a "Location: /folder/page.html" the script would try http:/folder/page.html. After adding '/' to the URL, if missing, this is resolved.
# Must have protocol
url = "http://#{url}" if url !~ /^http(s)?:\/\//
url = url+"/" if url !~ /\/$/
The culprit, line 262:
base_url = uri.to_s[0, uri.to_s.rindex('/')]
p.s. my apologies if this is fixed in some version i have missed or break some other dependency. I've only tested with a few sites and parameters.
Thanks, I’ll try that. It’s likely the case that I’m not on the right version.
I just did a git clone, and got the same issue. After i added the code as shown above (snipped below also), it worked.
url = url+"/" if url !~ /\/$/
Sorry I maybe wasn't clear. In my initial post, the snippet is code I've already added to my local version of your script.
Your snippet is adding a / to the end of the URL if there isn't one already there, wouldn't that break the majority of the redirects?
/test.php
would become
/test.php/
which is wrong.
At the moment inputting a target url like this: http://www.site.com
and get a redir location tag Location: /welcome/index.php
will result in cewl trying to go http:/welcome/index.php
which is wrong.
what i did solved my immediate hurdle. I did not work on a general case, my expectation is that is what these issues are for.
Just seen this in the code:
702 # The spider doesn't work properly if there isn't a / on the end
703 if url !~ /\/$/
704 # Commented out for Yori
705 # url = "#{url}/"
706 end
I can't remember who Yori is or why he wanted it commented out but looks like I knew it was a bug a while ago.
I've put the line back in in the master branch and updated the version number.
Now to wait for the comment reminding me why the line was commented out.
Thanks for the report.
Yeah, that's the part i noticed and used. But as you say, it only solved this situation outlined in my comment above.
Appreciate you looking into it. Thank you.
I left that 'adding / to the end' commented out, and instead I did the below modification on my local copy. See if it causes less issues:
if res.redirect?
puts "Redirect URL" if @debug
if uri.to_s[-1] == '/'
base_url = uri.to_s[0, uri.to_s.rindex('/')]
else
base_url = uri.to_s
end
new_url = URI.parse(construct_complete_url(base_url, res['Location']))
# If auth is used then a name:pass@ gets added, this messes the tree
# up so easiest to just remove it
current_uri = uri.to_s.gsub(/:\/\/[^:]*:[^@]*@/, "://")
@next_urls.push current_uri => new_url.to_s
elsif res.code == "401"
puts "Authentication required, can't continue on this branch - #{uri}" if @verbose
else
block.call(res)
end
Always adding a trailing / is a problem if the server doesn't handle the URL with the / the same way that without the /. Most of the time this isn't visible because the server will serve the same content for both URLs or do a redirect but when this isn't the case it will break.
For example it isn't possible to crawl a Wikipedia page because adding the trailing / will show a missing article page instead of the correct page:
https://en.wikipedia.org/wiki/Example -> show the correct article page
https://en.wikipedia.org/wiki/Example/ -> show the missing article page
Forcing the trailing / will probably also breaks things if the URL contains query string parameters.
The trailing / should probably only be added to construct a full URL from a relative location to avoid breaking the others cases.
Just ran into the same wikipedia-crawling problem as @SamuelPadou . Trailing slash returns 404.
Same issue here. Trailing slash makes it impossible to crawl Wikipedia
I've just tried the following two commands and both work fine:
CeWL $ ./cewl.rb https://en.wikipedia.org --verbose
CeWL $ ./cewl.rb https://en.wikipedia.org/ --verbose
What problem are you having? Are you definitely crawling the right URL, not one that redirects to different domains before showing content?
Try these examples: #26 (comment)