找回密码
 加入怎通
查看: 152|回复: 0

linux下最全curl命令使用方式学习和拓展(linux中curl命令)

[复制链接]
我来看看 发表于 2023-03-21 23:14:25 | 显示全部楼层 |阅读模式
' l" ]2 U2 y1 X: {3 ^, ?

为什么要使用curl命令?curl命令可以帮助我们在linux服务内部通讯,排查接口是否能够正确调用,外网的接口是否有防火墙限制,内网的请求可以快速帮我们获取接口参数返回,并且调试程序代码,在局域网,或者内网的时候只能在内网调试,这个时候curl命令足以支持我们完成所有调试和测试。

+ |8 ?' E2 J# |: z g

curl 能做什么?这是官网的介绍:记住学习一个技术一定要看官网的文档和介绍,不要一上手就去百度,百度只会让你成为一个基础的代码搬运工,要养成去官网看文档的习惯curl官网:https://curl.se/docs/httpscripting.html。

0 T6 S0 P$ j% c8 V

下面引用下官网的脚本介绍和使用:使用 Curl 编写 HTTP 请求脚本的艺术背景本文档假定您熟悉 HTML 和一般网络越来越多的应用程序迁移到 Web 使得“HTTP 脚本”的请求和需求更加频繁能够自动从网络中提取信息、伪造用户、向网络服务器发布或上传数据都是当今重要的任务。

+ o6 i* @6 _: w! z

Curl 是一个用于执行各种 URL 操作和传输的命令行工具,但本文档将重点介绍如何在执行 HTTP 请求时使用它以获取乐趣和利润我将假设您知道如何调用curl --help或curl --manual获取有关它的基本信息。

* }& |! R/ r2 P6 h7 D, t

Curl 并不是为你做所有事情它发出请求,获取数据,发送数据并检索信息您可能需要使用某种脚本语言或重复的手动调用将所有内容粘合在一起HTTP 协议HTTP 是用于从 Web 服务器获取数据的协议它是一个建立在 TCP/IP 之上的简单协议。

% I- _2 {( X' e3 s: u

该协议还允许使用几种不同的方法将信息从客户端发送到服务器,如下所示HTTP 是由客户端发送到服务器以请求特定操作的纯 ASCII 文本行,然后服务器在实际请求的内容发送到客户端之前回复几行文本客户端 curl 发送一个 HTTP 请求。

* E S; r; n; i" t* Q1 ^4 }9 V

请求包含一个方法(如 GET、POST、HEAD 等)、许多请求标头,有时还包含一个请求正文HTTP 服务器以状态行(指示事情是否顺利)、响应标头以及最常见的响应正文进行响应“body”部分是您请求的纯数据,例如实际的 HTML 或图像等。

* s' Z1 J. Q4 M% ^/ V& K

见协议使用 curl 的选项--verbose(-v作为一个简短的选项)将显示 curl 发送到服务器的命令类型,以及一些其他信息文本--verbose是调试甚至理解 curl 服务器交互是最有用的选项。

2 e3 Y# @+ V) X' D; C

有时甚至--verbose是不够的然后提供更多细节,因为它们显示了--tracecurl发送和接收的所有内容像这样使用它:--trace-asciicurl --trace-ascii debugdump.txt http://www.example.com/。

7 @) \3 k2 i, R5 r" q# S

看时间很多时候,您可能想知道到底是什么时间,或者您只想知道传输中两点之间的毫秒数对于这些情况以及其他类似情况,--trace-time您需要选择该选项它会将时间添加到每个跟踪输出行:curl --trace-ascii d.txt --trace-time http://example.com/。

' |# p$ z& F4 g) ]7 W: C: v

查看响应默认情况下 curl 将响应发送到标准输出您需要将其重定向到某个地方以避免这种情况,通常是使用 -oor完成的-O网址规格统一资源定位符格式是您指定 Internet 上特定资源地址的方式你知道这些,你已经看过像https://curl.se或https://yourbank.com这样的 URL一百万次。

; Y( n; p( |; {8 O0 t4 N

RFC 3986 是规范规范是的,正式名称不是 URL,而是 URI主持人主机名通常使用 DNS 或 /etc/hosts 文件解析为 IP 地址,这就是 curl 将与之通信的内容或者,您可以直接在 URL 中指定 IP 地址而不是名称。

) A) d/ n( |) D/ y% o5 m+ I% Q

对于开发和其他尝试情况,您可以使用 curl 的--resolve选项为主机名指向不同的 IP 地址,而不是其他情况下使用的 IP 地址:curl --resolve www.example.org:80:127.0.0.1 http://www.example.org/

) H5 M6 r4 v" P

端口号curl 支持的每个协议都在默认端口号上运行,无论是通过 TCP 还是在某些情况下是 UDP通常您不必考虑这一点,但有时您会在其他端口或类似端口上运行测试服务器然后,您可以在 URL 中使用冒号和紧跟主机名的数字指定端口号。

- m& m. ?6 x+ j3 a

就像对端口 1234 执行 HTTP 时一样:curl http://www.example.org:1234/您在 URL 中指定的端口号是服务器用来提供其服务的端口号有时您可能会使用代理,然后您可能需要将代理的端口号与 curl 连接到服务器所需的端口号分开。

! S3 `) ^ u Y

就像在端口 4321 上使用 HTTP 代理一样:curl --proxy http://proxy.example.org:4321 http://remote.example.org/用户名和密码某些服务设置为需要 HTTP 身份验证,然后您需要提供名称和密码,然后根据使用的确切身份验证协议以各种方式将其传输到远程站点。

% [' k* w6 b% z- |6 t& z) q

您可以选择在 URL 中插入用户名和密码,也可以单独提供:curl http://user:password@example.org/或者curl -u user:password http://example.org/

4 G5 z0 B: U7 u1 M4 R% \- `/ U9 A2 m

您需要注意的是,这种 HTTP 身份验证并不是当今面向用户的网站通常所做的和要求的他们倾向于使用表格和cookies路径部分路径部分只是被发送到服务器以请求它发回相关的响应路径是在主机名和可能的端口号后面的斜杠右侧的内容。

" o' y v) L( h6 `

获取页面得到使用 HTTP 进行的最简单和最常见的请求/操作是获取 URLURL 本身可以引用网页、图像或文件客户端向服务器发出 GET 请求并接收它请求的文档如果您发出命令行curl https://curl.se。

9 M& K% t* W V' a; |6 [

您会在终端窗口中返回一个网页该 URL 包含的整个 HTML 文档所有 HTTP 回复都包含一组通常隐藏的响应头,使用 curl 的--include( -i) 选项来显示它们以及文档的其余部分头--head您可以使用( ) 选项仅向远程服务器询问标头,-I这将使 curl 发出 HEAD 请求。

6 T6 ` D$ b% }. o6 F7 C/ l7 D, e

在某些特殊情况下,服务器拒绝 HEAD 方法,而另一些仍然有效,这是一种特殊的烦恼HEAD 方法的定义和制作使得服务器返回的标题与它对 GET 所做的完全一样,但没有正文这意味着您可能会Content-Length:在响应标头中看到 a,但在 HEAD 响应中不能有实际的正文。

9 r1 Q; D1 d& ?# k, _1 E) u

单个命令行中的多个 URL单个 curl 命令行可能涉及一个或多个 URL最常见的情况可能是只使用一个,但您可以指定任意数量的 URL是的,任何无限然后,您将收到针对所有给定 URL 的重复请求例如,发送两个 GET:

8 A- n3 M I# k) `2 k

curl http://url1.example.com http://url2.example.com如果您使用--dataPOST 到 URL,则使用多个 URL 意味着您将相同的 POST 发送到所有给定的 URL。

3 h1 f7 G z! l( f2 ?4 K

例如,发送两个 POST:curl --data name=curl http://url1.example.com http://url2.example.com单个命令行中的多个 HTTP 方法有时您需要在一个命令行中对多个 URL 进行操作,并对每个 URL 执行不同的 HTTP 方法。

# g. m+ G0 M$ z& P% P

为此,您将享受该--next选项它基本上是一个分隔符,将一堆选项与下一个选项分开之前的所有 URL--next都将获得相同的方法,并将所有 POST 数据合并为一个当 curl--next在命令行上到达时,它将重置方法和 POST 数据并允许新的设置。

* w# J4 Y! m3 l0 M$ _

也许最好用几个例子来说明这一点要先发送一个 HEAD,然后再发送一个 GET:curl -I http://example.com --next http://example.com要先发送 POST,然后再发送 GET:。

- @" U- T3 }; H( V$ L3 L: V

curl -d score=10 http://example.com/post.cgi --next http://example.com/results.htmlHTML 表单表格解释表单是网站呈现 HTML 页面的一般方式,其中包含供用户输入数据的字段,然后按某种“确定”或“提交”按钮将该数据发送到服务器。

( G+ s9 o% s) R9 P2 l5 I3 C' {

然后服务器通常使用发布的数据来决定如何行动就像使用输入的词在数据库中搜索,或在错误跟踪系统中添加信息,在地图上显示输入的地址或使用信息作为登录提示验证用户是否可以查看它的内容查看当然,服务器端必须有某种程序来接收您发送的数据。

) Z! }. d0 c1 D$ g) Y

