2017-03-29 10 views
3

ローカルのスプラッシュインスタンスでプロキシサーバーを動作させようとしています。私はいくつかの文書を読みましたが、実行可能な例は見つかりませんでした。このhttps://github.com/scrapy-plugins/scrapy-splash/issues/107が原因であると私の注意を喚起されました。私はもはやそのトレースバックを取得していませんが、依然としてプロキシを使用してスプラッシュを使用することはできません。下の新しいエラーメッセージ。誰でも私がこれを解決するのを助けることができれば、事前に感謝します。私の要求のどれもがSplashにそれを通じさえしていません。Scrapy-Splashを使用したプロキシサーバー

def parse_json(self, response): 
    json_data = response.body 
    load = json.loads(json_data.decode('utf-8')) 
    dump = json.dumps(load,sort_keys=True,indent=2) 
    LUA_SOURCE = """ 
    function main(splash) 
     local host = "proxy.crawlera.com" 
     local port = 8010 
     local user = "APIKEY" 
     local password = "" 
     local session_header = "X-Crawlera-Session" 
     local session_id = "create" 

     splash:on_request(function (request) 
      request:set_header("X-Crawlera-UA", "desktop") 
      request:set_header(session_header, session_id) 
      request:set_proxy{host, port, username=user, password=password} 
     end) 

     splash:on_response_headers(function (response) 
      if response.headers[session_header] ~= nil then 
       session_id = response.headers[session_header] 
      end 
     end) 

     splash:go(splash.args.url) 
     return splash:html() 
    end 
    """ 
    for link in load['d']['blogtopics']: 
     link = link['Uri'] 
     yield SplashRequest(link, self.parse_blog, endpoint='execute', args={'wait': 3, 'lua_source': LUA_SOURCE}) 


2017-03-29 09:26:37 [scrapy.core.engine] DEBUG: Crawled (503) <GET http://community.martindale.com/legal-blogs/Practice_Areas/b/corporate__securities_law/archive/2011/08/11/sec-adopts-new-rules-replacing-credit-ratings-as-a-criterion-for-the-use-of-short-form-shelf-registration.aspx via http://localhost:8050/execute> (referer: None) 
+1

このオープンな問題のようです:https://github.com/scrapy-plugins/scrapy-splash/issues/107 –

+0

私のサポートチケットのバグを確認したばかりです。うまくいけばすぐに修正されます。私はスプラッシュを放棄したくありません。 – eusid

+0

@eusid Crawleraはより多くのカスタムスプラッシュコードを必要としていると思います。ここで例を確認できますか?https://doc.scrapinghub.com/crawlera.html#using-crawlera-with-splash? –

答えて

2

問題は、Crawleraミドルウェアによって発生しているようです。 SplashRequestの処理はありません。私のローカルホストにプロキシを経由しようとします。