Daylogs/Unix

cURL 옵션 상세

ohgyun 2014. 2. 22. 00:20


발생일: 2014.02.15

키워드: curl

문제:
curl로 특정 요청을 보낸 후 응답으로 받은 쿠키를 저장하고, 그 쿠키를 재사용해 다음 요청을 보내고 싶다.


curl 매뉴얼을 보니 다 있다. :)

이참에 쓸만한 옵션들을 보기 쉽게 좀 정리했다.



해결책:

요약 정리


# page1.example.com 으로 요청을 보내고, 응답 쿠키를 cookie.txt에 저장한다.

$ curl -c cookie.txt http://page1.example.com


# 저장한 쿠키(cookie.txt)를 헤더에 추가해서, page2.example.com 으로 요청한다.

$ curl -b cookie.txt http://page2.example.com



요청 데이터 관련


-X, —request <command>

     HTTP 메서드를 설정할 수 있다.

     -X GET

     일반적으로는 옵션에 맞는 메서드가 적용돼 요청한다.


-H —header <header>

     헤더를 보낸다.

     -H “Accept: text/plain"

     헤더가 여러 개일 경우, 파라미터를 여러 개 붙인다. 


-d, —data <name=content>

     데이터를 전달한다.

     쿼리 스트링 형태로 인자를 전달한다.

     -data는 --data-ascii 와 동일하다.

     바이너리를 보내려면 —data-binary, URL인코딩된 값을 보내려면 —data-encode를 사용한다.


     요청 헤더의 contentType은 application/x-www-form-urlencoded 로 보낸다.


-f, —form <name=content>

     요청 헤더의 contentType은 multipart/form-data 로 보낸다.

     바이너리 파일의 업로드가 가능하다.

     content 부분에 파일 경로를 넣으려면 @으로 시작하도록 한다.

     -f password=@/etc/passwd


     @ 대신 < 를 사용할 수도 있는데, < 는 파일의 내용을 읽어서 첨부한다.

     

     ; 으로 컨텐트의 타입을 명시할 수도 있다.

     -f “web=@index.html;type=text/html”


     파일 업로드의 경우, 같은 방식으로 파일명을 변경할 수 있다.

     -f “file=@localfile;filename=nameinpost”


—form-string <name=content>

     —form 과 동일하지만,  @와 <, ; 등이 특별한 의미를 갖지 않는다.


-K, —config <config file>

     설정 파일로 요청을 보낸다.



-I, —head

     헤더 요청만 받는다.

     HEAD 메서드로 보내는 것과 동일하다.

     -X로 메서드를 명시하는 경우, 헤더만 출력한다. 


-b, —cookie <name=data>

     서버로 쿠키를 전달한다.

     파라미터는 “name1=value1; name2=value2” 형태로 구성해야 한다.

     요청에 ‘=‘ 기호가 없을 경우, 헤더가 저장된 파일에서 값을 가져오며,

     파일 내용 중에 Set-Cookie: 로 된 부분을 파싱해서 쿠키로 사용한다.

     -L, —location 옵션과 같이 사용할 때 유용하다.


     이 옵션은 쿠키를 인풋으로 전달할 때만 사용한다.

     쿠키를 저장할 목적이라면, -c, —cookie-jar 나 -D, —dump-header 옵션을 사용한다.






응답 데이터 관련


-i, —include

     응답 헤더를 출력한다


-o, —output <file>

     응답을 stdout이 아닌 file로 출력한다.

     여러 문서를 다운로드 받으려고 파일 선택자에 {} 나 []를 사용했다면, # 에 번호를 붙이는 식으로 해당 명을 사용할 수 있다.


     curl http://{one,two}.site.com/file[1-5].html -o "#1_#2”


-O, —remote-output

     응답을 리포트 파일명과 동일하게 저장한다.

     다른 디렉토리에 저장하고자 한다면, 워킹 디렉토리를 해당 디렉토리로 변경해야 한다.



-w, —write-format <format>

     응답에서 포맷에 맞는 데이터를 출력할 수 있다. 

     %{variable_name} 과 같은 식으로 출력할 수 있다.


     content_type, http_code, time_total 등의 정보를 출력할 수 있다.





기타 


-x, —proxy <url:port>

     HTTP 요청을 보낼 때, 프록시를 사용한다.

     

     curl -x http://localhost:8888 http://naver.com


-p, —proxytunnel

     -x 파라미터와 함께 사용되며, HTTP 요청이 아닌 것을 HTTP 요청으로 보낸다.


-s, —slient

     프로그레스나 에러 정보를 보여주지 않는다.


—retry <num>

—retry-delay <seconds>

     요청 실패 시 재시도 한다.


-L, —location

     서버 응답이 3XX로 와서 페이지가 이동된 걸로 판단된 경우,

     해당 페이지로 다시 요청을 보낸다.


-D, —dump-header <file name>

     응답 헤더를 특정 파일에 저장할 수 있다.

     헤더에서 쿠키 등을 저장했다가 다음 요청에 쓰는 용도로 활용할 수 있다. (-b, —cookie 옵션)

     다만, 쿠키를 저장해서 활용하는 용도라면 이것보단 -c, —cookie-jar 옵션이 더 유용하다.


-c, —cookie-jar <filename>

     요청이 완료된 후 쿠키를 모두 저장한다.

     저장한 쿠키는 -b, —cookie 옵션으로 사용할 수 있다.



     




반응형