你不能凭空发明一些东西得到GET-form 使用 GET 方法,如 HTML 中指定的那样:

* Q% r R* l# M: q$ h3 u/ z% E

在您喜欢的浏览器中,此表单将显示一个文本框以供填写,并带有一个标有“确定”的按钮如果您填写“1905”并按 OK 按钮,您的浏览器将创建一个新的 URL 来为您获取该 URL 将junk.cgi?birthyear=1905&press=OK附加到前一个 URL 的路径部分。

) w! h* O6 D9 H

如果在页面上看到原始表单www.example.com/when/birth.html,您将获得的第二页将变为www.example.com/when/junk.cgi?birthyear=1905&press=OK。

% d% T# g7 r W; w) @7 i$ L

大多数搜索引擎都是这样工作的要让 curl 为您发送 GET 表单,只需输入预期的创建 URL:curl "http://www.example.com/when/junk.cgi?birthyear=1905&press=OK"。

+ { K R% T1 U

邮政GET 方法使所有输入字段名称都显示在浏览器的 URL 字段中当您希望能够使用给定数据为该页面添加书签时,这通常是一件好事,但如果您在其中一个字段中输入了秘密信息,或者如果有大量字段创建了一个长且不可读的网址。

8 P! Y- k" E4 X8 f1 i

然后 HTTP 协议提供 POST 方法这样,客户端发送的数据与 URL 分开,因此您不会在 URL 地址字段中看到任何数据该表单看起来与前一个类似:

- K5 V- j2 U1 F

并且要使用 curl 来发布此表单,并填写与以前相同的数据,我们可以这样做:curl --data "birthyear=1905&press=%20OK%20" http://www.example.com/when/junk.cgi

" K; N6 s5 ~; _ ]; B& D. C

这种 POST 将使用 Content-Typeapplication/x-www-form-urlencoded并且是使用最广泛的 POST 类型您发送到服务器的数据必须已经正确编码,curl 不会为您这样做。

: `* H- }/ q0 P! T$ a9 D' a

例如,如果您希望数据包含一个空格,则需要将该空格替换为%20等不遵守此规定很可能会导致您的数据被错误接收并弄乱最近的 curl 版本实际上可以为您对 POST 数据进行 url 编码,如下所示:curl --data-urlencode "name=I am Daniel" http://www.example.com

" c% F0 ?( _' j4 e& D1 ]' x+ Y

如果您--data在命令行上重复多次,curl 将连接所有给定的数据段 - 并&在每个数据段之间放置一个符号文件上传 POST早在 1995 年末,他们就定义了另一种通过 HTTP 发布数据的方式它记录在 RFC 1867 中,为什么这种方法有时被称为 RFC1867-posting。

6 A+ Z# W( l3 Q- h6 W. m' \8 p

该方法主要是为了更好地支持文件上传而设计的允许用户上传文件的表单可以用 HTML 编写如下:

) \2 V3 L% Q# i$ J$ s7 o

这清楚地表明即将发送的 Content-Type 是multipart/form-data.

7 x2 T; Z' y% y7 m3 `

要使用 curl 发布到这样的表单,请输入如下命令行:curl --form upload=@localfilename --form press=OK [URL]隐藏字段基于 HTML 的应用程序在页面之间传递状态信息的常用方法是向表单添加隐藏字段。

* ?+ a7 c1 Y9 _4 Z( f( t* v

隐藏字段已经填写,它们不会显示给用户,它们会像所有其他字段一样被传递具有一个可见字段、一个隐藏字段和一个提交按钮的类似示例表单可能如下所示:

3 g; N8 F! b( w0 @. j

要使用 curl 发布此内容,您无需考虑字段是否隐藏卷曲它们都是一样的:curl --data "birthyear=1905&press=OK&person=daniel" [URL]。

, w5 N) O7 m8 |* D

弄清楚 POST 的样子当您要填写表单并使用 curl 而不是浏览器将其发送到服务器时,您当然有兴趣完全按照浏览器的方式发送 POST一个简单的查看方法是将带有表单的 HTML 页面保存在本地磁盘上,将“方法”修改为 GET,然后按提交按钮(如果需要,您也可以更改操作 URL) .。

# V, R: h$ s) o: s" }! g

然后,您将清楚地看到数据被附加到 URL 中,并用 -?字母分隔,因为 GET 表单应该如此HTTP 上传放也许将数据上传到 HTTP 服务器的最佳方式是使用 PUT话又说回来,这当然需要有人在知道如何接收 HTTP PUT 流的服务器端放置一个程序或脚本。

1 J r% W( x; m+ z. v& t! ]

使用 curl 将文件放入 HTTP 服务器:curl --upload-file uploadfile http://www.example.com/receive.cgiHTTP 身份验证基本认证HTTP 身份验证能够告诉服务器您的用户名和密码,以便它可以验证您是否被允许执行您正在执行的请求。

& K6 |9 {4 W4 Z0 g* K+ E$ I% x

HTTP 中使用的基本身份验证(默认情况下 curl 使用的类型)是基于纯文本的,这意味着它发送的用户名和密码只是稍微混淆,但仍然可以被任何在你和远程服务器之间的网络上嗅探的人完全读取告诉 curl 使用用户和密码进行身份验证:

( t' f$ B, n6 b3 t3 V" A4 o9 X5 N

curl --user name:password http://www.example.com其他认证该站点可能需要不同的身份验证方法(检查服务器返回的标头),然后--ntlm, --digest,--negotiate甚至--anyauth可能是适合您的选项。

2 u7 c8 K! u) @: @4 ?2 a! ]; ~# \

代理身份验证有时您的 HTTP 访问只能通过使用 HTTP 代理获得这似乎在各个公司中尤为常见HTTP 代理可能需要自己的用户名和密码才能允许客户端访问 Internet要使用 curl 指定那些,请运行以下命令:。

. B! d; h, \% R) w: U: M* I9 l) ]

