|
0 c* g7 D9 G! U6 Y- h3 |
在本教程中,我们介绍cURL的基本选项,并通过示例介绍如何使用它们,然后我们开发了一个带有三个端点的Node/Express服务器,以演示如何使用本文介绍的cURL选项对服务器执行cURL的GET/POST请求。
' G# s1 I. m4 ?! l. u9 E9 P. c 与cURL一起使用的选项很多,我们在此介绍的是可用于快速测试API端点的基本选项介绍cURL是一种用于从服务器传输数据或向服务器传输数据的传输工具它支持各种互联网传输协议,包括:DICTFILEFTP, FTPS。 7 n% T, S ^3 B# j9 R4 u8 F
GOPHERHTTP, HTTPSIMAP, IMAPSLDAP, LDAPSPOP3, POP3SRTMP, RTSPSCP, SFTPSMB, SMBSSMTP, SMTPSTELNET and TFTP 1 ]& R: A; { p- `
我们可以使用cURL执行一些有用的技巧,如代理支持、用户身份验证、FTP上传、HTTP post、SSL连接、cookie、文件传输恢复、Metalink等等cURL是在命令行中使用的,在软件开发过程中,它主要是用来快速测试API的。
& v' M' p- a5 [) @5 q; h 当我想在Node.js服务器中测试我所有的API时,我个人使用cURL对于开发者来说,这是一个非常方便的工具 Postman很酷,但是cURL非常酷 – Chidume Nnamdi在本文中,我们将介绍基本的cURL函数和选项。
# U9 b. }8 N( T4 R3 Y, w 我们还将学习如何使用cURL在API端点上执行GET,POST请求cURL选项--request 或者 -X—request 和 -X 指定与HTTP服务器通信时可以使用的自定义请求方法,将使用指定的请求方法代替其他方法(默认为GET)。 / [: r) F3 Y+ {- Q
要执行POST请求:curl --request POST要执行GET请求:curl --request GET--url ' @8 y3 n+ }" Z5 b5 G% B3 j
如果给定的URL缺少scheme name(例如“http://””或“ftp://””等),则cURL将基于主机进行猜测如果最外面的子域名与DICT,FTP,IMAP,LDAP,POP3或SMTP匹配,则将使用该协议。 ) L' E- S, Q/ F( L
否则,将使用HTTP例如,如果你想在本地服务器上的 localhost:3000 上执行GET请求,则需要将 --url 设置为 localhost:3000:curl --request GET \
8 J* Z' o2 @; ]5 O3 z/ _$ L; y) O --url http://localhost:3000
9 J( i5 f5 e/ e' I/ G5 x" V" ` 要在同一URL上执行POST:curl --request POST \& G+ `5 \( x! }4 X) m1 a
--url http://localhost:3000注意:反斜杠 \ 用于分隔cURL中的选项对于外部API,还是一样。 " T! M. m3 Y( e
假设你要从https://moviesdb.com/movies/all获取电影列表curl --request GET \
9 y: w1 d4 |# d9 _5 A --url https://moviesdb.com/movies/all。 6 r# s+ s5 z) y
moviedb 中所有电影的列表都将被获取并打印--header 或者 -H这个选项用于设置请求的头信息当向服务器发送HTTP时,在请求中包含的额外头你可以指定任意数量的额外头请注意,如果你要添加一个自定义的头文件,而这个头文件的名字与 curl 内部使用的头文件相同,那么你在外部设置的头将被用来代替内部头。
- I* B' v' ^% U4 R8 |! S 这反映了我们在正常编程中的做法,特别是在JavaScript中使用 XMLHttpRequest:const xhttp = new XMLHttpRequest()
4 f% X) ~# p/ n" B" S5 g T5 m) K
: K5 G l) a: n2 ?) g [ xhttp.setHeader("Content-Type", "application/json") $ W+ j1 P. M( z4 x% |
头信息用于向Web服务器传达传入的数据类型,或期望的数据类型,发送的数据类型应与标头中指定的类型相同我们可以使用头文件来获得CORS权限,甚至可以获得某些类型的请求方法的权限我们可以用头文件做的事情有很多。
: N6 D+ }4 e. z 因此,在cURL中,我们可以使用 —header 选项设置标头:curl --request POST \ |7 {' t9 d: E, Z) X( I
--url http://localhost:5000/api/user \ r; `+ ~, l" I- l- {
--header content-type: application/json
" a' w( ~/ F& }9 w. y! l 这里,我们正在向http://localhost:5000/api/user 端点发出 POST 请求,并通过 --header content-type: application/json’ 告诉服务器我们要发送的数据是 JSON 数据类型。
% A( s, P5 F P* E2 y0 z --data 或者 -d此选项用于将数据发送到HTTP服务器,这主要是在POST请求中使用,因为我们将数据发送到我们要添加到数据库的服务器因此,在cURL中,我们可以通过设置 —data 选项将数据指定为POST。 ) ~+ U2 ~1 I3 J% w- l; Z7 V- r
在POST请求中向HTTP服务器发送指定的数据,就像浏览器在用户填写HTML表格并按下提交按钮时一样这是一个例子:curl --request POST \
4 `, L: a2 M7 P, c, ^ --url http://localhost:5000 \# X5 _+ |% K. n
--header content-type: application/json \( _$ V& H& Y" N. w+ G8 K
--data {"name":"Arrow","description":"bad movie","rating":"7.0","image":"michaeljackson.png"}。
1 Y0 b t( h- A* B 在这里,我们正在执行对 http://localhost:5000端点的POST请求我们在 —data 选项中设置了要发送到服务器的数据,即:{"name":"Arrow","description":"bad movie","rating":"7.0","image":"michaeljackson.png”}。
7 l! x5 M+ s$ f+ P" K 在Node.js / Express.js中使用cURL让我们看看如何设置Node.js / Express.js服务器并使用cURL测试端点:// server.js6 a( I8 H, e( r- r
constexpress=require - M! ^) R0 X+ V$ S5 U g* U
("express")constcors=require(cors)constbodyParser=require(body-parser)consthelmet=require(helmet)const / N8 |) F' ^' U' {
app=express()letport=5000||process.env.PORT/** 设置中间件 */app.use(cors())app.use(bodyParser.json({limit: + s/ T; p5 u4 X( [; A6 v- B
50mb}))app.use(helmet())letusers=[]letcurrIdDate.now()app.get("api/user/:id",(req,res,next)=>{constuserId
5 Q, f) [$ c' d2 a. o A, ? =req.params.idconstusers=users.filter(user=>user.id===userId)if(users.length>0)res.send({user:users[0 1 G6 k6 Q8 F3 p! Z1 o4 W
]})elseres.send({mesg:"No user found."})next()})app.get("api/users",(req,res,next)=>{res.send({users}) # \4 w9 f# W2 A/ i5 B3 D4 J' f: ~
next()})app.post("api/user",(req,res,next)=>{letbdy=req.bodybdy={id:++currId,...bdy}users.push(bdy)res , {8 a9 W& m4 |" J
.send({user:bdy})next()})/** 启动服务器 */app.listen(port,()=>{console.log(`Server started at port: ${port
. g4 Q; u% K- r& \. ]+ V }`);});我们在这里有一些小的API端点:GEt api/usersGET api/user/:idPOST api/user它通过其 id 提取所有用户(特定用户),并可以添加新用户启动服务器:node server.js
0 [' I' \; Y) {4 l
( p+ V( V" F# ^; t0 W; y4 b Server started at port: 5000
6 K! @2 X& o, y) _7 G& j 现在,要在 api/user 上执行POST请求,我们将 —url 设置为 http://localhost:5000/api/user,并将 --request 设置为POST,将 --header 设置为 s+ A" v& l/ z- x( M
content-type:application/json我们要添加用户:name: "Chidume",
' p. ?3 ^2 ?, B. G& q age: 28因此数据将为 {"name": "Chidume", "age": "28"}因此,cURL命令将是: 2 t6 L b9 u& A/ S |
curl --request POST \
& R8 x" }2 q! m0 M --url http://localhost:5000/api/user \
4 N. Z4 V2 U( ]/ F2 [: P4 m --header content-type: application/json \6 U1 R7 w& J8 F! ` M2 t( Y* z
--data {"name": "Chidume", "age": "28"}
1 C5 ~% B7 y/ v0 R( \2 j7 O6 p- [3 G6 Y/ B7 v& Z5 H! b
{ id: 5122435464, name: "Chidume", age: 28 }
# R W0 Y$ [ x9 V 我们从服务器上看到了结果:将用户及其 id 添加到数据库中让我们添加另一个用户:curl --request POST \0 T1 c% v) q* U o5 b& ]2 E
--url http://localhost:5000/api/user \- W/ w8 b" a7 H7 | ^$ N
--header content-type: application/json \: I S t A& [+ R+ o) ?
--data {"name": "Nnamdi", "age": "21"}
( Q a* R: S+ E' N: }, X
/ K; V2 |: K4 m# N _8 k1 Y { id: 5122435465, name: "Nnamdi", age: 21 }。 3 e! X/ ~8 Q1 ^$ O# Q
我们添加了另一个用户“Nnamdi”,我们可以看到服务器的 id 及其结果现在,让我们通过 api/user/:id 查询“ Chidume”在这里 :id 将是 id 5122435464因此cURL将是:。
+ S* u# R4 Y: p! x6 s- U curl --request GET \
$ ^8 }0 l+ }% e2 P --url http://localhost:5000/api/user/51224354644 i# _" k# u4 u# l
1 W9 F5 o) Y& I, |/ T. S* o2 _
{ user: { id: 5122435464, name: "Chidume", age: 28 } } - H/ e8 H! t9 F/ P2 g! q |; V! ^2 F
服务器的结果返回 id 为5122435464的用户,即“Chidume”现在让我们查询一个不存在的用户:curl --request GET \+ p5 d! O4 l5 Y& l2 q* i3 A
--url http://localhost:5000/api/user/2000000000
' f0 P- c& X+ ?( h/ X& n1 l) @, k) F
* ~) ^: `6 t0 _
{ mesg: "No user found." }。
( ]5 ]9 l2 O* e* c 这是当我们遇到不存在的用户时服务器上返回的结果现在,让我们查询所有用户:curl --request GET \
8 R6 r* y% n$ W. ]7 D2 |* N --url http://localhost:5000/api/users- G0 x2 W7 Q7 v* p
' A& Y: F, M1 ~
+ v# P. {) ?3 s4 ?- @ { users: [ { id: 5122435465, name: "Nnamdi", age: 21 }, { id: 5122435464, name: "Chidume", age: 28 } ] }。
# y& Q) `* ]8 h) ~9 W1 I4 q6 H 如你所见,将返回服务器中的所有用户结束如果你对此有任何疑问,或者我应该添加,更正或删除任何内容,请随时发表评论原文:https://blog.logrocket.com作者:Chidume Nnamdi Follow。 * r- W# a# V3 R% H
5 p2 i3 G+ E0 o4 q+ A) `- s. l( i0 z$ T
* j/ E8 U- R, {" {) }$ L; S1 S9 \/ x" S Q
! B$ r3 u5 a9 L. R |