Rumah >pembangunan bahagian belakang >Tutorial Python >Bagaimana untuk Mengatasi Ralat HTTP 403 Dilarang Semasa Memuat Turun Data Saham Bersejarah?

Bagaimana untuk Mengatasi Ralat HTTP 403 Dilarang Semasa Memuat Turun Data Saham Bersejarah?

DDD
DDDasal
2024-11-09 07:03:02315semak imbas

How to Overcome HTTP Error 403 Forbidden When Downloading Historic Stock Data?

Ralat HTTP 403: Dilarang Apabila Mencuba Mengambil Data Saham Bersejarah

Isu ini berpunca daripada percubaan memuat turun data stok bersejarah secara automatik menggunakan urllib2 , yang mengakibatkan respons HTTP Ralat 403 Terlarang.

Untuk menangani perkara ini ralat, beberapa penyelesaian telah dicadangkan, termasuk mengubah suai rentetan ejen pengguna dan menerima kuki respons. Walau bagaimanapun, percubaan ini tidak berjaya.

Setelah penyiasatan lanjut, didapati bahawa dengan menambahkan pengepala tambahan pada permintaan, terutamanya pengepala 'Terima', data itu boleh berjaya diambil.

Coretan kod berikut menggambarkan pelaksanaan yang berjaya:

import urllib2,cookielib

site= "http://www.nseindia.com/live_market/dynaContent/live_watch/get_quote/getHistoricalData.jsp?symbol=JPASSOCIAT&fromDate=1-JAN-2012&toDate=1-AUG-2012&datePeriod=unselected&hiddDwnld=true"
hdr = {'User-Agent': 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.11 (KHTML, like Gecko) Chrome/23.0.1271.64 Safari/537.11',
       'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8',
       'Accept-Charset': 'ISO-8859-1,utf-8;q=0.7,*;q=0.3',
       'Accept-Encoding': 'none',
       'Accept-Language': 'en-US,en;q=0.8',
       'Connection': 'keep-alive'}

req = urllib2.Request(site, headers=hdr)

try:
    page = urllib2.urlopen(req)
except urllib2.HTTPError, e:
    print e.fp.read()

content = page.read()
print content

Terutamanya, penambahan hanya Pengepala 'Terima' sudah memadai untuk menyelesaikan ralat.

Atas ialah kandungan terperinci Bagaimana untuk Mengatasi Ralat HTTP 403 Dilarang Semasa Memuat Turun Data Saham Bersejarah?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn