Это мой код, который работал:
import requests
from bs4 import BeautifulSoup as bs4
cookies = {
'JSESSIONID': '15EA1C17E103E8206BAFFF73FA157231',
}
headers = {
'Pragma': 'no-cache',
'Origin': 'http://www.cubetutor.com',
'Accept-Encoding': 'gzip, deflate',
'Accept-Language': 'en-US,en;q=0.9',
'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_2) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/76.0.3809.132 Safari/537.36',
'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8',
'Accept': '*/*',
'Cache-Control': 'no-cache',
'X-Requested-With': 'XMLHttpRequest',
'Connection': 'keep-alive',
'Referer': 'http://www.cubetutor.com/topcardsbyset/1;jsessionid=15EA1C17E103E8206BAFFF73FA157231',
}
data = {
't:ac': '1',
't:formdata': 'byjWim5rtLJcD8P4BWZe94Mn6II=:H4sIAAAAAAAAAJWOPQ4BQRSAH4lCdBIRPe1oaKiQqEQkywHezj5rZOxM5j1/l3ECcQmFzh0cQKtS2DiARPsV3/edn1DaN6A+d36EIeHhMSLpMQmTJS0coOtCqtCjXpES9MQSjl2lXSBrYhUjkxrEOUQtY0M2aeaCrW8trpVH7fYuQmECFe0yCc5OcUMC1ckad9i2mKXtSILJ0v7BC5TzaPSN/v4Z/PszC04Tc7SNN4bZuOx6STrL1+leBDj4DxyMK0MBAQAA',
'setSelect': '10E',
't:zoneid': 'topCardsZone'
}
response = bs4(requests.post('http://www.cubetutor.com/topcardsbyset.topcardsform', headers=headers, cookies=cookies, data=data).json()['content'], 'lxml')
text = response.text.split("\n")
file = text.pop(0)
link = response.find_all("a")
arr = {file : {}}
for i in range(len(link)):
arr[file][text[i]] = link[i]
print(file)
for i in arr[file]:
print(i," : ", arr[file][i])
Весь материал из text = response.text.split ("\ n") не важен (не закончен и не там, где проблема). Этот верхний код работает нормально, но он требует, чтобы я заходил на сайт, просматривал сетевые запросы / заголовки и каждый раз получал всю эту информацию. Я пытаюсь немного автоматизировать процесс, но во-вторых, я пытаюсь создать свой собственный идентификатор jsession, чтобы мне не приходилось постоянно заходить на сайт, и это выдает ошибку 500 раз. Сначала я подумал, что это может быть из-за того, что идентификатор jsession и заголовки не совпадают, поэтому я изменил его на равные session.headers, как вы можете видеть ниже, но это ничего не исправило. Код на https://github.com/icarus612/spiderPY-magicTG/, если вы хотите посмотреть другие коммиты. Любая помощь будет великолепна.
import requests
from bs4 import BeautifulSoup as soup
data = {
't:ac': '1',
't:formdata': 'byjWim5rtLJcD8P4BWZe94Mn6II=:H4sIAAAAAAAAAJWOPQ4BQRSAH4lCdBIRPe1oaKiQqEQkywHezj5rZOxM5j1/l3ECcQmFzh0cQKtS2DiARPsV3/edn1DaN6A+d36EIeHhMSLpMQmTJS0coOtCqtCjXpES9MQSjl2lXSBrYhUjkxrEOUQtY0M2aeaCrW8trpVH7fYuQmECFe0yCc5OcUMC1ckad9i2mKXtSILJ0v7BC5TzaPSN/v4Z/PszC04Tc7SNN4bZuOx6STrL1+leBDj4DxyMK0MBAQAA',
'setSelect': '10E',
't:zoneid': 'topCardsZone'
}
session = requests.Session()
r = session.get('http://www.cubetutor.com')
cookies = session.cookies.get_dict()
headers = session.headers
headers['Referer'] = f"http://www.cubetutor.com/topcardsbyset/1;jsessionid={cookies['JSESSIONID']}"
headers['Pragma'] = 'no-cache'
headers['Origin'] = 'http://www.cubetutor.com'
headers['X-Requested-With'] = 'XMLHttpRequest'
print(r)
response = session.get('http://www.cubetutor.com/topcardsbyset.topcardsform', headers=headers, data=data, cookies=cookies)
print(response)
#text = response.find_all(class_='compareCubeColumn').text
#link = response.find_all("a")