curl笔记

-a/--append	上传文件时,附加到目标文件 
-A/--user-agent 设置用户代理发送给服务器
-anyauth	可以使用“任何”身份验证方法 
-b/--cookie cookie字符串或文件读取位置      
	--basic	使用HTTP基本验证 
-B/--use-ascii	使用ASCII /文本传输 
-c/--cookie-jar 操作结束后把cookie写入到这个文件中 
-C/--continue-at 断点续转 
-d/--data HTTP POST方式传送数据      
	--data-ascii 以ascii的方式post数据      
	--data-binary 以二进制的方式post数据      
	--negotiate	使用HTTP身份验证      
	--digest	使用数字身份验证      
	--disable-eprt	禁止使用EPRT或LPRT      
	--disable-epsv	禁止使用EPSV 
-D/--dump-header 把header信息写入到该文件中      
	--egd-file 为随机数据(SSL)设置EGD socket路径      
	--tcp-nodelay	使用TCP_NODELAY选项 
-e/--referer	来源网址 
-E/--cert 客户端证书文件和密码 (SSL)      
	--cert-type 证书文件类型 (DER/PEM/ENG) (SSL)      
	--key 私钥文件名 (SSL)      
	--key-type 私钥文件类型 (DER/PEM/ENG) (SSL)      
	--pass 私钥密码 (SSL)      
	--engine 加密引擎使用 (SSL). "--engine list" for list      
	--cacert CA证书 (SSL)      
	--capath CA目录 (made using c_rehash) to verify peer against (SSL)      
	--ciphers SSL密码      
	--compressed	要求返回是压缩的形势 (using deflate or gzip)      
	--connect-timeout 设置最大请求时间      
	--create-dirs	建立本地目录的目录层次结构      
	--crlf	上传是把LF转变成CRLF 
-f/--fail	连接失败时不显示http错误      
	--ftp-create-dirs	如果远程目录不存在,创建远程目录      
	--ftp-method [multicwd/nocwd/singlecwd]	控制CWD的使用      
	--ftp-pasv	使用 PASV/EPSV 代替端口      
	--ftp-skip-pasv-ip	使用PASV的时候,忽略该IP地址      
	--ftp-ssl	尝试用 SSL/TLS 来进行ftp数据传输      
	--ftp-ssl-reqd	要求用 SSL/TLS 来进行ftp数据传输 
-F/--form 模拟http表单提交数据      
	--form-string 模拟http表单提交数据 	
-g/--globoff	禁用网址序列和范围使用{}和[] 
-G/--get	以get的方式来发送数据 
-H/--header 自定义头信息传递给服务器      
	--ignore-content-length	忽略的HTTP头信息的长度 
-i/--include	输出时包括protocol头信息 
-I/--head	只显示请求头信息 
-j/--junk-session-cookies	读取文件进忽略session cookie      
	--interface 使用指定网络接口/地址      
	--krb4 使用指定安全级别的krb4 
-k/--insecure	允许不使用证书到SSL站点 
-K/--config	指定的配置文件读取 
-l/--list-only	列出ftp目录下的文件名称      
	--limit-rate 设置传输速度      
	--local-port	强制使用本地端口号 
-m/--max-time 设置最大传输时间      
	--max-redirs 设置最大读取的目录数      
	--max-filesize 设置最大下载的文件总量 
-M/--manual	显示全手动 
-n/--netrc	从netrc文件中读取用户名和密码      
	--netrc-optional	使用 .netrc 或者 URL来覆盖-n      
	--ntlm	使用 HTTP NTLM 身份验证 
-N/--no-buffer	禁用缓冲输出 
-o/--output	把输出写到该文件中 
-O/--remote-name	把输出写到该文件中,保留远程文件的文件名 
-p/--proxytunnel	使用HTTP代理      
	--proxy-anyauth	选择任一代理身份验证方法      
	--proxy-basic	在代理上使用基本身份验证      
	--proxy-digest	在代理上使用数字身份验证      
	--proxy-ntlm	在代理上使用ntlm身份验证 
