python http 를 통 해 파일 업로드 사고방식 상세 설명

여 기 는 주로 multipart/form-data 라 는 형식의 파일 업 로드 를 해결 합 니 다.기본적으로 현재 http 프로 토 콜 업로드 파일 은 기본적으로 이러한 형식 으로 업 로드 됩 니 다.
사고
일반적인 상황 에서 만약 에 저희 가 한 주소 로 파일 을 업로드 하려 면 로그 인 을 해 야 합 니 다.로그 인 에 성공 한 후에 cookies 를 받 은 다음 에 파일 을 업로드 하 는 요청 에 이 cookies 를 휴대 해 야 합 니 다.
그리고 저 희 는 브 라 우 저 를 통 해 사이트 에 파일 을 업로드 해 야 합 니 다.이 럴 때 저 희 는 브 라 우 저의 개발 자 도구 나 fiddler 를 열 고 가방 을 잡 아 업로드 파일 을 조립 하 는 post 요청 을 해 야 합 니 다.
여러분 은 post 요청 에서 files 매개 변수 로 파일 대상 과 관련 된 매개 변 수 를 받 아들 이 고 data/json 매개 변 수 를 통 해 post 요청 체 의 다른 매개 변 수 를 받 아들 이면 된다 는 원칙 을 파악 하고 있 습 니 다.
2 실현
2.1 사이트 접속
requests.session()대상 을 사용 하여 사이트 에 로그 인 합 니 다.여 기 는 주로 편 의 를 위해 다음 에 이 대상 으로 post 로 파일 을 업로드 하 라 는 요청 을 보 내 면 됩 니 다.요청 체 에 cookies 를 추가 하지 않 아 도 됩 니 다.
로그 인 URL 찾기

찾기 요청 헤더

로그 인 인자 찾기

코드 는 다음 과 같 습 니 다: 

import requests
 
s = requests.session()
 
res1 = s.post(
    url="http://127.0.0.1:5000/login",
    headers={
        'Host': '127.0.0.1:5000',
        'Connection': 'keep-alive',
        'Content-Length': '28',
        'Cache-Control': 'max-age=0',
        'sec-ch-ua': '" Not A;Brand";v="99", "Chromium";v="90", "Google Chrome";v="90"',
        'sec-ch-ua-mobile': '?0',
        'Upgrade-Insecure-Requests': '1',
        'Origin': 'http://127.0.0.1:5000',
        'Content-Type': 'application/x-www-form-urlencoded',
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/90.0.4430.93 Safari/537.36',
        'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9',
        'Sec-Fetch-Site': 'same-origin',
        'Sec-Fetch-Mode': 'navigate',
        'Sec-Fetch-User': '?1',
        'Sec-Fetch-Dest': 'document',
        'Referer': 'http://127.0.0.1:5000/login',
        'Accept-Encoding': 'gzip, deflate, br',
        'Accept-Language': 'zh-CN,zh;q=0.9'
    },
    data={
        "account": "admin",
        "password": "admin"
    }
)
2.2 수 동 으로 파일 을 업로드 하고 http 요청 한 인 자 를 분석 합 니 다.
구 글 브 라 우 저 는 파일 을 업로드 할 때 http 에서 요청 한 인 자 를 볼 수 없 기 때문에 fiddler 를 사용 하여 캡 처 를 진행 합 니 다.

가방 캡 처 상황 은 다음 과 같 습 니 다:

설명:
위의 그림 에서 첫 번 째 빨 간 상자 의 매개 변 수 는 모두 어 지 러 운 코드 입 니 다.여기 가 바로 우리 가 업로드 한 파일 바 이 너 리 형식의 표현 입 니 다.여기 의 데 이 터 는 files 매개 변 수 를 통 해 받 는 것 입 니 다. 
두 번 째 빨 간 상자 에서 name 의 값 은 k 입 니 다.예 를 들 어 cid 는 k 값 이 고 다음 줄 의 값 은 7 은 v 입 니 다.여기 있 는 매개 변 수 는 data 매개 변 수 를 통 해 받 아야 합 니 다.
http 에서 요청 한 raw 형식 입 니 다.웹 Forms 형식의 http 요청 을 볼 수 있 습 니 다.
 나누다
분석 이 끝 난 후 코드 를 볼 수 있 습 니 다.

res2 = s.post(
    url="http://127.0.0.1:5000/upload",
    headers={
        'Host': '127.0.0.1:5000',
        'Connection': 'keep-alive',
        'Content-Length': '28',
        'Cache-Control': 'max-age=0',
        'sec-ch-ua': '" Not A;Brand";v="99", "Chromium";v="90", "Google Chrome";v="90"',
        'sec-ch-ua-mobile': '?0',
        'Upgrade-Insecure-Requests': '1',
        'Origin': 'http://127.0.0.1:5000',
        # 'Content-Type': 'application/x-www-form-urlencoded',
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/90.0.4430.93 Safari/537.36',
        'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9',
        'Sec-Fetch-Site': 'same-origin',
        'Sec-Fetch-Mode': 'navigate',
        'Sec-Fetch-User': '?1',
        'Sec-Fetch-Dest': 'document',
        'Referer': 'http://127.0.0.1:5000/login',
        'Accept-Encoding': 'gzip, deflate, br',
        'Accept-Language': 'zh-CN,zh;q=0.9'
    },
    files={
        "filename_list": open("./test", "rb"),
        "Content-Type": "text/plain",
        "Content-Disposition": "form-data",
        "filename": "test"
    },
 
    data={
        "cid": "7"
    }
)
세 가지 포인트.
3.1 데이터 매개 변수
k 값 과 가방 의 대 비 를 주의 깊 게 보 세 요.


3.2 files 매개 변수
여기 가 중요 합 니 다.여기 가 바로 우리 가 올 린 파일 대상 입 니 다.filename_list 이 매개 변 수 는 파일 파일 대상,filename 을 대표 합 니 다. 이 값 은 일반적으로 업 로드 된 파일 의 이름 입 니 다.(쓰 지 않 아 도 됩 니 다)


3.3 content-type 파라미터
form-data 방식 으로 파일 을 업로드 하면 post 요청 을 조립 할 때 headers 라 는 매개 변수 에 이 값 을 포함 할 수 없습니다.requests 라 이브 러 리 에서 이 요 소 를 추가 합 니 다.
만약 우리 가 똑똑 하 다 면 업로드 에 실패 할 것 입 니 다.여 기 는 매우 중요 합 니 다!!
보시 다시 피 저 는 코드 에서 content-type 이라는 인 자 를 전달 하지 않 았 습 니 다.그러나 스냅 백 은 이 인자 가 있 기 때문에 이 인 자 를 추가 할 수 없습니다.

 실제 스냅 백 에는 이 인자 가 있 습 니 다.

실제 패키지 인증 을 업로드 하면 됩 니 다.브 라 우 저 와 약간 다 르 지만 업로드 에 영향 을 주지 않 습 니 다. 
여기 서 python 이 http 를 통 해 파일 을 업로드 하 는 것 에 관 한 글 은 여기까지 소개 되 었 습 니 다.더 많은 관련 python 이 파일 을 업로드 하 는 내용 은 예전 의 글 을 검색 하거나 아래 의 관련 글 을 계속 찾 아 보 세 요.앞으로 저 희 를 많이 사랑 해 주세요!

좋은 웹페이지 즐겨찾기