curl --proxy-user proxyuser:proxypassword curl.se如果您的代理需要使用 NTLM 方法完成身份验证,请使用--proxy-ntlm,如果它需要 Digest 使用--proxy-digest。

7 o9 @% R' M$ C3 O/ S

如果您使用这些用户+密码选项中的任何一个,但省略了密码部分,curl 将交互提示输入密码隐藏凭据请注意,当程序运行时,在列出系统正在运行的进程时,可能会看到它的参数因此,如果您将密码作为纯命令行选项传递,其他用户可能会看到您的密码。

7 Y9 a, D2 i' d+ m6 ]% \$ F! u

有办法规避这一点值得注意的是,虽然这是 HTTP 身份验证的工作方式,但许多网站在提供登录等时不会使用此概念有关详细信息,请参阅下面的 Web 登录章节更多 HTTP 标头推荐人HTTP 请求可能包含一个“referer”字段(是的,它拼写错误),可用于判断客户端从哪个 URL 获取到该特定资源。

W9 R2 q) m5 Z1 g4 d1 Q, `9 Q

一些程序/脚本会检查请求的引用字段,以验证这不是来自外部站点或未知页面虽然这是一种检查容易伪造的东西的愚蠢方法,但许多脚本仍然这样做使用 curl,您可以在引用字段中放入任何您想要的内容,从而更容易欺骗服务器为您的请求提供服务。

3 b0 b' i/ ^7 w! ?

使用 curl 设置引用字段:curl --referer http://www.example.come http://www.example.com用户代理与referer 字段类似,所有HTTP 请求都可以设置User-Agent 字段。

4 {* j9 `* K$ q

它命名正在使用的用户代理(客户端)许多应用程序使用此信息来决定如何显示页面愚蠢的网络程序员试图为不同浏览器的用户制作不同的页面,以使它们看起来最适合他们的特定浏览器他们通常也做不同类型的 JavaScript、VBScript 等。

0 C5 U; _0 \1 L! I* R( ]5 x/ G3 e8 d: v

有时,您会看到使用 curl 获取页面不会返回您在使用浏览器获取页面时看到的相同页面然后你知道是时候设置用户代理字段来欺骗服务器,让服务器认为你是那些浏览器之一要使 curl 在 Windows 2000 机器上看起来像 Internet Explorer 5:。

" H6 @3 G* g4 K. R1 X8 g

curl --user-agent "Mozilla/4.0 (compatible; MSIE 5.01; Windows NT 5.0)" [URL]或者为什么不看起来像在旧的 Linux 机器上使用 Netscape 4.73:

5 y& @. |1 w) s: y" A# e

curl --user-agent "Mozilla/4.73 [en] (X11; U; Linux 2.2.15 i686)" [URL]重定向位置标头当从服务器请求资源时,来自服务器的回复可能包括关于浏览器下一步应该去哪里找到该页面的提示,或者一个新页面保留新生成的输出。

