热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

linuxcurl命令详解,以及实例

linuxcurl是一个利用URL规则在命令行下工作的文件传输工具。它支持文件的上传和下载,所以是综合传输工具,但按传统,习惯称url为下

linux curl是一个利用URL规则在命令行下工作的文件传输工具。它支持文件的上传和下载,所以是综合传输工具,但按传统,习惯称url为下载工具。

一,curl命令参数,有好多我没有用过,也不知道翻译的对不对,如果有误的地方,还请指正。

查看复制打印?
  1. -a/--append 上传文件时,附加到目标文件  
  2.  -A/--user-agent   设置用户代理发送给服务器  
  3.  - anyauth   可以使用“任何”身份验证方法  
  4.  -b/--COOKIE  COOKIE字符串或文件读取位置  
  5.  - basic 使用HTTP基本验证  
  6.  -B/--use-ascii 使用ASCII /文本传输  
  7.  -c/--COOKIE-jar  操作结束后把COOKIE写入到这个文件中  
  8.  -C/--continue-at   断点续转  
  9.  -d/--data    HTTP POST方式传送数据  
  10.  --data-ascii   以ascii的方式post数据  
  11.  --data-binary  以二进制的方式post数据  
  12.  --negotiate     使用HTTP身份验证  
  13.  --digest        使用数字身份验证  
  14.  --disable-eprt  禁止使用EPRT或LPRT  
  15.  --disable-epsv  禁止使用EPSV  
  16.  -D/--dump-header  把header信息写入到该文件中  
  17.  --egd-file  为随机数据(SSL)设置EGD socket路径  
  18.  --tcp-nodelay   使用TCP_NODELAY选项  
  19.  -e/--referer 来源网址  
  20.  -E/--cert  客户端证书文件和密码 (SSL)  
  21.  --cert-type  证书文件类型 (DER/PEM/ENG) (SSL)  
  22.  --key      私钥文件名 (SSL)  
  23.  --key-type  私钥文件类型 (DER/PEM/ENG) (SSL)  
  24.  --pass    私钥密码 (SSL)  
  25.  --engine   加密引擎使用 (SSL). "--engine list" for list  
  26.  --cacert  CA证书 (SSL)  
  27.  --capath  CA目录 (made using c_rehash) to verify peer against (SSL)  
  28.  --ciphers   SSL密码  
  29.  --compressed    要求返回是压缩的形势 (using deflate or gzip)  
  30.  --connect-timeout  设置最大请求时间  
  31.  --create-dirs   建立本地目录的目录层次结构  
  32.  --crlf          上传是把LF转变成CRLF  
  33.  -f/--fail          连接失败时不显示http错误  
  34.  --ftp-create-dirs 如果远程目录不存在,创建远程目录  
  35.  --ftp-method [multicwd/nocwd/singlecwd] 控制CWD的使用  
  36.  --ftp-pasv      使用 PASV/EPSV 代替端口  
  37.  --ftp-skip-pasv-ip 使用PASV的时候,忽略该IP地址  
  38.  --ftp-ssl       尝试用 SSL/TLS 来进行ftp数据传输  
  39.  --ftp-ssl-reqd  要求用 SSL/TLS 来进行ftp数据传输  
  40.  -F/--form  模拟http表单提交数据  
  41.  -form-string  模拟http表单提交数据  
  42.  -g/--globoff 禁用网址序列和范围使用{}和[]  
  43.  -G/--get 以get的方式来发送数据  
  44.  -h/--help 帮助  
  45.  -H/--header 自定义头信息传递给服务器  
  46.  --ignore-content-length  忽略的HTTP头信息的长度  
  47.  -i/--include 输出时包括protocol头信息  
  48.  -I/--head  只显示文档信息  
  49.  从文件中读取-j/--junk-session-COOKIEs忽略会话COOKIE  
  50.  - 界面<interface>指定网络接口/地址使用  
  51.  - krb4 <级别>启用与指定的安全级别krb4  
  52.  -j/--junk-session-COOKIEs 读取文件进忽略session COOKIE  
  53.  --interface <interface> 使用指定网络接口/地址  
  54.  --krb4   使用指定安全级别的krb4  
  55.  -k/--insecure 允许不使用证书到SSL站点  
  56.  -K/--config  指定的配置文件读取  
  57.  -l/--list-only 列出ftp目录下的文件名称  
  58.  --limit-rate  设置传输速度  
  59.  --local-port 强制使用本地端口号  
  60.  -m/--max-time  设置最大传输时间  
  61.  --max-redirs  设置最大读取的目录数  
  62.  --max-filesize  设置最大下载的文件总量  
  63.  -M/--manual  显示全手动  
  64.  -n/--netrc 从netrc文件中读取用户名和密码  
  65.  --netrc-optional 使用 .netrc 或者 URL来覆盖-n  
  66.  --ntlm          使用 HTTP NTLM 身份验证  
  67.  -N/--no-buffer 禁用缓冲输出  
  68.  -o/--output 把输出写到该文件中  
  69.  -O/--remote-name 把输出写到该文件中&#xff0c;保留远程文件的文件名  
  70.  -p/--proxytunnel   使用HTTP代理  
  71.  --proxy-anyauth 选择任一代理身份验证方法  
  72.  --proxy-basic   在代理上使用基本身份验证  
  73.  --proxy-digest  在代理上使用数字身份验证  
  74.  --proxy-ntlm    在代理上使用ntlm身份验证  
  75.  -P/--ftp-port 
     使用端口地址&#xff0c;而不是使用PASV  
  76.  -Q/--quote 文件传输前&#xff0c;发送命令到服务器  
  77.  -r/--range 检索来自HTTP/1.1或FTP服务器字节范围  
  78.  --range-file 读取&#xff08;SSL&#xff09;的随机文件  
  79.  -R/--remote-time   在本地生成文件时&#xff0c;保留远程文件时间  
  80.  --retry    传输出现问题时&#xff0c;重试的次数  
  81.  --retry-delay   传输出现问题时&#xff0c;设置重试间隔时间  
  82.  --retry-max-time  传输出现问题时&#xff0c;设置最大重试时间  
  83.  -s/--silent静音模式。不输出任何东西  
  84.  -S/--show-error   显示错误  
  85.  --socks4  用socks4代理给定主机和端口  
  86.  --socks5  用socks5代理给定主机和端口  
  87.  --stderr   
  88.  -t/--telnet-option  Telnet选项设置  
  89.  --trace   对指定文件进行debug  
  90.  --trace-ascii  Like --跟踪但没有hex输出  
  91.  --trace-time    跟踪/详细输出时&#xff0c;添加时间戳  
  92.  -T/--upload-file  上传文件  
  93.  --url      Spet URL to work with  
  94.  -u/--user 设置服务器的用户和密码  
  95.  -U/--proxy-user 设置代理用户名和密码  
  96.  -v/--verbose  
  97.  -V/--version 显示版本信息  
  98.  -w/--write-out [format]什么输出完成后  
  99.  -x/--proxy 在给定的端口上使用HTTP代理  
  100.  -X/--request 指定什么命令  
  101.  -y/--speed-time 放弃限速所要的时间。默认为30  
  102.  -Y/--speed-limit 停止传输速度的限制&#xff0c;速度时间&#39;秒  
  103.  -z/--time-cond  传送时间设置  
  104.  -0/--http1.0  使用HTTP 1.0  
  105.  -1/--tlsv1  使用TLSv1&#xff08;SSL&#xff09;  
  106.  -2/--sslv2 使用SSLv2的&#xff08;SSL&#xff09;  
  107.  -3/--sslv3         使用的SSLv3&#xff08;SSL&#xff09;  
  108.  --3p-quote      like -Q for the source URL for 3rd party transfer  
  109.  --3p-url        使用url&#xff0c;进行第三方传送  
  110.  --3p-user       使用用户名和密码&#xff0c;进行第三方传送  
  111.  -4/--ipv4   使用IP4  
  112.  -6/--ipv6   使用IP6  
  113.  -#/--progress-bar 用进度条显示当前的传送状态  

