Scrapy使用aspx页面进行身份验证

时间:2013-12-12 08:49:12

标签: python asp.net authentication scrapy

我正在尝试使用aspx页面找到登录网站的最佳方式,然后重定向到该网站内的新页面以开始抓取。我确信刮擦部分正在工作,因为我已经在模拟页面上尝试过,但我之前没有进行过身份验证,而且我发现该网站正在重定向到搜索网址。我唯一能想到的是scrapy正在触发搜索框?

该网站是howdidido.co.uk,我的蜘蛛代码如下:

from scrapy.spider       import BaseSpider
from scrapy.selector     import Selector
from pgcmh.items         import PgcmhItem
from scrapy.http         import Request
from scrapy.http         import FormRequest
from scrapy.selector     import HtmlXPathSelector
from scrapy.contrib.spiders.init import InitSpider

class LoginSpider(BaseSpider):
    name = 'pgcmh'
    allowed_domains     = ["howdidido.co.uk"]
    login_page = 'http://howdidido.co.uk/Widgets.aspx'
    start_urls = ["http://howdidido.co.uk/ClubDetails.aspx?section=55&pagesection=handicaplist&cid=74"]

    def start_requests(self):
        return self.init_request()

    def init_request(self):
        return [Request(url=self.login_page, callback=self.login)]

    def login(self, response):
        return FormRequest.from_response(response, formdata={'username': 'dummyemail', 'password': 'dummypass'}, callback=self.check_login_response)

    def check_login_response(self, response):
        if "Logout" in response.body:
                for url in self.start_urls:
                        yield self.make_requests_from_url(url)
        else:
                self.log("Could not log in...")

    def make_requests_from_url(url):
        sel = Selector(response)
        for tablerow in sel.css('table.basictable tr'):
            item = PgcmhItem()
            item["name"] = tablerow.xpath('td[1]').extract()
            item["handicap"] = tablerow.xpath('td[2]').extract()
            item["exact"] = tablerow.xpath('td[3]').extract()
            item["category"] = tablerow.xpath('td[4]').extract()
            yield item

1 个答案:

答案 0 :(得分:2)

return FormRequest.from_response(response, formdata={'ctl00$WrappedContent$txtUser': 'dummyemail', 'ctl00$WrappedContent$txtPass': 'dummypass'}, callback=self.check_login_response)