zoukankan      html  css  js  c++  java
  • Linux curl 网络访问

    Linux curl 网络访问

    参数详解

    -a/--append    上传文件时,附加到目标文件
    -A/--user-agent <string>    设置用户代理发送给服务器
    -anyauth    可以使用“任何”身份验证方法
    -b/--cookie <name=string/file>    cookie字符串或文件读取位置
         --basic    使用HTTP基本验证
    -B/--use-ascii    使用ASCII /文本传输
    -c/--cookie-jar <file>    操作结束后把cookie写入到这个文件中
    -C/--continue-at <offset>    断点续转
    -d/--data <data>    HTTP POST方式传送数据
         --data-ascii <data>    以ascii的方式post数据
         --data-binary <data>    以二进制的方式post数据
         --negotiate    使用HTTP身份验证
         --digest    使用数字身份验证
         --disable-eprt    禁止使用EPRT或LPRT
         --disable-epsv    禁止使用EPSV
    -D/--dump-header <file>    把header信息写入到该文件中
         --egd-file <file>    为随机数据(SSL)设置EGD socket路径
         --tcp-nodelay    使用TCP_NODELAY选项
    -e/--referer    来源网址
    -E/--cert <cert[:passwd]>    客户端证书文件和密码 (SSL)
         --cert-type <type>    证书文件类型 (DER/PEM/ENG) (SSL)
         --key <key>    私钥文件名 (SSL)
         --key-type <type>    私钥文件类型 (DER/PEM/ENG) (SSL)
         --pass <pass>    私钥密码 (SSL)
         --engine <eng>    加密引擎使用 (SSL). "--engine list" for list
         --cacert <file>    CA证书 (SSL)
         --capath <directory>    CA目录 (made using c_rehash) to verify peer against (SSL)
         --ciphers <list>    SSL密码
         --compressed    要求返回是压缩的形势 (using deflate or gzip)
         --connect-timeout <seconds>    设置最大请求时间
         --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 <name=content>    模拟http表单提交数据
         --form-string <name=string>    模拟http表单提交数据
    -g/--globoff    禁用网址序列和范围使用{}和[]
    -G/--get    以get的方式来发送数据
    -H/--header <line>    自定义头信息传递给服务器
         --ignore-content-length    忽略的HTTP头信息的长度
    -i/--include    输出时包括protocol头信息
    -I/--head    只显示请求头信息
    -j/--junk-session-cookies    读取文件进忽略session cookie
         --interface <interface>    使用指定网络接口/地址
         --krb4 <level>    使用指定安全级别的krb4
    -k/--insecure    允许不使用证书到SSL站点
    -K/--config    指定的配置文件读取
    -l/--list-only    列出ftp目录下的文件名称
         --limit-rate <rate>    设置传输速度
         --local-port<NUM>    强制使用本地端口号
    -m/--max-time <seconds>    设置最大传输时间
         --max-redirs <num>    设置最大读取的目录数
         --max-filesize <bytes>    设置最大下载的文件总量
    -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 <address>    使用端口地址,而不是使用PASV
    -q    作为第一个参数,关闭 .curlrc
    -Q/--quote <cmd>    文件传输前,发送命令到服务器
    -r/--range <range>    检索来自HTTP/1.1或FTP服务器字节范围
    --range-file    读取(SSL)的随机文件
    -R/--remote-time    在本地生成文件时,保留远程文件时间
         --retry <num>    传输出现问题时,重试的次数
         --retry-delay <seconds>    传输出现问题时,设置重试间隔时间
         --retry-max-time <seconds>    传输出现问题时,设置最大重试时间
    -s/--silent    静默模式。不输出任何东西
    -S/--show-error    显示错误
         --socks4 <host[:port]>    用socks4代理给定主机和端口
         --socks5 <host[:port]>    用socks5代理给定主机和端口
         --stderr <file>     
    -t/--telnet-option <OPT=val>    Telnet选项设置
         --trace <file>    对指定文件进行debug
         --trace-ascii <file>    Like --跟踪但没有hex输出
         --trace-time    跟踪/详细输出时,添加时间戳
    -T/--upload-file <file>    上传文件
         --url <URL>    Spet URL to work with
    -u/--user <user[:password]>    设置服务器的用户和密码
    -U/--proxy-user <user[:password]>    设置代理用户名和密码
    -w/--write-out [format]    什么输出完成后
    -x/--proxy <host[:port]>    在给定的端口上使用HTTP代理
    -X/--request <command>    指定什么命令
    -y/--speed-time    放弃限速所要的时间,默认为30
    -Y/--speed-limit    停止传输速度的限制,速度时间
    参数

    请求参数

    ---------------------------------
    
    time_namelookup:  %{time_namelookup}
    time_connect:  %{time_connect}
    time_appconnect:  %{time_appconnect}
    time_pretransfer:  %{time_pretransfer}
    time_redirect:  %{time_redirect}
    time_starttransfer:  %{time_starttransfer}
    time_total:  %{time_total}
    
    ---------------------------------
    
    time_namelookup:DNS解析域名时间,把域名--->ipd的时间
    time_connect:TCP连接的时间,三次握手的时间
    time_appconnect:SSL|SSH等上层连接建立的时间
    time_pretransfer:从请求开始到到响应开始传输的时间
    time_redirect:从开始到最后一个请求事务的时间
    time_starttransfer:从请求开始到第一个字节将要传输的时间
    time_total:总时间
    
    ---------------------------------
    请求参数
    curl -o /dev/null -s -w '%{xxx}
    ' 'http://www.baidu.com/'

    访问资源打印头部信息

    curl -I www.baidu.com                        #-I只打印http的头部
    -----------------------------------------------------------
    HTTP/1.1 200 OK                              #响应行,请求状态码
    Server: bfe/1.0.8.18                         #服务器主机
    Date: Fri, 20 Apr 2018 09:56:19 GMT          #请求时间
    Content-Type: text/html                      #请求到的文本类型
    Content-Length: 277                          #总文件大小
    Last-Modified: Mon, 13 Jun 2016 02:50:08 GMT    
                                                 #last-Modified  web对象认为对象的最后修改时间,比如文件的最后修改时间等
    Connection: Keep-Alive                       #请求连接   
                                                 #(keepalive表示连接保持,即一次来连接可以多次请求,请求最大次数在服务器配置内有限定)
                                                 #(close 一次连接仅能一次请求)
    ETag: "575e1f60-115"    
    Cache-Control: private, no-cache, no-store, proxy-revalidate, no-transform
                                                 #请求缓存
                                                 #max-age表示本响应包含的对象过期时间,单位为秒
    Pragma: no-cache
    Accept-Ranges: bytes                         #是否允许断点续传
                                                 #断点续传,web服务器表明自己是否接受客户端获取其实体的一部分
                                                 #(比如文件的一部分)none不允许,bytes 允许

    访问指定资源时间

    curl -o /dev/null -s -w '%{time_total}
    ' http://xxx.xxx.xxx/
  • 相关阅读:
    hdoj 2803 The MAX【简单规律题】
    hdoj 2579 Dating with girls(2)【三重数组标记去重】
    hdoj 1495 非常可乐【bfs隐式图】
    poj 1149 PIGS【最大流经典建图】
    poj 3281 Dining【拆点网络流】
    hdoj 3572 Task Schedule【建立超级源点超级汇点】
    hdoj 1532 Drainage Ditches【最大流模板题】
    poj 1459 Power Network【建立超级源点,超级汇点】
    hdoj 3861 The King’s Problem【强连通缩点建图&&最小路径覆盖】
    hdoj 1012 u Calculate e
  • 原文地址:https://www.cnblogs.com/xiangsikai/p/9627831.html
Copyright © 2011-2022 走看看