二&#xff0c;常用curl实例

1&#xff0c;抓取页面内容到一个文件中

查看复制打印?
  1. [root&#64;krlcgcms01 mytest]# curl -o home.html  http://blog.51yip.com  

2&#xff0c;用-O&#xff08;大写的&#xff09;&#xff0c;后面的url要具体到某个文件&#xff0c;不然抓不下来。我们还可以用正则来抓取东西

查看复制打印?
  1. [root&#64;krlcgcms01 mytest]# curl -O http://blog.51yip.com/wp-content/uploads/2010/09/compare_varnish.jpg  
  2. [root&#64;krlcgcms01 mytest]# curl -O http://blog.51yip.com/wp-content/uploads/2010/[0-9][0-9]/aaaaa.jpg  

3&#xff0c;模拟表单信息&#xff0c;模拟登录&#xff0c;保存COOKIE信息

查看复制打印?
  1. [root&#64;krlcgcms01 mytest]# curl -c ./COOKIE_c.txt -F log&#61;aaaa -F pwd&#61;****** http://blog.51yip.com/wp-login.php  

4&#xff0c;模拟表单信息&#xff0c;模拟登录&#xff0c;保存头信息

查看复制打印?
  1. [root&#64;krlcgcms01 mytest]# curl -D ./COOKIE_D.txt -F log&#61;aaaa -F pwd&#61;****** http://blog.51yip.com/wp-login.php  

-c(小写)产生的COOKIE和-D里面的COOKIE是不一样的。

5&#xff0c;使用COOKIE文件

查看复制打印?
  1. [root&#64;krlcgcms01 mytest]# curl -b ./COOKIE_c.txt  http://blog.51yip.com/wp-admin  

6&#xff0c;断点续传&#xff0c;-C(大写的)

查看复制打印?
  1. [root&#64;krlcgcms01 mytest]# curl -C -O http://blog.51yip.com/wp-content/uploads/2010/09/compare_varnish.jpg  

7&#xff0c;传送数据,最好用登录页面测试&#xff0c;因为你传值过去后&#xff0c;curl回抓数据&#xff0c;你可以看到你传值有没有成功

查看复制打印?
  1. [root&#64;krlcgcms01 mytest]# curl -d log&#61;aaaa  http://blog.51yip.com/wp-login.php  

8&#xff0c;显示抓取错误&#xff0c;下面这个例子&#xff0c;很清楚的表明了。

查看复制打印?
  1. [root&#64;krlcgcms01 mytest]# curl -f http://blog.51yip.com/asdf  
  2. curl: (22) The requested URL returned error: 404  
  3. [root&#64;krlcgcms01 mytest]# curl http://blog.51yip.com/asdf  
  4.   
  5.   
  6. 。。。。。。。。。。。。  

9&#xff0c;伪造来源地址&#xff0c;有的网站会判断&#xff0c;请求来源地址。

查看复制打印?
  1. [root&#64;krlcgcms01 mytest]# curl -e http://localhost http://blog.51yip.com/wp-login.php  

10&#xff0c;当我们经常用curl去搞人家东西的时候&#xff0c;人家会把你的IP给屏蔽掉的,这个时候,我们可以用代理

查看复制打印?
  1. [root&#64;krlcgcms01 mytest]# curl -x 24.10.28.84:32779 -o home.html http://blog.51yip.com  

11&#xff0c;比较大的东西&#xff0c;我们可以分段下载

查看复制打印?
  1. [root&#64;krlcgcms01 mytest]# curl -r 0-100 -o img.part1 http://blog.51yip.com/wp-  
  2.   
  3. content/uploads/2010/09/compare_varnish.jpg  
  4.  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current  
  5.  Dload  Upload   Total   Spent    Left  Speed  
  6. 100   101  100   101    0     0    105      0 --:--:-- --:--:-- --:--:--     0  
  7. [root&#64;krlcgcms01 mytest]# curl -r 100-200 -o img.part2 http://blog.51yip.com/wp-  
  8.   
  9. content/uploads/2010/09/compare_varnish.jpg  
  10.  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current  
  11.  Dload  Upload   Total   Spent    Left  Speed  
  12. 100   101  100   101    0     0     57      0  0:00:01  0:00:01 --:--:--     0  
  13. [root&#64;krlcgcms01 mytest]# curl -r 200- -o img.part3 http://blog.51yip.com/wp-  
  14.   
  15. content/uploads/2010/09/compare_varnish.jpg  
  16.  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current  
  17.  Dload  Upload   Total   Spent    Left  Speed  
  18. 100  104k  100  104k    0     0  52793      0  0:00:02  0:00:02 --:--:-- 88961  
  19. [root&#64;krlcgcms01 mytest]# ls |grep part | xargs du -sh  
  20. 4.0K    one.part1  
  21. 112K    three.part3  
  22. 4.0K    two.part2  

用的时候&#xff0c;把他们cat一下就OK了,cat img.part* >img.jpg

12&#xff0c;不会显示下载进度信息

查看复制打印?
  1. [root&#64;krlcgcms01 mytest]# curl -s -o aaa.jpg  http://blog.51yip.com/wp-content/uploads/2010/09/compare_varnish.jpg  

13&#xff0c;显示下载进度条

查看复制打印?
  1. [root&#64;krlcgcms01 mytest]# curl -# -O  http://blog.51yip.com/wp-content/uploads/2010/09/compare_varnish.jpg  
  2. ######################################################################## 100.0%  

14,通过ftp下载文件

查看复制打印?
  1. [zhangy&#64;BlackGhost ~]$ curl -u 用户名:密码 -O http://blog.51yip.com/demo/curtain/bbstudy_files/style.css  
  2.  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current  
  3.  Dload  Upload   Total   Spent    Left  Speed  
  4. 101  1934  101  1934    0     0   3184      0 --:--:-- --:--:-- --:--:--  7136  


或者用下面的方式
查看复制打印?
  1. [zhangy&#64;BlackGhost ~]$ curl -O ftp://用户名:密码&#64;ip:port/demo/curtain/bbstudy_files/style.css  

15&#xff0c;通过ftp上传

查看复制打印?
  1. [zhangy&#64;BlackGhost ~]$ curl -T test.sql ftp://用户名:密码&#64;ip:port/demo/curtain/bbstudy_files/  



转载请注明
作者:海底苍鹰
地址:http://blog.51yip.com/linux/1049.html

推荐阅读
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • ZABBIX 3.0 配置监控NGINX性能【OK】
    1.在agent端查看配置:nginx-V查看编辑时是否加入状态监控模块:--with-http_stub_status_module--with-http_gzip_stat ... [详细]
  • PHP输出缓冲控制Output Control系列函数详解【PHP】
    后端开发|php教程PHP,输出缓冲,Output,Control后端开发-php教程概述全景网页源码,vscode如何打开c,ubuntu强制解锁,sts启动tomcat慢,sq ... [详细]
  • 一.常见基于身份识别进行反爬1通过headers字段来反爬headers中有很多字段,这些字段都有可能会被对方服务器拿过来进行判断是否为爬虫1.1通过headers中的User-A ... [详细]
  • 有些网站设置了权限,只有在登录了之后才能爬取网站的内容,如何模拟登录,目前的方法主要是利用浏览器cookie模拟登录。浏览器访问服务器的过程在用户访问网页时,不论是通过URL输入域名或I ... [详细]
  • 单页面应用 VS 多页面应用的区别和适用场景
    本文主要介绍了单页面应用(SPA)和多页面应用(MPA)的区别和适用场景。单页面应用只有一个主页面,所有内容都包含在主页面中,页面切换快但需要做相关的调优;多页面应用有多个独立的页面,每个页面都要加载相关资源,页面切换慢但适用于对SEO要求较高的应用。文章还提到了两者在资源加载、过渡动画、路由模式和数据传递方面的差异。 ... [详细]
  • 超级简单加解密工具的方案和功能
    本文介绍了一个超级简单的加解密工具的方案和功能。该工具可以读取文件头,并根据特定长度进行加密,加密后将加密部分写入源文件。同时,该工具也支持解密操作。加密和解密过程是可逆的。本文还提到了一些相关的功能和使用方法,并给出了Python代码示例。 ... [详细]
  • .NetCoreWebApi生成Swagger接口文档的使用方法
    本文介绍了使用.NetCoreWebApi生成Swagger接口文档的方法,并详细说明了Swagger的定义和功能。通过使用Swagger,可以实现接口和服务的可视化,方便测试人员进行接口测试。同时,还提供了Github链接和具体的步骤,包括创建WebApi工程、引入swagger的包、配置XML文档文件和跨域处理。通过本文,读者可以了解到如何使用Swagger生成接口文档,并加深对Swagger的理解。 ... [详细]
  • 本文介绍了NetCore WebAPI开发的探索过程,包括新建项目、运行接口获取数据、跨平台部署等。同时还提供了客户端访问代码示例,包括Post函数、服务器post地址、api参数等。详细讲解了部署模式选择、框架依赖和独立部署的区别,以及在Windows和Linux平台上的部署方法。 ... [详细]
  • 前言:关于跨域CORS1.没有跨域时,ajax默认是带cookie的2.跨域时,两种解决方案:1)服务器端在filter中配置详情:http:blog.csdn.netwzl002 ... [详细]
  • adfs是什么_培训与开发的概念
    adfs是什么_培训与开发的概念(如您转载本文,必须标明本文作者及出处。如有任何疑问请与我联系me@nap7.com)ADFS相关开发技术的中文资料相对匮乏,之前在弄这个东西的时候 ... [详细]
  • 渗透测试基础bypass绕过阻挡我们的WAF(下)
    渗透测试基础-bypass ... [详细]
  • 找到JDK下载URL当然去官网找了。目前最新的1.8的下载URL(RPM)如下:http:download.oracle.comotn-pubjavajdk8u161-b122f3 ... [详细]
  • Java大文件HTTP断点续传到服务器该怎么做?
    最近由于笔者所在的研发集团产品需要,需要支持高性能的大文件http上传,并且要求支持http断点续传。这里在简要归纳一下,方便记忆 ... [详细]
author-avatar
珠珠VS胖胖
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有