3 `6 N) q0 W$ _# O: c

告诉浏览器重定向的标头是Location:.默认情况下, Curl 不跟随Location:标头,而是以与显示所有 HTTP 回复相同的方式简单地显示此类页面但是,它确实具有一个选项,可以使它尝试跟随Location:指针。

4 ?6 O; [! w: w

告诉 curl 跟随一个位置:curl --location http://www.example.com如果您使用 curl 发布到一个立即将您重定向到另一个页面的站点,您可以安全地使用--location( -L) 和--data/--form一起。

& ^+ _2 ~8 _* B% t( f

Curl 只会在第一个请求中使用 POST,然后在以下操作中恢复为 GET其他重定向浏览器通常支持至少两种 curl 不支持的其他重定向方式:首先,html 可能包含一个元刷新标签,要求浏览器在设定的秒数后加载特定的 URL,或者它可能使用 JavaScript 来完成。

0 {- C9 B& @) ?. W/ o$ ?0 H

饼干饼干基础Web 浏览器执行“客户端状态控制”的方式是使用 cookieCookie 只是带有相关内容的名称cookie 由服务器发送给客户端服务器告诉客户端它想要返回 cookie 的路径和主机名,它还发送一个过期日期和更多属性。

) c9 v( ~! x% P

当客户端使用先前在接收到的 cookie 中指定的名称和路径与服务器通信时,客户端将 cookie 及其内容发送回服务器,当然除非它们已过期许多应用程序和服务器使用此方法将一系列请求连接到单个逻辑会话中。

3 l; e7 y9 q9 t9 H( ?

为了能够在这种情况下使用 curl,我们必须能够以 Web 应用程序期望的方式记录和发送回 cookie浏览器处理它们的方式相同饼干选项使用 curl 获取页面时向服务器发送一些 cookie 的最简单方法是在命令行中添加它们,例如:

( \& ~! C4 A5 c8 p' p2 @- ^

curl --cookie "name=Daniel" http://www.example.comCookies 作为常见的 HTTP 标头发送这是实用的,因为它允许 curl 仅通过记录标题来记录 cookie。

5 ~" L0 \" R }

使用--dump-header( -D) 选项使用 curl 记录 cookie,例如:curl --dump-header headers_and_cookies http://www.example.com

) X4 G. j, k u; ?

(请注意,--cookie-jar下面描述的选项是存储 cookie 的更好方法)如果您想重新连接到服务器并使用从先前连接中存储的 cookie(或手动制作以欺骗服务器相信您有先前的连接,Curl 内置了一个完整的 cookie 解析引擎,则可以使用该引擎)。

' \3 ?% E, E ~- n

要使用以前存储的 cookie,您可以运行 curl,如下所示:curl --cookie stored_cookies_in_file http://www.example.com--cookie当您使用该选项时,Curl 的“cookie 引擎”将被启用。

# S4 u% f' M& J: F

如果您只想让 curl 了解收到的 cookie,请使用--cookie不存在的文件例如,如果你想让 curl 理解来自页面的 cookie 并跟踪一个位置(因此可能会发回它收到的 cookie),你可以像这样调用它:。

% }, t7 ~* G2 o8 G& V

curl --cookie nada --location http://www.example.comCurl 能够读取和写入使用 Netscape 和 Mozilla 曾经使用的相同文件格式的 cookie 文件。

' A. N8 p+ c1 v$ r: `9 m. D& a

这是在脚本或调用之间共享 cookie 的便捷方式( --cookie)-b开关自动检测给定文件是否是这样的 cookie 文件并对其进行解析,并且通过使用--cookie-jar( -c) 选项,您将使 curl 在操作结束时写入一个新的 cookie 文件:。

B, a$ h8 u7 U7 O6 X

curl --cookie cookies.txt --cookie-jar newcookies.txt http://www.example.comHTTPSHTTPS 是 HTTP 安全的有几种方法可以进行安全的 HTTP 传输。

6 D- F! k7 I+ V2 f* Q0 ]; g

到目前为止,最常用的协议是通常称为 HTTPS、HTTP over SSL 的协议SSL 对通过网络发送和接收的所有数据进行加密,从而使攻击者更难窥探敏感信息SSL(或称为该标准的最新版本的 TLS)提供了大量高级功能,以允许加密 HTTP 所需的所有加密和关键基础设施机制。

: _7 z% ^& p- p/ f

当构建使用 TLS 库时,Curl 支持加密提取,并且可以构建它以使用相当大的一组库中的curl -V一个 - 将显示您的 curl 是为使用哪个库而构建的(如果有的话!)要从 HTTPS 服务器获取页面,只需运行 curl,如下所示:。

! F" L4 y/ R/ q N7 W1 @: }1 J. \

curl https://secure.example.com证书在 HTTPS 世界中,您使用证书来验证您是您声称的那个人,作为普通密码的补充Curl 支持客户端证书所有证书都使用密码锁定,您需要输入密码才能让 curl 使用证书。

) v+ s8 t1 N& S) K) Q/ c0 V

密码短语可以在命令行中指定,如果没有,则在 curl 查询时以交互方式输入在 HTTPS 服务器上使用带有 curl 的证书,例如:curl --cert mycert.pem https://secure.example.com

. f/ _" [ ~) T: h4 {( ~: u& A( k

curl 还尝试通过根据本地存储的 CA 证书包验证服务器的证书来验证服务器是否是它声称的身份验证失败将导致 curl 拒绝连接然后您必须使用--insecure( -k) 以防您想告诉 curl 忽略无法验证服务器。

" `/ Q- u8 G# L6 D/ L0 t6 ^6 B- I

有关服务器证书验证和 ca 证书捆绑的更多信息,请参阅SSLCERTS 文档有时您可能会得到自己的 CA 证书存储,然后您可以告诉 curl 使用它来验证服务器的证书:curl --cacert ca-bundle.pem https://example.com/。

; r+ ~3 K n7 n/ ` D9 A

自定义请求元素修改方法和标头做一些花哨的事情,您可能需要添加或更改单个 curl 请求的元素例如,您可以将 POST 请求更改为 PROPFIND 并将数据发送为Content-Type: text/xml(而不是默认的 Content-Type),如下所示:。

+ [# K- n* h) H0 \& O, A* Y! f

curl --data "" --header "Content-Type: text/xml" --request PROPFIND example.com您可以通过提供没有内容的默认标题来删除默认标题。

. @4 Y0 p6 _- p! `+ c" z4 w* N

就像您可以通过切断 Host: 标头来破坏请求一样:curl --header "Host:" http://www.example.com您可以以相同的方式添加标题您的服务器可能需要一个Destination:标头,您可以添加它:。

- F) e# L" ?' `7 J0 K* J