-P/--ftp-port    使用端口地址,而不是使用PASV 
-q	作为第一个参数,关闭 .curlrc
-Q/--quote 文件传输前,发送命令到服务器 
-r/--range 检索来自HTTP/1.1或FTP服务器字节范围 
	--range-file	读取(SSL)的随机文件 
-R/--remote-time	在本地生成文件时,保留远程文件时间      
	--retry 传输出现问题时,重试的次数      
	--retry-delay 传输出现问题时,设置重试间隔时间      
	--retry-max-time 传输出现问题时,设置最大重试时间 
-s/--silent	静默模式。不输出任何东西 
-S/--show-error	显示错误      
	--socks4 用socks4代理给定主机和端口      
	--socks5 用socks5代理给定主机和端口        
-t/--telnet-option Telnet选项设置      
	--trace 对指定文件进行debug      
	--trace-ascii Like --跟踪但没有hex输出      
	--trace-time	跟踪/详细输出时,添加时间戳 
-T/--upload-file 上传文件      
	--url Spet URL to work with 
-u/--user 设置服务器的用户和密码 
-U/--proxy-user 设置代理用户名和密码 
-w/--write-out [format]	什么输出完成后
	url_effective 最终获取的url地址,尤其是当你指定给curl的地址存在301跳转,且通过-L继续追踪的情形。
	http_code http状态码,如200成功,301转向,404未找到,500服务器错误等。
	time_total 总时间,按秒计。精确到小数点后三位。
	time_namelookup DNS解析时间,从请求开始到DNS解析完毕所用时间。
	time_connect 连接时间,从开始到建立TCP连接完成所用时间,包括前边DNS解析时间,如果需要单纯的得到连接时间,用这个time_connect时间减去前边time_namelookup时间。以下同理,不再赘述。
	time_appconnect 连接建立完成时间,如SSL/SSH等建立连接或者完成三次握手时间。
	time_pretransfer 从开始到准备传输的时间。
	time_redirect 重定向时间,包括到最后一次传输前的几次重定向的DNS解析,连接,预传输,传输时间。
	time_starttransfer 开始传输时间。在发出请求之后,Web 服务器返回数据的第一个字节所用的时间
	size_download 下载大小。
	size_upload 上传大小。
	size_header  下载的header的大小
	size_request 请求的大小。
	speed_download 下载速度,单位-字节每秒。
	speed_upload 上传速度,单位-字节每秒。
	content_type 就是content-Type,不用多说了,这是一个访问我博客首页返回的结果示例
	num_connects Number of new connects made in the recent transfer. 
	num_redirects Number of redirects that were followed in the request. 
	redirect_url When a HTTP request was made without -L to follow redirects, this variable will show the actual URL a redirect would take you to.
	ftp_entry_path The initial path libcurl ended up in when logging on to the remote FTP server
	ssl_verify_result ssl认证结果,返回0表示认证成功。
-x/--proxy 在给定的端口上使用HTTP代理 
-X/--request 指定什么命令 
-y/--speed-time	放弃限速所要的时间,默认为30 
-Y/--speed-limit	停止传输速度的限制,速度时间
curl选项中文解释

实例

1、文件下载

       curl是将下载文件输出到stdout,将进度信息输出到stderr,不显示进度信息使用--silent选项。
       curl URL --silent
       这条命令是将下载文件输出到终端,所有下载的数据都被写入到stdout。

       使用选项-O将下载的数据写入到文件,必须使用文件的绝对地址:

       curl http://man.linuxde.net/text.iso --silent -O

       选项-o将下载数据写入到指定名称的文件中,并使用--progress显示进度条:

       curl http://man.linuxde.net/test.iso -o filename.iso --progress

       ######################################### 100.0%
2、断点续传

      curl能够从特定的文件偏移处继续下载,它可以通过指定一个偏移量来下载部分文件:

      curl URL/File -C 偏移量

      #偏移量是以字节为单位的整数,如果让curl自动推断出正确的续传位置使用-C -:

      curl -C -URL
