시뮬레이션 로그인은 모든 사람에게 친숙하다고 생각합니다. 다음 기사에서는 Python 시뮬레이션 로그인 및 쿠키 유지 방법을 주로 소개하며, 이를 필요로 하는 모든 사람을 위한 특정 참조 가치가 있습니다. 아래를 함께 살펴보세요.
서문
최근 nosec.org의 데이터를 크롤링하던 중 쿠키에 액세스하기 전에 로그인을 시뮬레이션해야 한다는 것을 알았습니다. 중요: nosec.org의 로그인 페이지 양식에는 login_token 필드가 있는데, 이는 로그인 페이지를 방문할 때마다 자동으로 생성되며 사용자 이름 및 비밀번호와 같이 서버에 게시됩니다.
몇 가지 조사 결과, 웹사이트 로그인 인터페이스에 직접 액세스할 때 서버의 응답 헤더에 다음과 같은 Set-Cookie 필드가 있다는 사실을 발견했습니다.
_nosec_session=ZTlHNmxuZXE4R0s1UXpsVUxGRTNPblNBWFd2TXU4TU9aNWVJM2lyLzNFY0pLeUdNMDY1cmZqanpkc0ppaGtjU i9kTGdWenBrNXJKenNqbnN2YUxucE1DRW5UMHNTR1RxWDZPeGlLazllTmY1czVpYWplazJXdWkvZS9wUHJpc1Jya3ZzcmNVMytPR it2T1dEcGx4bHNDTTVzSmVTb0xhSjRycE03QUl5RXE5Z2tZWG1mTHFBWGx1QW52QjBURi8rLS1acE8yeVRtMFRZR1JWdExneStwdmpRPT0 %3D--a6ccd9a12a8af5c8b5fb6625c24bb4db0398c503; path=/; HttpOnly
그리고 다음과 같은 형식입니다. 페이지 양식에 authenticate_token이 입력되어 있으며 내용은 다음과 같습니다.
<input type="hidden" name="authenticity_token" value="cGdhqVxDMRndpKbpvIV66wfEQlGf4Rz6UtXqsf79brEvFveHw2rCc6uz3euFEyUlpuA0azt5uNhnmrUiCaAyUg==" />
이전에는 _nosec_session의 값을 백엔드 로직에 따라 분석하고 복호화한 후 다양한 xx 기법을 사용하여 값을 얻었습니다. 인증 토큰을 입력한 다음 사용자 이름과 비밀번호만 게시하면 됩니다. 마침내 정말 바보 같은 사람이라는 것을 알게 되었습니다. ! 늘 뒷생각의 문제만 생각하고 최근에는 잘 걷지도 못해요. 따라서 페이지에서 직접 생성된 authenticate_token 값을 가져온 다음 POST를 따르세요.
요청 라이브러리의 Session()
메소드를 사용하는 것이 초기에 cookielib를 직접 사용하는 것보다 훨씬 편리합니다.
코드
클래스 XXX의 로그인 메소드는 로그인을 시뮬레이션하는 데 사용되므로 이 부분의 로그인 코드를 게시하겠습니다.
class XXX: def login(self): r = self.s.get('https://nosec.org/users/sign_in') html = r.text p1 = re.compile(r'city_token" value="(.*?)"') res = re.search(p1,html) authenticity_token = str(res.group(1)) print 'authenticity_token:',authenticity_token # print 'cookies',self.s.cookies # print s.cookies data = { 'authenticity_token':authenticity_token, 'user[login]':'xxxxx', 'user[password]':'xxxxx' } r = self.s.post('https://nosec.org/users/sign_in',data=data) # print r.headers # print r.request.headers # print self.s.cookies print '[*] OK!' return True
로그인 방법을 호출한 후 다음번에 self.s.get()
을 사용하여 직접 웹페이지를 요청할 때 쿠키가 포함됩니다.
이전에도 한 번 아이디어에 속았고 오타(https는 http로 썼다)에 속아서 한참을 미쳐가다가 이 "BUG"를 발견했습니다. " = =, 그래서 개선을 위해 코드에 감사해야 합니다. 버그 제거 효율은 2333입니다!
요약
위 내용은 Python에서 로그인을 시뮬레이션하고 쿠키를 유지하는 방법에 대한 자세한 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

2 시간 이내에 Python의 기본 프로그래밍 개념과 기술을 배울 수 있습니다. 1. 변수 및 데이터 유형을 배우기, 2. 마스터 제어 흐름 (조건부 명세서 및 루프), 3. 기능의 정의 및 사용을 이해하십시오. 4. 간단한 예제 및 코드 스 니펫을 통해 Python 프로그래밍을 신속하게 시작하십시오.

Python은 웹 개발, 데이터 과학, 기계 학습, 자동화 및 스크립팅 분야에서 널리 사용됩니다. 1) 웹 개발에서 Django 및 Flask 프레임 워크는 개발 프로세스를 단순화합니다. 2) 데이터 과학 및 기계 학습 분야에서 Numpy, Pandas, Scikit-Learn 및 Tensorflow 라이브러리는 강력한 지원을 제공합니다. 3) 자동화 및 스크립팅 측면에서 Python은 자동화 된 테스트 및 시스템 관리와 같은 작업에 적합합니다.

2 시간 이내에 파이썬의 기본 사항을 배울 수 있습니다. 1. 변수 및 데이터 유형을 배우십시오. 이를 통해 간단한 파이썬 프로그램 작성을 시작하는 데 도움이됩니다.

10 시간 이내에 컴퓨터 초보자 프로그래밍 기본 사항을 가르치는 방법은 무엇입니까? 컴퓨터 초보자에게 프로그래밍 지식을 가르치는 데 10 시간 밖에 걸리지 않는다면 무엇을 가르치기로 선택 하시겠습니까?

Fiddlerevery Where를 사용할 때 Man-in-the-Middle Reading에 Fiddlereverywhere를 사용할 때 감지되는 방법 ...

Python 3.6에 피클 파일로드 3.6 환경 보고서 오류 : modulenotfounderror : nomodulename ...

경치 좋은 스팟 댓글 분석에서 Jieba Word 세분화 문제를 해결하는 방법은 무엇입니까? 경치가 좋은 스팟 댓글 및 분석을 수행 할 때 종종 Jieba Word 세분화 도구를 사용하여 텍스트를 처리합니다 ...

정규 표현식을 사용하여 첫 번째 닫힌 태그와 정지와 일치하는 방법은 무엇입니까? HTML 또는 기타 마크 업 언어를 다룰 때는 정규 표현식이 종종 필요합니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

에디트플러스 중국어 크랙 버전
작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

WebStorm Mac 버전
유용한 JavaScript 개발 도구

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기
