목차

Curl

기본옵션

순수하게 컨텐츠만 받기

curl -fsSL "<url>"

인증

curl --user name:password http://www.example.com

name:password 에 특수 문자가 들어갈 경우 홑따옴표로 감싸면 된다.

method

-X GET|POST|PUT|HEAD|… 로 메소드를 지정할 수 있다.

POSTing File

응답 헤더 출력

-D, --dump-header <file> 으로 헤더를 덤프할 수 있다. <file>-로 지정하면 스트림으로 출력한다.

헤더 지정

-H “HeaderKey: HeaderValue” 혹은 --header “HeaderKey: HeaderValue” 형태로 요청 헤더를 지정할 수 있다.

Shell script 등에서 실패시 exit fail

response=$(curl -s -w "%{http_code}" -o /path/to/download.zip http://url.to/target.zip)
if [ "$response" != "200" ]
then
 exit 1
fi

Basic Auth

curl --user myusername:mypassword http://...

json

# --json 은 아래와 동일한 옵션이다.
--data [arg]
--header "Content-Type: application/json"
--header "Accept: application/json"
# 기본 사용법
curl --json '{"tool": "curl"}' https://example.com/
 
# json 파일 지정
curl --json @json.txt https://example.com/
 
# stdin
echo '{"a":"b"}' | curl --json @- https://example.com/
jo name=daniel tool=curl | curl --json @- https://httpbin.org/post | jq

tiemout

retry

OpenSSL 인증서 실패

갑자기 아래와 같은 오류가 발생했는데, 이는 curl이나 운영체제의 문제가 아니라 당시 접속하고 있던 해당 WiFi 망의 라위터가 인증서를 조작한 것으로 보인다.

OpenSSL SSL_connect: SSL_ERROR_SYSCALL in connection to raw.githubusercontent.com:443 

혹은 http_proxy, https_proxy 같은 환경 변수 설정의 proxy 서버에서 인증서를 변조할 수도 있다.

이로인해, curl 뿐만 아니라 웹 브라우저에서도 올바로 접속이 안됐다.

망이나 프록시 서버를 바꿔서 접속하니까 잘 됐다.