如何解决Cookie 和 sessionId 设置在登录时不起作用
与 urllib3(或与此相关的请求)苦苦挣扎。
这是代码片段:
http = urllib3.PoolManager()
register_url = "https://www.tennisvlaanderen.be/tornooi-inschrijven?tornooiId=67975"
myfields = {}
loginHeadersResponse = {}
print(loginHeadersResponse)
loginHeadersResponse['user-agent'] = 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML,like Gecko) Chrome/87.0.4280.88 Safari/537.36'
jsessionid = '2B6A36F1C1E2CCB4976E1E134B708883'
loginHeadersResponse['Cookie'] = f'GUEST_LANGUAGE_ID=nl_BE,COOKIE_SUPPORT=true,COMPANY_ID=10153,ID=3753745964426e6466386471707849594555504963413d3d,wpcc=dismiss,JSESSIONID={jsessionid},USER_UUID="7StYdBndf8fspjvSCcvhSCWM+g6YAOtnaqcSGBFDyHA=",LFR_SESSION_STATE_27124178=1608979584293'
print(loginHeadersResponse)
myheaders = loginHeadersResponse
r = http.request('GET',register_url,myfields,myheaders)
html_doc = r.data
soup = BeautifulSoup(html_doc,'html.parser')
try:
allReeksen = [aReeks.text.strip() for aReeks in soup.find('div',{'class':'form-section'}).find_all('option')]
except AttributeError as _attErr:
raise NotLoggedInException()
当我手动登录站点并复制此代码中的 jsessionid 时,此方法有效。然后我得到了预期的输出。
现在,如果我也尝试模仿脚本中的登录行为,这就是出现问题并开始表现奇怪的地方。然后它不喜欢我在 POST 请求到登录页面后从服务器返回的 jsessionid。这是我尝试过的一些代码,但不接受 Jsession ID,因为我总是在随后的 GET 请求中将登录页面重定向回 register_url。
loginUrl = "https://www.tennisvlaanderen.be/home?p_p_state=maximized&p_p_mode=view&saveLastPath=0&_58_struts_action=%2Flogin%2Flogin&p_p_id=58&_58_doActionAfterLogin=false"
http = urllib3.PoolManager()
login = '********'
psw = '********'
loginData = {'_58_login':login,'_58_password':psw}
#loginCookieDetails = ['COOKIE_SUPPORT=true',# 'JSESSIONID=76FF1AC80587C5C3ED9C035C5DBC1D45',# 'COMPANY_ID=10153',# 'LFR_SESSION_STATE_27124178=expired'
# ]
myheaders = {'Cookie':','.join(loginCookieDetails)}
r = http.request('POST',loginUrl,fields=loginData,headers=myheaders)
#print(r.status)
#print(r.headers)
#print(http.headers)
#print(r.headers['Set-Cookie'])
#print(r.data)
cookieFromServer = r.headers['Set-Cookie']
loginHeadersResponse = r.headers
stringForSession = 'JSESSIONID'
beginIndex = cookieFromServer.find(stringForSession) + len(stringForSession) + 1 # 1 for equal sign
endIndex = cookieFromServer.find(';',beginIndex)
jsessionid = cookieFromServer[beginIndex:endIndex]
使用这个 jsessionId 不起作用,而从浏览器复制粘贴的那个。我在这里遗漏了任何愚蠢的、明显的东西?
使用请求包中的会话时也是如此。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。