curl --header "Destination: http://nowhere" http://example.com更多关于改变方法需要注意的是,curl 根据请求的操作自行选择使用哪些方法-d会做 POST,-I会做 HEAD 等等。

0 K( h/ O7 a; C- N, h

如果使用--request/-X选项,您可以更改 curl 选择的方法关键字,但不会修改 curl 的行为这意味着如果您例如使用 -d "data" 进行 POST,您可以将方法修改为PROPFINDwith-X并且 curl 仍会认为它发送 POST 。

4 ?; M7 ?; ?) g6 l/ z

-X POST您可以通过简单地添加如下命令行将普通 GET 更改为 POST 方法:curl -X POST http://example.org/...但是 curl 仍然会像发送 GET 一样思考和行动,因此它不会发送任何请求正文等。

5 T1 Z* A) s n) j( b. M

网页登录一些登录技巧虽然不仅仅是与 HTTP 相关,但它仍然会给很多人带来问题,所以这里是关于绝大多数登录表单如何工作以及如何使用 curl 登录到它们的执行概要还可以注意到,要以自动化方式正确执行此操作,您肯定需要编写脚本并执行多个 curl 调用等。

8 M: o: _7 _0 J# a

首先,服务器主要使用 cookie 来跟踪客户端的登录状态,因此您需要捕获在响应中收到的 cookie然后,许多网站还在登录页面上设置了一个特殊的 cookie(以确保您通过他们的登录页面到达那里),因此您应该养成首先获取登录表单页面以捕获那里设置的 cookie 的习惯。

' d; m2 Z* @& O& ?) V

一些基于 Web 的登录系统具有不同数量的 JavaScript,有时它们使用此类代码来设置或修改 cookie 内容可能他们这样做是为了防止编程登录,就像本手册描述了如何......无论如何,如果阅读代码不足以让您手动重复该行为,那么捕获浏览器完成的 HTTP 请求并分析发送的 cookie 通常是一种工作方法,用于解决如何缩短 JavaScript 所需的时间。

) V6 Y, ^% K# p& h7 @0 H; {

在登录的实际标签中,许多网站填写随机/会话或其他秘密生成的隐藏标签,您可能需要先捕获登录表单的 HTML 代码并提取所有隐藏字段才能正确执行登录 POST请记住,在普通 POST 中发送时,内容需要进行 URL 编码。

6 c! T' N& X, G0 n* c

调试一些调试技巧很多时候,当您在站点上运行 curl 时,您会注意到该站点对您的 curl 请求的响应方式似乎与它对浏览器的响应方式不同然后你需要开始让你的 curl 请求更类似于浏览器的请求:使用该--trace-ascii选项来存储请求的完整详细日志,以便于分析和更好地理解。

. q' I$ g: d* b* M6 K Q7 x! l

确保在需要时检查并使用 cookie(阅读--cookie和写作--cookie-jar)将 user-agent (with -A) 设置为一个,就像最近流行的浏览器一样-E像浏览器设置的那样设置引用者(带)

, W4 q6 x1 k& |' M' V$ W4 ]

如果您使用 POST,请确保以与浏览器相同的顺序发送所有字段检查浏览器的功能确保您正确执行此操作的一个好帮手是 Web 浏览器的开发人员工具,可让您查看您发送和接收的所有标头(即使使用 HTTPS)更原始的方法是使用 Wireshark 或 tcpdump 等工具捕获网络上的 HTTP 流量,并检查浏览器发送和接收的标头。

9 B- J5 j- N( g! H0 [

(HTTPS 强制您使用它SSLKEYLOGFILE来执行此操作)参数帮助命令:[root@master ~]# curl -h4 T( M; X. c& ^# E5 Q+ Q & n, m8 w6 R& @/ }( }+ r# D; n Usage: curl [options...] . f9 h9 d2 I' ~% y- b1 f% i 8 W8 V8 n1 w0 y, p Options: (H) means HTTP/HTTPS only, (F) means FTP only * i- b( v" J1 ]+ P' _' ? / t" D% n2 O, j/ B* F& X2 t

+ y) ?) o# N7 ~' S

--anyauth Pick "any" authentication method (H) ' E/ M* ` o% X! q5 {/ u7 X+ p4 y+ l- r3 G -a, --append Append to target file when uploading (F/SFTP)

& B& }$ z7 {- `, e. x5 U/ Q

--basic Use HTTP Basic Authentication (H)--cacert FILE CA certificate to verify peer against (SSL)--capath DIR CA directory to verify peer against (SSL)

; f! A, M9 y1 L# g

: x( H0 D# H2 V* p6 S) v" j3 B/ G' x/ b3 h7 a0 c/ C -E, --cert CERT[ASSWD] Client certificate file and password (SSL)--cert-type TYPE Certificate file type (DER/PEM/ENG) (SSL)

$ v9 b7 x0 X) _4 x; j6 G Y6 C+ E

--ciphers LIST SSL ciphers to use (SSL)--compressed Request compressed response (using deflate or gzip)

8 O. o5 ~% y) u* u+ u0 T; N

& t* k: q; W H) d) ?/ C" _ " h7 p, M* Y# \/ a -K, --config FILE Specify which config file to read--connect-timeout SECONDS Maximum time allowed for connection

6 j6 c$ j/ {1 ?

5 s: G! D2 w4 `5 X $ E" o* f( a1 T- I' e -C, --continue-at OFFSET Resumed transfer offset / c& Z) y% x, c. V; M5 z + r9 y5 V, N- F. t/ r0 V -b, --cookie STRING/FILE String or file to read cookies from (H)

. e' T6 ]+ `- Q. M9 v

' s% G* h+ ~2 D9 \) l ; u" R# h5 o, N# ~. U- l8 ^ -c, --cookie-jar FILE Write cookies to this file after operation (H)--create-dirs Create necessary local directory hierarchy

- r9 d/ T) v9 V. I% K3 z: d' ]: J6 Y

--crlf Convert LF to CRLF in upload--crlfile FILE Get a CRL list in PEM format from the given file0 j% f$ D6 O8 K ~2 Q8 i 0 c9 \5 C, I" ~4 o -d,

' B0 J6 S1 q. j9 O

--data DATA HTTP POST data (H)--data-ascii DATA HTTP POST ASCII data (H)--data-binary DATA HTTP POST binary data (H)

