Задать вопрос
@fridary

Возможна ли блокировка POST запросов с localhost на сайт?

Мне нужно запарсить статьи с портала ras.arbitr.ru
На данном ресурсе после нажатия на кнопку поиска отправляется POST запрос на ras.arbitr.ru/Ras/Search с параметрами
{"GroupByCase":false,"Count":25,"Page":1,"DateFrom":"2000-01-01T00:00:00","DateTo":"2030-01-01T23:59:59",
"Sides":[],"Judges":[],"Cases":[],"Text":""}

Ответ получаем в json формате со всеми статьями (по 25 штук на страницу):
{"Result":{"PagesCount":40,"TotalCount":23840237,"NumOnPage":25,"Page":1,"ReturnCount":1000,"Items":[{"Id":"54ec7dd5-10cd-4425-b8c0-46f509eec71f","CaseId":"6ba8cdf0-7df8-4708-8b03-471ce85eb997","RegistrationDate":"18.02.2025","InstanceNumber":"А71-4617/2012"...}


Я написал простенький скрипт на python для парсинга отправки POST запроса:
import requests
import json
payload = {"GroupByCase":False,"Count":25,"Page":1,"DateFrom":"2000-01-01T00:00:00","DateTo":"2030-01-01T23:59:59","Sides":[],"Judges":[],"Cases":[],"Text":""}
r = requests.post("http://ras.arbitr.ru/Ras/Search", data=payload)
print(r.status_code, r.reason)

И ответ от сервера:
(500, 'Internal Server Error')

Тот же самый ответ с другой библиотекой и со всеми заголовками:
data = json.dumps({"GroupByCase":False,"Count":25,"Page":1,"DateFrom":"2000-01-01T00:00:00","DateTo":"2030-01-01T23:59:59","Sides":[],"Judges":[],"Cases":[],"Text":""})

c = pycurl.Curl()
c.setopt(pycurl.URL, 'http://ras.arbitr.ru/Ras/Search')
c.setopt(pycurl.HTTPHEADER, [
	"Accept:application/json, text/javascript, */*",
	"Accept-Encoding:gzip, deflate",
	"Accept-Language:en-US,en;q=0.8,ru;q=0.6",
	"Connection:keep-alive",
	"Content-Length:149",
	"Content-Type:application/json",
	"Cookie:ASP.NET_SessionId=eob3w5vypepmykpcsixfpxyv; __utmt=1; CUID=49784dc2-a97e-4249-8c61-415fe5f6f081:QNsAJT4ya5WN7jeL7jCECg==; __utma=160997822.296078651.1469210605.1469210605.1469257019.2; __utmb=160997822.4.10.1469257019; __utmc=160997822; __utmz=160997822.1469210605.1.1.utmcsr=(direct)|utmccn=(direct)|utmcmd=(none)",
	"Host:ras.arbitr.ru",
	"Origin:http://ras.arbitr.ru",
	"Referer:http://ras.arbitr.ru/",
	"User-Agent:Mozilla/5.0 (Macintosh; Intel Mac OS X 10_10_5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.103 Safari/537.36",
	"X-Requested-With:XMLHttpRequest"
])
c.setopt(pycurl.POST, 1)
c.setopt(pycurl.POSTFIELDS, data)
c.perform()


Пробовал изменять код разными способами, так же вмето библиотеки requests использовать httplib - нет результата.

Подскажите, что может быть не так? Может ли стоять блокировка на ras.arbitr.ru, что отправлять POST запросы можно только с их сайта? Или может мне нужно еще так же определенные headers отправлять?
Спасибо
  • Вопрос задан
  • 597 просмотров
Подписаться 1 Оценить 1 комментарий
Пригласить эксперта
Ответы на вопрос 3
dimonchik2013
@dimonchik2013
non progredi est regredi
1) pycurl
2) fiddler (ну или в Хроме там отладка есть)
Ответ написан
fox_12
@fox_12 Куратор тега Python
Расставляю биты, управляю заряженными частицами
Смотрите что броузер передает в заголовках. И передавайте такой же.
Начиная от юзер-агента, реферера, и до передачи кукисов
Ответ написан
2ord
@2ord
Наверно, дело в cross-origin HTTP request (CORS).
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы