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!