% Y6 @- W( ?: z3 g- e; @! O3 e

--data-urlencode DATA HTTP POST data url encoded (H)--delegation STRING GSS-API delegation permission

8 v& l3 q$ Z6 U4 b% W

--digest Use HTTP Digest Authentication (H)--disable-eprt Inhibit using EPRT or LPRT (F)--disable-epsv Inhibit using EPSV (F)

; h* o9 o' I( p/ s* S

4 ?3 v+ G# c7 ~ - M: Z% K5 Y- j -D, --dump-header FILE Write the headers to this file--egd-file FILE EGD socket path for random data (SSL)

! S6 w& u; f9 m* d% ?+ y- i" h

--engine ENGINGE Crypto engine (SSL). "--engine list" for list# w/ ]- g9 V, w& z + F. s: f4 ^# [8 b# x! D' ~ -f, --fail Fail silently (no output at all) on HTTP errors (H)

8 c( D# w2 l" D* X. s

0 d' F N5 c4 j- D3 \6 b % W ~, P2 ~! _' J -F, --form CONTENT Specify HTTP multipart POST data (H)--form-string STRING Specify HTTP multipart POST data (H)

L m( Q& O/ p9 s% F* w

--ftp-account DATA Account data string (F)--ftp-alternative-to-user COMMAND String to replace "USER [name]" (F)

n N6 M& E, i( S8 ?

--ftp-create-dirs Create the remote dirs if not present (F)--ftp-method [MULTICWD/NOCWD/SINGLECWD] Control CWD usage (F)

$ j+ d: ?3 D; y+ D5 k/ y

--ftp-pasv Use PASV/EPSV instead of PORT (F)* ~& O7 b4 V: W5 g9 l$ {. Y5 l$ C 6 c) @/ g% ]+ @0 { -P, --ftp-port ADR Use PORT with given address instead of PASV (F)

" Y y8 P: n, V( O- S

--ftp-skip-pasv-ip Skip the IP address for PASV (F)--ftp-pret Send PRET before PASV (for drftpd) (F)--ftp-ssl-ccc Send CCC after authenticating (F)

! [5 ^' t% w0 t* i" x

--ftp-ssl-ccc-mode ACTIVE/PASSIVE Set CCC mode (F)--ftp-ssl-control Require SSL/TLS for ftp login, clear for transfer (F)

2 Z; b0 T* p) `$ H/ N

6 J2 h; N9 y& d* p; Q& }! e 2 S$ l Y' [7 J" H) N1 m/ h -G, --get Send the -d data with a HTTP GET (H) 2 P+ q- \; A3 |, P8 ]7 z. D3 o5 @8 x: q3 [ -g, --globoff Disable URL sequences and ranges using {} and []

% \5 z' \, h: h3 d& s3 |: ?8 C, Z

. k* a" O' l' j. @- g : p+ T6 {2 W. N* l" b" ]" `6 d! K -H, --header LINE Custom header to pass to server (H)0 M9 ]1 M0 Z# ^9 w 4 S- S$ q! p% s, _: L -I, --head Show document info only1 P' N; P. @- `( I; g; \ 9 \7 G) {* {/ p' k) F. P$ k" M -h, --help This help text

+ C3 I9 J5 o1 a5 A$ Q5 p

--hostpubmd5 MD5 Hex encoded MD5 string of the host public key. (SSH)-0, --http1.0 Use HTTP 1.0 (H)--ignore-content-length Ignore the HTTP Content-Length header

2 h% w. f- h! I; K) h

9 D* Q# L( O. {0 m& h: |* C' G1 n8 A$ N7 b$ @ -i, --include Include protocol headers in the output (H/F) + j" t# j6 G/ Q 5 ]) G. I, k# n6 _ -k, --insecure Allow connections to SSL sites without certs (H)

: r/ S8 |; G2 g8 v2 q) N( } r8 K

--interface INTERFACE Specify network interface/address to use-4, --ipv4 Resolve name to IPv4 address

# \+ p( m7 H$ `, i! n

-6, --ipv6 Resolve name to IPv6 address ) y* O6 ]7 m N2 n7 Z. x( y 9 l: [8 S! q4 [! q, A -j, --junk-session-cookies Ignore session cookies read from file (H)

& H! b+ T" k/ v

--keepalive-time SECONDS Interval between keepalive probes--key KEY Private key file name (SSL/SSH)--key-type TYPE Private key file type (DER/PEM/ENG) (SSL)

6 i- `" B' X& u. W

--krb LEVEL Enable Kerberos with specified security level (F)--libcurl FILE Dump libcurl equivalent code of this command line

' K, x2 ^/ C |5 t$ i0 `: S% w

--limit-rate RATE Limit transfer speed to this rate. o, y# p, y* T8 [. m0 p 9 f" P( F- N; H% x -l, --list-only List only names of an FTP directory (F)

- }$ Z5 V0 U$ m0 g6 P; ]+ m

--local-port RANGE Force use of these local port numbers' |2 f2 r6 {2 ]: Q$ \; ?% f 6 s' u; b/ w# k- U' P -L, --location Follow redirects (H)--location-trusted like --location and send auth to other hosts (H)

I' u# M) ]3 F' p0 i6 j+ T

9 E# X. R* ~2 s! G$ p5 B" @ 1 L9 W0 @1 x$ x -M, --manual Display the full manual--mail-from FROM Mail from this address--mail-rcpt TO Mail to this receiver(s)

1 u# _( A' P. y1 a) M8 [

--mail-auth AUTH Originator address of the original email--max-filesize BYTES Maximum file size to download (H/F)

* v2 F$ e# W7 }: J4 q

--max-redirs NUM Maximum number of redirects allowed (H)' h" H# C+ S/ r% q8 h0 T# T 8 @" V* n, y% Q2 K -m, --max-time SECONDS Maximum time allowed for the transfer

: u3 Z& Z9 ^3 e4 y

--metalink Process given URLs as metalink XML file--negotiate Use HTTP Negotiate Authentication (H)/ E' {3 B- C- ^- k; N# v/ M 6 j% \$ W$ E+ s$ \$ R -n,

6 M. x$ K" d2 ]$ n0 ?& X# J

--netrc Must read .netrc for user name and password--netrc-optional Use either .netrc or URL; overrides -n

! @; r/ f9 d1 s) D" e

