私はウェブサイトASP.NET Webformを掻き取ろうとしています。ソースページを見ると、ページが読み込まれるたびにフォームがサーバーからVarsSessionIDを受け取ることがわかります。 続行ボタンをクリックすると、フォームはAJAX要求をASMX Webserivceに送信します。 Webサービスは、検索結果を表示する新しいURLにリダイレクトを返します。示すようにAjaxでASMXウェブサービスへのリクエストを送信しました
私は、AjaxのPOSTリクエストを提出のポイントに私のscrapyスパイダーを実装している:
import scrapy
from scrapy.http import *
from scrapy.selector import Selector
import json
from scrapy.utils.response import open_in_browser
class TestSpider(scrapy.Spider):
name = "test"
allowed_domains = ['customer2.videcom.com']
start_urls = ['http://customer2.videcom.com/med-
view/VARS/Public/CustomerPanels/requirements.aspx?country=ng&lang=en']
def parse(self, response):
form_data = {
'VarsSessionID': '',
'__VIEWSTATE': '/wEPDwULLTE4MTk4NDM5NjEPZBYCAgMPZBYCAgMPFgIeB1Zpc2libGVoZGSNuC4VK36MoPTmce49gcH1j2nxAPDYsLXii0G/syddwQ=='}
yield FormRequest.from_response(response,
formid='frmChangePage',
formdata=form_data,
method='POST',
callback=self.after_parse,
url='http://customer2.videcom.com/med-view/VARS/Public/CustomerPanels/requirements.aspx?country=ng&lang=en',
)
def after_parse(self, response):
print "====RESPONSE==="
print response.headers
print "=========="
print response.request.headers
print "=========="
VarsSessionID = Selector(response=response).xpath("//*[@id='VarsSessionID']/@value").extract()[0]
viewstate = Selector(response=response).xpath("//*[@id='__VIEWSTATE']/@value").extract()[0]
print "VarsSessionID: " + VarsSessionID
print "__VIEWSTATE: " + viewstate
url = "http://customer2.videcom.com/med-view/VARS/Public/WebServices/AvailabilityWS.asmx/GetFlightAvailability?VarsSessionID="+VarsSessionID
payload = {
"FormData":
{
'Origin': ['LOS'],
'VarsSessionID': VarsSessionID,
'Destination': ['ABV'],
'DepartureDate': ['05-May-2017'],
'ReturnDate': '',
'Adults': '1',
'Children': '0',
'SmallChildren': '0',
"Seniors": '0',
"Students": '0',
"Infants": '0',
"Youths": '0',
"Teachers": '0',
"SeatedInfants": '0',
"EVoucher": '',
"recaptcha": 'SHOW',
"SearchUser": 'PUBLIC',
"SearchSource": "requirements"
}, "IsMMBChangeFlightMode": 'false'
}
headers = {
'Accept': 'application/json, text/javascript, */*',
'Accept-Encoding': 'gzip, deflate, br',
'accept-language': 'en_US',
'Connection': 'keep-alive',
'content-type': 'application/json',
'Cookie': {'VarsSessionID':''},
'User-Agent': "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_3) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/57.0.2987.133 Safari/537.36"
}
yield Request(url,
callback=self.after_search,
method='POST',
body=json.dumps(payload),
headers=headers)
def after_search(self, response):
print "========SEARCH HEADERS========"
print response.headers
print response.request.headers
open_in_browser(response)
を私はクッキーの確認するためにChromeデベロッパーツールを使用して、ヘッダー(リクエストとレスポンス)を検討し、その他のヘッダーの詳細。私は、以下に示すようにInternal Server Error 500
を得続ける上でコードを実行するには
:
2017-05-02 11:52:47 [scrapy.downloadermiddlewares.cookies] DEBUG:
Sending cookies to: <POST http://customer2.videcom.com/med-view/VARS/Public/WebServices/AvailabilityWS.asmx/GetFlightAvailability?VarsSessionID=3d2048c4-2af5-4065-999f-8df6f162737b>
Cookie: ASP.NET_SessionId=v2kipt3kr2elvkat5buyajhs
2017-05-02 11:52:49 [scrapy.downloadermiddlewares.retry] DEBUG:
Retrying <POST http://customer2.videcom.com/med-view/VARS/Public/WebServices/AvailabilityWS.asmx/GetFlightAvailability?VarsSessionID=3d2048c4-2af5-4065-999f-8df6f162737b> (failed 1 times): 500
Internal Server Error
2017-05-02 11:52:49 [scrapy.downloadermiddlewares.cookies] DEBUG:
Sending cookies to: <POST http://customer2.videcom.com/med-view/VARS/Public/WebServices/AvailabilityWS.asmx/GetFlightAvailability?
VarsSessionID=3d2048c4-2af5-4065-999f-8df6f162737b>
Cookie: ASP.NET_SessionId=v2kipt3kr2elvkat5buyajhs
2017-05-02 11:52:52 [scrapy.downloadermiddlewares.retry] DEBUG:
Retrying <POST http://customer2.videcom.com/med-view/VARS/Public/WebServices/AvailabilityWS.asmx/GetFlightAvailability?
VarsSessionID=3d2048c4-2af5-4065-999f-8df6f162737b> (failed 2 times):
500 Internal Server Error
2017-05-02 11:52:52 [scrapy.downloadermiddlewares.cookies] DEBUG:
Sending cookies to: <POST http://customer2.videcom.com/med-view/VARS/Public/WebServices/AvailabilityWS.asmx/GetFlightAvailability?
VarsSessionID=3d2048c4-2af5-4065-999f-8df6f162737b>
Cookie: ASP.NET_SessionId=v2kipt3kr2elvkat5buyajhs
2017-05-02 11:52:54 [scrapy.downloadermiddlewares.retry] DEBUG: Gave up retrying <POST http://customer2.videcom.com/med-view/VARS/Public/WebServices/AvailabilityWS.asmx/GetFlightAvailability?
VarsSessionID=3d2048c4-2af5-4065-999f-8df6f162737b> (failed 3 times):
500 Internal Server Error
2017-05-02 11:52:54 [scrapy.core.engine] DEBUG: Crawled (500) <POST
http://customer2.videcom.com/med-view/VARS/Public/WebServices/AvailabilityWS.asmx/GetFlightAvailability?
VarsSessionID=3d2048c4-2af5-4065-999f-8df6f162737b> (referer:
http://customer2.videcom.com/med-view/VARS/Public/CustomerPanels/requirements.aspx?country=ng&lang=en)
2017-05-02 11:52:54 [scrapy.spidermiddlewares.httperror] INFO:
Ignoring response <500 http://customer2.videcom.com/med-view/VARS/Public/WebServices/AvailabilityWS.asmx/GetFlightAvailability?
VarsSessionID=3d2048c4-2af5-4065-999f-8df6f162737b>: HTTP status code is not handled or not allowed
2017-05-02 11:52:54 [scrapy.core.engine] INFO: Closing spider
(finished)
私はデータを投稿し、そのような私は、ブラウザで検索するときのように、検索結果を受信する方法を考え出す助けが必要です。 ありがとう
感謝を。 '__VIEWSTATE'パラメータはページの読み込み時に設定されます。私はハードコードされたものを削除しました。主な問題は、ASMX Webサービスにリクエストを送信する 'after_parse'メソッドの2番目のリクエストです。 '__VIEWSTATE'が使われたり、サーバに送られた場所がなく、私は' 500 Internal Server'エラーを出し続けます –