3、使用curl设置参照页字符串

      参照页是位于HTTP头部中的一个字符串,用来表示用户是从哪个页面到达当前页面的,如果用户点击网页A中的某个连接,那么用户就会跳转到B网页,网页B头部的参照页字符串就包含网页A的URL。

       使用--referer选项指定参照页字符串:

       curl --referer http://www.google.com http://man.linuxde.net
4、用curl设置cookies
      使用--cookie "COKKIES"选项来指定cookie,多个cookie使用分号分隔:

      curl http://man.linuxde.net --cookie "user=root;pass=123456"

      将cookie另存为一个文件,使用--cookie-jar选项:

      curl URL --cookie-jar cookie_file
5、用curl设置用户代理字符串
      有些网站访问会提示只能使用IE浏览器来访问,这是因为这些网站设置了检查用户代理,可以使用curl把用户代理设置为IE,这样就可以访问了。使用--user-agent或者-A选项:

       curl URL --user-agent "Mozilla/5.0"

       curl URL -A "Mozilla/5.0"

       其他HTTP头部信息也可以使用curl来发送,使用-H"头部信息" 传递多个头部信息,例如:

       curl -H "Host:man.linuxde.net" -H "accept-language:zh-cn" URL
6、curl的带宽控制和下载配额
      使用--limit-rate限制curl的下载速度:

       curl URL --limit-rate 50k 命令中用k(千字节)和m(兆字节)指定下载速度限制。

       使用--max-filesize指定可下载的最大文件大小:

        curl URL --max-filesize bytes

        如果文件大小超出限制,命令则返回一个非0退出码,如果命令正常则返回0。
7、用curl进行认证
      使用curl选项 -u 可以完成HTTP或者FTP的认证,可以指定密码,也可以不指定密码在后续操作中输入密码:

      curl -u user:pwd http://man.linuxde.net

      curl -u user http://man.linuxde.net
8、只打印响应头部信息
      通过-I或者-head可以只打印出HTTP头部信息:

      [root@localhost text]# curl -I http://man.linuxde.net

      HTTP/1.1 200 OK

      Server: nginx/1.2.5

      date: Mon, 10 Dec 2012 09:24:34 GMT

      Content-Type: text/html; charset=UTF-8

      Connection: keep-alive

      Vary: Accept-Encoding

       X-Pingback: http://man.linuxde.net/xmlrpc.php

工作中使用示例

#!/bin/bash
#
start_time=`date +%s` && proxytxt=`/home/root/get_ppp_ip.sh 183.60.41.83 26690` && end_time=`date +%s`

IP=`echo ${proxytxt}|awk -F: '{print $3}'|awk -F \" '{print $2}'`
PORT=`echo ${proxytxt}|awk -F: '{print $4}'|awk -F \" '{print $2}'`

if [ -z $IP ] || [ -z $PORT ];then
  exit 1;  #如果循环,就替换成continue
fi

let cost_time=(${end_time} - ${start_time})

CODE=`curl -m 15 -x ${IP}:${PORT} -o /dev/null -s -w %{http_code} https://www.baidu.com`

response_speed=`curl -m 15 -x ${IP}:${PORT} -o /dev/null -s -w %{time_total} https://www.baidu.com`

wait
#echo "ip=${IP} : port=${PORT} : code=${CODE} : cost_time=${cost_time} : response_speed=${response_speed}" >> /tmp/test.txt
echo "${IP}:${PORT} ${CODE} ${cost_time} ${response_speed}" >> /tmp/test.txt
脚本中使用curl取所需值
 curl --socks5 60.182.50.192:15570 https://www.baidu.com -m 5 -U china:IvHOfpDYMm 使用socks5代理给定主机和端口 并给定代理用户名和密码 访问 网站
 
 curl -o /dev/null -s -w %{time_total} --socks5 60.182.50.192:15570 https://www.baidu.com -m 5 -U china:IvHOfpDYMm 使用socks5 并测试响应速度
下面这个要区分清楚
    --connect-timeout <seconds> 设置最大请求时间
    -m/--max-time <seconds> 设置最大传输时间

转载于:https://www.cnblogs.com/wjstud/p/7374478.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值