--netrc-file FILE Set up the netrc filename to use! A: M; ?( w2 n# j* Z9 V # U t D, W( ?5 ]* i3 ^ -N, --no-buffer Disable buffering of the output stream

; L, ~# }' f0 ~. L

--no-keepalive Disable keepalive use on the connection--no-sessionid Disable SSL session-ID reusing (SSL)

+ W) ^ B; `9 U2 Z H

--noproxy List of hosts which do not use proxy--ntlm Use HTTP NTLM authentication (H)$ w; K' J$ K7 |' h( \# u # }5 z+ D8 R0 z9 f -o, --output FILE Write output to instead of stdout

( m+ p+ a% Z( t7 Z

--pass PASS Pass phrase for the private key (SSL/SSH)--post301 Do not switch to GET after following a 301 redirect (H)

$ O% G) X! R7 y1 b' Y

--post302 Do not switch to GET after following a 302 redirect (H)--post303 Do not switch to GET after following a 303 redirect (H)

8 ?9 l7 ?+ T8 }4 H2 K9 m

2 w" C1 M1 m: R8 S, ` \) h 0 v; {5 N. }& D/ H -#, --progress-bar Display transfer progress as a progress bar--proto PROTOCOLS Enable/disable specified protocols

9 u) G& z5 B M

--proto-redir PROTOCOLS Enable/disable specified protocols on redirect G% @1 u4 S3 `4 P# K ' _/ ~4 ? _$ h# S* U# B. _8 s -x, --proxy [PROTOCOL://]HOST[ORT] Use proxy on given port

9 z6 \- q3 p1 r3 n

--proxy-anyauth Pick "any" proxy authentication method (H)--proxy-basic Use Basic authentication on the proxy (H)

4 M. C! e) j6 ?- N% n6 z

--proxy-digest Use Digest authentication on the proxy (H)--proxy-negotiate Use Negotiate authentication on the proxy (H)

% a% M: l- L8 L4 D3 x

--proxy-ntlm Use NTLM authentication on the proxy (H) ) h3 N" [3 Q* ~4 j( v9 j2 f0 C# f( @/ D/ H0 F -U, --proxy-user USER[ASSWORD] Proxy user and password

r" d' n9 e- H/ p4 i2 Q' q

--proxy1.0 HOST[:PORT] Use HTTP/1.0 proxy on given port5 V; u: g7 b% ], [* _4 L# W! i ; ?' x6 D' X& V/ {, U, k! r+ n/ V -p, --proxytunnel Operate through a HTTP proxy tunnel (using CONNECT)

. p% A) `( ], g4 H8 i9 ^% {% K0 x# S

--pubkey KEY Public key file name (SSH)& M6 o) `1 e5 K: {7 \ * D+ v3 \! B- e+ V. k8 _ -Q, --quote CMD Send command(s) to server before transfer (F/SFTP)

# E9 ~# O1 h: _' B

--random-file FILE File for reading random data from (SSL)# z7 ?& o6 j A3 j( j `; i( q0 R* b9 r5 g, M. O -r, --range RANGE Retrieve only the bytes within a range

) _: C( J/ a) Y& {# B" k

--raw Do HTTP "raw", without any transfer decoding (H)3 Q) O- X+ {8 F5 u. p * V/ T9 z/ K+ F! ~4 {+ t -e, --referer Referer URL (H). `5 O' Z4 k/ j4 ]' y( ` # ^( y4 d* J. u. O -J, --remote-header-name Use the header-provided filename (H)

. z5 O7 _ Y, a) B$ e- a( K, k

% @# O3 T4 p! J1 g1 }3 _0 }, C8 b- J- o1 y3 a& Y9 S$ b }& E -O, --remote-name Write output to a file named as the remote file--remote-name-all Use the remote file name for all URLs

+ {5 m0 T# {7 ^- b+ r8 N+ Y, @

7 @8 z7 `. }. |* R/ K8 O. V. f + O6 q; u/ ?) `- n) u2 d r% s -R, --remote-time Set the remote files time on the local output; ~* k, ? U- @9 s$ P' s # S; g- e6 L8 k% c& y& c/ B5 @. ]4 U -X, --request COMMAND Specify request command to use

+ H2 {5 q1 d' _9 O" s

--resolve HOST:PORT:ADDRESS Force resolve of HOST:PORT to ADDRESS--retry NUM Retry request NUM times if transient problems occur

& z1 Y, E. ~- @5 \ i [& |/ L

--retry-delay SECONDS When retrying, wait this many seconds between each--retry-max-time SECONDS Retry only within this period

6 y3 U; Y" p/ k1 g5 s

! v# q) r* l# w0 E( w6 } 7 V3 V* `. _- @3 j' w -S, --show-error Show error. With -s, make curl show errors when they occur: X- ~7 W5 Q: G8 }9 C5 P4 F 3 z/ ]1 {- l1 e- Z5 s! q -s, --silent Silent mode. Dont output anything

; U2 H* d; m7 e( Z" Y, b

--socks4 HOST[:PORT] SOCKS4 proxy on given host + port--socks4a HOST[:PORT] SOCKS4a proxy on given host + port

4 \/ |! k) }& ~: \5 t0 [! Z2 D

--socks5 HOST[:PORT] SOCKS5 proxy on given host + port--socks5-hostname HOST[:PORT] SOCKS5 proxy, pass host name to proxy

& w7 i0 t% ?' ^

--socks5-gssapi-service NAME SOCKS5 proxy service name for gssapi--socks5-gssapi-nec Compatibility with NEC SOCKS5 server

+ n& a/ h- u' c# H7 p; V7 m' O' c

$ t% S# H% g0 ~( ]8 u% `/ s' ]" ^ + u* q0 f1 ~ I3 m. X -Y, --speed-limit RATE Stop transfers below speed-limit for speed-time secs R* ?/ r+ |, J* G. b) f* t& P- i% ]+ O! j3 S! Q! F; P -y, --speed-time SECONDS Time for trig speed-limit abort. Defaults to 30

/ x8 H6 V, i: r: }! r# ?7 h

--ssl Try SSL/TLS (FTP, IMAP, POP3, SMTP)--ssl-reqd Require SSL/TLS (FTP, IMAP, POP3, SMTP)-2, --sslv2 Use SSLv2 (SSL)

; B) i. J5 K) [

-3, --sslv3 Use SSLv3 (SSL)--ssl-allow-beast Allow security flaw to improve interop (SSL)--stderr FILE Where to redirect stderr. - means stdout

3 B1 s4 d0 T4 \% c6 r; B

--tcp-nodelay Use the TCP_NODELAY option 7 F: k3 Z, ~, `- x ; Y+ Q" a. ]0 `* Y* T -t, --telnet-option OPT=VAL Set telnet option--tftp-blksize VALUE Set TFTP BLKSIZE option (must be >512)

: Q! x8 b) g+ a. i$ [

. L* n c# a$ j " C, W8 o, z( I' K+ K6 a# E -z, --time-cond TIME Transfer based on a time condition-1, --tlsv1 Use => TLSv1 (SSL)--tlsv1.0 Use TLSv1.0 (SSL)

+ ^. Q, N% |' [: U

--tlsv1.1 Use TLSv1.1 (SSL)--tlsv1.2 Use TLSv1.2 (SSL)--trace FILE Write a debug trace to the given file

5 X& P1 m+ F/ t0 x

--trace-ascii FILE Like --trace but without the hex output--trace-time Add time stamps to trace/verbose output

1 D" m- }" j( g5 ]& X

--tr-encoding Request compressed transfer encoding (H) ; W i r' z+ F* f5 \- c& V / ]6 `; f$ O9 M. I" U -T, --upload-file FILE Transfer FILE to destination

- L0 q4 R, n4 [5 i

--url URL URL to work with 2 f, r' }' y: p |6 s ! S# y: H( x9 n5 j0 R/ z" G -B, --use-ascii Use ASCII/text transfer. Y* a' N# [) q8 L, z/ m6 J * B( B! n. I/ i" p, ~" z' { -u, --user USER[:PASSWORD] Server user and password

6 M. X/ n3 C7 r% D' R2 |

--tlsuser USER TLS username--tlspassword STRING TLS password--tlsauthtype STRING TLS authentication type (default SRP)

* t& f ^2 r; l1 i4 P# O/ ?

--unix-socket FILE Connect through this UNIX domain socket3 v! ~4 O1 t5 n2 p) \$ w7 n * h9 x8 ]2 G* O/ X' c: q5 t0 t -A, --user-agent STRING User-Agent to send to server (H)

/ D$ N8 k, L# E0 j) C

' a& a1 l4 y# ~; ^! R' }; q! u% g 8 f8 a( d: n0 M, h8 g# a -v, --verbose Make the operation more talkative % |/ F7 X/ P8 J( A# N) d; S' d: ?5 g/ Q$ U; }6 D$ X -V, --version Show version number and quit ; Q9 f& c5 h9 A7 Z 3 `& @8 t! C9 s5 O -w, --write-out FORMAT What to output after completion

2 b$ F$ O3 N1 u+ P1 t4 ^' S

--xattr Store metadata in extended file attributes ) m' t# F# s8 L1 l( ?/ D1 w) j. ?5 ^( z -q If used as the first parameter disables .curlrc

