- 浏览: 458281 次
- 性别:
- 来自: 广州
文章分类
- 全部博客 (538)
- C/C++ Primer (69)
- Objective-C Primer (102)
- Python Primer (19)
- JavaScript Primer (1)
- Java Primer (37)
- PHP Primer (17)
- 泛 Linux (37)
- Shell Script (21)
- APUE (21)
- UNP__1&2 (19)
- NetWork (7)
- Oracle周边 (38)
- Mysql里边 (6)
- Windows技 (9)
- 简单算法 & 数据结构 (14)
- 设计模式 (6)
- GTK历程 (12)
- 工具使用 (25)
- 杂事 (23)
- 一些概念 (17)
- Web方面 (10)
- myCodeTools (9)
- ^未 竟$ (13)
- 硬件通信 (2)
- Games (1)
最新评论
http://hi.baidu.com/yuanhotel/blog/item/032190ec35fa6a3b269791d1.html
Curl是Linux下一个很强大的http命令行工具,其功能十分强大。
1) 下载页面:
$ curl http://www.linuxidc.com
回车之后,www.linuxidc.com 的html就稀里哗啦地显示在屏幕上了 ~
2) 嗯,要想把读过来页面存下来,是不是要这样呢?
curl http://www.linuxidc.com > page.html
当然可以,但不用这么麻烦的!
用curl的内置option就好,存下http的结果,用这个option: -o
$ curl -o page.html http://www.linuxidc.com
这样,你就可以看到屏幕上出现一个下载页面进度指示。等进展到100%,自然就 OK咯
3) 什么什么?!访问不到?肯定是你的proxy没有设定了。
使用curl的时候,用这个option可以指定http访问所使用的proxy服务器及其端口: -x
$ curl -x 123.45.67.89:1080 -o page.html http://www.linuxidc.com
4) 访问有些网站的时候比较讨厌,他使用cookie来记录session信息。
像IE/NN这样的浏览器,当然可以轻易处理cookie信息,但我们的curl呢?.....
我们来学习这个option: -D <— 这个是把http的response里面的cookie信息存到一个特别的文件中去
$ curl -x 123.45.67.89:1080 -o page.html -D cookie0001.txt http://www.linuxidc.com
这样,当页面被存到page.html的同时,cookie信息也被存到了cookie0001.txt里面了
5)那么,下一次访问的时候,如何继续使用上次留下的cookie信息呢?要知道,很多网站都是靠监视你的cookie信息,来判断你是不是不按规矩访问他们的网站的。
这次我们使用这个option来把上次的cookie信息追加到http request里面去: -b
$ curl -x 123.45.67.89:1080 -o page1.html -D cookie0002.txt -b cookie0001.txt http://www.linuxidc.com
这样,我们就可以几乎模拟所有的IE操作,去访问网页了!
6)稍微等等 ~我好像忘记什么了 ~
对了!是浏览器信息
有些讨厌的网站总要我们使用某些特定的浏览器去访问他们,有时候更过分的是,还要使用某些特定的版本。NND,哪里有时间为了它去找这些怪异的浏览器呢!?
好在curl给我们提供了一个有用的option,可以让我们随意指定自己这次访问所宣称的自己的浏览器信息: -A
$ curl -A "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0)" -x 123.45.67.89:1080 -o page.html -D cookie0001.txt http://www.linuxidc.com
这样,服务器端接到访问的要求,会认为你是一个运行在Windows 2000上的 IE6.0,嘿嘿嘿,其实也许你用的是苹果机呢!
而"Mozilla/4.73 [en] (X11; U; Linux 2.2; 15 i686"则可以告诉对方你是一台 PC上跑着的Linux,用的是Netscape 4.73,呵呵呵
7)另外一个服务器端常用的限制方法,就是检查http访问的referer。比如你先访问首页,再访问里面所指定的下载页,这第二次访问的 referer地址就是第一次访问成功后的页面地址。这样,服务器端只要发现对下载页面某次访问的referer地址不是首页的地址,就可以断定那是个盗 连了 ~
讨厌讨厌 ~我就是要盗连 ~!!
幸好curl给我们提供了设定referer的option: -e
$ curl -A "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0)" -x 123.45.67.89:1080 -e "mail.linuxidc.com" -o page.html -D cookie0001.txt http://www.linuxidc.com
这样,就可以骗对方的服务器,你是从mail.linuxidc.com点击某个链接过来的了,呵呵呵
8)写着写着发现漏掉什么重要的东西了!——- 利用curl 下载文件
刚才讲过了,下载页面到一个文件里,可以使用 -o ,下载文件也是一样。比如,
$ curl -o 1.jpg http://cgi2.tky.3web.ne.jp/~zzh/screen1.JPG
这里教大家一个新的option: -O 大写的O,这么用:
$ curl -O http://cgi2.tky.3web.ne.jp/~zzh/screen1.JPG
这样,就可以按照服务器上的文件名,自动存在本地了!
再来一个更好用的。
如果screen1.JPG以外还有screen2.JPG、screen3.JPG、....、screen10.JPG需要下载,难不成还要让我们写一个script来完成这些操作?
不干!
在curl里面,这么写就可以了:
$ curl -O http://cgi2.tky.3web.ne.jp/~zzh/screen[1-10].JPG
呵呵呵,厉害吧?! ~
9)再来,我们继续讲解下载!
$ curl -O http://cgi2.tky.3web.ne.jp/~{zzh,nick}/[001-201].JPG
这样产生的下载,就是
~zzh/001.JPG
~zzh/002.JPG
...
~zzh/201.JPG
~nick/001.JPG
~nick/002.JPG
...
~nick/201.JPG
够方便的了吧?哈哈哈
咦?高兴得太早了。
由于zzh/nick下的文件名都是001,002...,201,下载下来的文件重名,后面的把前面的文件都给覆盖掉了 ~
没关系,我们还有更狠的!
$ curl -o #2_#1.jpg http://cgi2.tky.3web.ne.jp/~{zzh,nick}/[001-201].JPG
—这是.....自定义文件名的下载? —对头,呵呵!
这样,自定义出来下载下来的文件名,就变成了这样:原来: ~zzh/001.JPG —-> 下载后: 001-zzh.JPG 原来: ~nick/001.JPG —-> 下载后: 001-nick.JPG
这样一来,就不怕文件重名啦
Curl是Linux下一个很强大的http命令行工具,其功能十分强大。
1) 下载页面:
$ curl http://www.linuxidc.com
回车之后,www.linuxidc.com 的html就稀里哗啦地显示在屏幕上了 ~
2) 嗯,要想把读过来页面存下来,是不是要这样呢?
curl http://www.linuxidc.com > page.html
当然可以,但不用这么麻烦的!
用curl的内置option就好,存下http的结果,用这个option: -o
$ curl -o page.html http://www.linuxidc.com
这样,你就可以看到屏幕上出现一个下载页面进度指示。等进展到100%,自然就 OK咯
3) 什么什么?!访问不到?肯定是你的proxy没有设定了。
使用curl的时候,用这个option可以指定http访问所使用的proxy服务器及其端口: -x
$ curl -x 123.45.67.89:1080 -o page.html http://www.linuxidc.com
4) 访问有些网站的时候比较讨厌,他使用cookie来记录session信息。
像IE/NN这样的浏览器,当然可以轻易处理cookie信息,但我们的curl呢?.....
我们来学习这个option: -D <— 这个是把http的response里面的cookie信息存到一个特别的文件中去
$ curl -x 123.45.67.89:1080 -o page.html -D cookie0001.txt http://www.linuxidc.com
这样,当页面被存到page.html的同时,cookie信息也被存到了cookie0001.txt里面了
5)那么,下一次访问的时候,如何继续使用上次留下的cookie信息呢?要知道,很多网站都是靠监视你的cookie信息,来判断你是不是不按规矩访问他们的网站的。
这次我们使用这个option来把上次的cookie信息追加到http request里面去: -b
$ curl -x 123.45.67.89:1080 -o page1.html -D cookie0002.txt -b cookie0001.txt http://www.linuxidc.com
这样,我们就可以几乎模拟所有的IE操作,去访问网页了!
6)稍微等等 ~我好像忘记什么了 ~
对了!是浏览器信息
有些讨厌的网站总要我们使用某些特定的浏览器去访问他们,有时候更过分的是,还要使用某些特定的版本。NND,哪里有时间为了它去找这些怪异的浏览器呢!?
好在curl给我们提供了一个有用的option,可以让我们随意指定自己这次访问所宣称的自己的浏览器信息: -A
$ curl -A "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0)" -x 123.45.67.89:1080 -o page.html -D cookie0001.txt http://www.linuxidc.com
这样,服务器端接到访问的要求,会认为你是一个运行在Windows 2000上的 IE6.0,嘿嘿嘿,其实也许你用的是苹果机呢!
而"Mozilla/4.73 [en] (X11; U; Linux 2.2; 15 i686"则可以告诉对方你是一台 PC上跑着的Linux,用的是Netscape 4.73,呵呵呵
7)另外一个服务器端常用的限制方法,就是检查http访问的referer。比如你先访问首页,再访问里面所指定的下载页,这第二次访问的 referer地址就是第一次访问成功后的页面地址。这样,服务器端只要发现对下载页面某次访问的referer地址不是首页的地址,就可以断定那是个盗 连了 ~
讨厌讨厌 ~我就是要盗连 ~!!
幸好curl给我们提供了设定referer的option: -e
$ curl -A "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0)" -x 123.45.67.89:1080 -e "mail.linuxidc.com" -o page.html -D cookie0001.txt http://www.linuxidc.com
这样,就可以骗对方的服务器,你是从mail.linuxidc.com点击某个链接过来的了,呵呵呵
8)写着写着发现漏掉什么重要的东西了!——- 利用curl 下载文件
刚才讲过了,下载页面到一个文件里,可以使用 -o ,下载文件也是一样。比如,
$ curl -o 1.jpg http://cgi2.tky.3web.ne.jp/~zzh/screen1.JPG
这里教大家一个新的option: -O 大写的O,这么用:
$ curl -O http://cgi2.tky.3web.ne.jp/~zzh/screen1.JPG
这样,就可以按照服务器上的文件名,自动存在本地了!
再来一个更好用的。
如果screen1.JPG以外还有screen2.JPG、screen3.JPG、....、screen10.JPG需要下载,难不成还要让我们写一个script来完成这些操作?
不干!
在curl里面,这么写就可以了:
$ curl -O http://cgi2.tky.3web.ne.jp/~zzh/screen[1-10].JPG
呵呵呵,厉害吧?! ~
9)再来,我们继续讲解下载!
$ curl -O http://cgi2.tky.3web.ne.jp/~{zzh,nick}/[001-201].JPG
这样产生的下载,就是
~zzh/001.JPG
~zzh/002.JPG
...
~zzh/201.JPG
~nick/001.JPG
~nick/002.JPG
...
~nick/201.JPG
够方便的了吧?哈哈哈
咦?高兴得太早了。
由于zzh/nick下的文件名都是001,002...,201,下载下来的文件重名,后面的把前面的文件都给覆盖掉了 ~
没关系,我们还有更狠的!
$ curl -o #2_#1.jpg http://cgi2.tky.3web.ne.jp/~{zzh,nick}/[001-201].JPG
—这是.....自定义文件名的下载? —对头,呵呵!
这样,自定义出来下载下来的文件名,就变成了这样:原来: ~zzh/001.JPG —-> 下载后: 001-zzh.JPG 原来: ~nick/001.JPG —-> 下载后: 001-nick.JPG
这样一来,就不怕文件重名啦
发表评论
-
Git ignore of xcode
2013-05-14 14:50 779#OS junk files [Tt]humbs.db ... -
Git 教程
2013-05-08 18:38 551书籍Pro Git。 Githug通关攻略 http://l ... -
mar 工具
2012-07-17 14:47 650Dash mac OmniGraffle Pro 5.4 ... -
SVN
2012-05-30 09:53 394SVN 基线 svn与git命令对照表:http://che ... -
mac software
2012-05-16 11:17 484文本工具:TextWrangler chm工具:CHM Vi ... -
VBox Mac
2011-10-27 23:48 1294蚕妇 [宋] 张俞 昨日入城市, 归来 ... -
git简单使用
2011-05-26 11:17 597http://www.cnblogs.com/shanyou/ ... -
Code::Blocks使用
2011-05-18 13:08 616http://lavasoft.blog.51cto.com/ ... -
MinGW和CygWin
2011-03-23 17:32 722http://hi.baidu.com/hyaloid/blo ... -
VBox的网络介绍
2011-02-26 15:32 985http://blog.mcuol.com/User/xiao ... -
Virtual常用
2011-02-25 14:12 723http://blogold.chinaunix.net/u2 ... -
memcached
2010-11-02 17:03 1460Memcached 是一个高性能的分布式内存对象缓存系统,用 ... -
UML
2010-09-27 18:04 589http://blog.csdn.net/sfdev/arch ... -
各语言的注释符一览
2010-08-17 11:28 854http://pengshaosheng2009.blog.1 ... -
数据恢复工具
2010-08-12 15:24 802习惯性Shift+Delete的朋友注意啦,别毛手毛脚的。 ... -
Vim 一些技巧
2010-08-09 11:49 75查找: Shift + # 查找当前字符串 /flw ... -
Windows上配置Code::Blocks + wxWidgets
2010-08-01 11:50 1510http://apps.hi.baidu.com/share/ ... -
Eclipse+WxWidgets开发环境搭配
2010-08-01 11:48 1089http://www.cppblog.com/zyzx/arc ... -
Source Insight 经典教程
2010-07-16 18:14 1412copy:http://hi.baidu.com/yaofly ... -
SlickEdit
2010-07-12 11:14 1370http://blog.csdn.net/keensword0 ...
相关推荐
以下是对cURL常用命令的详细解释: 1. **下载单个文件** 默认情况下,`curl`命令会将下载内容输出到标准输出(STDOUT)。例如: ``` curl http://www.centos.org ``` 2. **保存文件到本地** - `-o` 选项用于...
**三、Curl常用命令和选项** 1. `-L` 或 `--location`:自动处理重定向。 2. `-X` 或 `--request`:指定HTTP请求方法,如`-X POST`。 3. `-d` 或 `--data`:发送POST数据,如`-d "key=value"`。 4. `-H` 或 `--...
2. **CURL常用选项** - **CURLOPT_URL**:设置要访问的URL。 - **CURLOPT_RETURNTRANSFER**:是否将结果返回为字符串,而非直接输出。 - **CURLOPT_POST**:设置为true进行POST请求。 - **CURLOPT_POSTFIELDS**...
`curl_init()`初始化cURL会话,`curl_setopt()`设置选项,如URL、是否包含头信息和是否返回结果而不是直接输出。`curl_exec()`执行请求,最后`curl_close()`关闭cURL会话。 ```php $ch = curl_init(); curl_setopt...
四、curl常用命令与选项 1. 基本用法:curl [URL],例如"curl https://www.google.com"将下载Google首页的HTML内容。 2. -L选项:跟随重定向,例如"curl -L https://github.com"。 3. -O选项:保存远程文件,例如...
2. Curl常用参数详解: - `-I`:只显示HTTP响应的头部信息,不获取实际内容。 - `-d`:使用HTTP POST方法传递数据,可以是JSON格式或其他形式。 - `-o`:将输出写入指定文件,而不是在终端上显示。 - `-s`:静默...
实现了curl常用的post请求,上传,获取验证码,下载图片操作的封装
本文将详细讲解PHP中的cURL类及其常用方法,如何封装和使用,以及如何处理登录、获取Cookie、模拟提交数据等任务。 首先,让我们了解什么是cURL。cURL(Client URL Library)是一个库,它提供了在命令行或编程语言...
curl 命令提供了许多选项,以下是一些常用的选项: * `-1, --tlsv1`:强制 curl 使用 TLS 1.x 版本。 * `-2, --sslv2`:强制 curl 使用 TLS 2 版本。 * `-3, --sslv3`:强制 curl 使用 TLS 3 版本。 * `-4, --ipv4`...
分享一个php中curl类, 设置Cookie文件保存路径及文件名,模拟登录获取Cookie函数 , 模拟获取内容函数,模拟提交数据函数,php中curl类常用方法封装和详解
这个过程可能涉及到了交叉编译,因为Android使用的是基于Linux的系统,但其架构与常见的Linux桌面环境不同,需要针对ARM处理器(armeabi-v7a和armeabi是Android设备常用的两种CPU架构)进行编译。编译完成后,生成了...
### 常用命令和选项 1. **基本请求**:`curl [URL]`,这将简单地获取指定URL的内容。 2. **POST请求**:`curl -d "key=value" [URL]`,将数据`key=value`发送到服务器。 3. **头信息**:`curl -H "Header: value" ...
3. **常用选项**: - `-L`:跟随重定向,如果服务器返回重定向,curl会自动处理。 - `-O`:保存远程文件到本地,文件名默认为URL的最后一部分。 - `-o`:指定本地保存文件名。 - `-d`/`--data`:POST数据,常...
您可能感兴趣的文章:Linux 中 CURL常用命令详解linux下为php添加curl扩展的方法Linux下命令行cURL的10种常见用法示例linux curl命令详解及实例分享Linux中curl命令和wget命令的使用介绍与比较linux shell中curl ...
- **网络通信**:curl库和工具支持多种网络协议,如HTTP/HTTPS、FTP/FTPS、SMTP等,是进行网络通信的常用工具。 - **嵌入式开发**:在ARM架构的Linux系统中,预编译的curl常用于物联网、嵌入式设备等场景,进行数据...
curl是Charles Schmitt在1998年创建的,至今已成为开发者和系统管理员的常用工具,广泛用于自动化脚本、下载文件、测试API接口等工作。 curl库支持多种协议: 1. HTTP/1.x 和 HTTP/2:能够执行GET、POST、PUT、...
**curl for Windows** `curl` 是一个开源的命令行工具,用于传输数据到或从URL。它支持多种协议,如HTTP、HTTPS、FTP、FTPS等,是开发者和系统管理员在处理网络请求时的常用工具。在Windows操作系统上,`curl` 的...
Openssl是一个开源的加密库,提供了各种安全协议的支持,如SSLv3、TLSv1、TLSv1.1、TLSv1.2等,以及常用的加密算法,如RSA、AES、MD5等。在curl中使用Openssl,可以确保通过HTTPS等安全协议进行的数据传输过程是加密...