+ q) k; c! Y3 _" M3 V) R. G; g. Q

curl最全命令使用介绍:https://curl.se/docs/manpage.htmlcurl最全基础教程使用方式:https://curl.se/docs/manual.html常用的4种方式:post ,get,delete.put

\& ?8 A N3 k0 E

curl get方式:curl url 直接访问curl -o url 下载

" p- b1 `- T, ?: A7 C

get 加请求头-X 请求方式-H 请求头-v 显示请求信息-d请求体

* \! {& Z9 ~6 X4 q! H0 S( n. N

curl -X GET -H "Content-type: application/json" -H "Content-Type: application/json" -d {"excelExportColumnList":[{"fieldName":"orderCode","title":"订单号"}],"excelName":"充电订单记录导出.xlsx","queryParams":{"cacheKey":"

- B- W/ a9 D$ s" R/ q! T

cdf8a3da-cf96-4d8b-8001-0e3802a25872"}} "http://*******/api/charge/report/searchChargerOrder"post 方式带token访问(post方式参数和get一样)

4 y7 i0 g3 w/ l

curl -X POST -H Authorization:{{4_5_Fe33QEGRSnh7Taotz4DLscmuNye02f8dyHYj_Jw.jQfVt4l6Xp7yUdtNxqdTpKXNbgUEmezd1zBuRSAK1Iw}} -H Content-Type: application/json -d {"name": "vipTest1"} url

' E8 t3 N) D( \

put请求:服务注册发现用的比较多curl -X PUT -H "Content-Type: application/json" -d {"key1":"value"} "YOUR_URI"delete请求:

# f3 q, o, A' C) {% S

curl -v -X DELETE url看过我自己写的请求,只是基础使用,具体的方式都在curl官网,教程操作文档很全,我介绍了我们常用使用curl的方式,当然还有证书,代理,其他协议的使用,感兴趣的可以自己去官网研究下,curl支持脚本方式调用,不仅仅支持xshell脚本,还有代码。

/ y' }; ?! M. K7 r7 X4 p& H

————没有与生俱来的天赋,都是后天的努力拼搏(我是小杨,谢谢你的关注和支持)

& s7 y; Q$ b* Z; k) D* U$ s 9 X( B6 M5 F* k6 f! c6 m; g% J5 @ 7 ]; F' g6 ^: g8 `% f& Z) c/ o1 l; ~2 N " k9 `8 k' C3 N! U% u! o
回复

使用道具 举报

    您需要登录后才可以回帖 登录 | 加入怎通

    本版积分规则

    QQ|手机版|小黑屋|网站地图|真牛社区 ( 苏ICP备2023040716号-2 )

    GMT+8, 2026-4-4 03:33 , Processed in 0.072290 second(s), 23 queries , Gzip On.

    免责声明:本站信息来自互联网,本站不对其内容真实性负责,如有侵权等情况请联系420897364#qq.com(把#换成@)删除。

    Powered by Discuz! X3.5

    快速回复 返回顶部 返回列表