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

使用curl调用restful API(curl 调用接口)

[复制链接]
我来看看 发表于 2023-03-17 18:37:34 | 显示全部楼层 |阅读模式
+ L- y0 O! I! t9 {

我们的示例天气API除了GET方法外,不允许您使用其他任何方法,因此,在本练习中,要使用其他带有curl的方法,我们将使用Swagger的petstore API但是,我们实际上将不会使用Swagger UI(稍后将对此进行探讨)。

/ u+ o" ]& a, `$ m( u

目前,我们只需要一个可用于创建,更新和删除内容的API在此示例中,使用Petstore API,您将创建一个新宠物,更新该宠物,获取该宠物的ID,删除该宠物,然后尝试获取已删除的宠物目录创建一个新宠物更新你的宠物

% b! A3 S6 R" J D: h

通过ID获取宠物的名字删除你的宠物将curl导入Postman在Postman中导出curl创建一个新宠物要创建宠物,您必须在请求正文中传递JSON消息您无需将JSON编码并传递到URL中,而是将JSON存储在文件中并引用该文件。

: I3 k8 F& E: S( t: {8 ^

1.将以下内容插入文本文件此信息将在curl请求的-d参数中传递:{ "id": 123, "category": { "id": 123, "name": "test" }, "name"

' m# k& [6 f* {: b3 a( r% k b

: "fluffy", "photoUrls": [ "string" ], "tags": [ { "id": 0, "name": "string" } ],

( @* U# i- y- T7 a0 P

"status": "available"}2. 将第一个id值更改为另一个整数(整数)另外,将宠物的fluffy名称更改为其他名称3. 将文件保存在您可以从终端方便地访问的目录中,例如用户目录(在Mac上为Users / YOURUSERNAME-在计算机上用您的实际用户名替换YOURUSERNAME)。

8 c, d- E/ V" f; ]2 W% x2 ~

4. 在终端中,浏览到保存mypet.json文件的目录(通常,默认目录为Users / YOURUSERNAME,因此是上一步)如果您从未使用命令行浏览过目录,请按照以下步骤操作:在Mac上,通过输入pwd查找当前的工作目录。

# r6 F; n' P# [- D

然后通过键入更改目录cd ../将其上移通过键入cd pets向下移动一个级别,其中pets是要移动到的目录的名称键入ls列出目录的内容在Windows上,查看提示路径以查看当前目录然后通过输入cd ../向上移动一个级别。

: e# E2 E5 N6 m

通过键入cd pets向下移动一个级别,其中pets是要移动到的目录的名称键入dir以列出当前目录的内容在终端或命令提示符与JSON文件位于同一目录中之后,使用以下curl请求创建新宠物:curl -X POST --header

7 j( ^& j/ u4 s$ t; ?5 @2 U

"Content-Type: application/json" --header "Accept: application/json" -d @mypet.json "http://petstore.swagger.io/v2/pet"

+ }: V5 h+ ?4 Z2 @& J; i% [5 L1 @

Content-Type指示在请求正文中提交的内容的类型接受表示我们将在响应中接受的内容类型响应应如下所示:{"id":51231236,"category":{"id":4,"name":"testexecution"。

7 x6 Q* f0 {( x( ^6 n' F, K

},"name":"fluffernutter","photoUrls":["string"],"tags":[{"id":0,"name":"string"}],"status":"available"

c0 g0 |+ F6 ?+ O c

}在响应中,检查是否已返回您宠物的名字更新您的宠物猜猜是什么,您的宠物讨厌它的名字!使用更新宠物方法将宠物的名字更改为更正式的名称在mypet.json文件中,更改宠物的名称使用PUT方法而不是POST来更新宠物的名字(否则保持相同的curl内容):。

: Y$ _. P6 O4 Y% K( R+ d7 M) \

curl -X PUT --header "Content-Type: application/json" --header "Accept: application/json" -d @mypet.json

( U) k/ v) W; J4 l3 F

"http://petstore.swagger.io/v2/pet"通过ID获取宠物的名字通过将ID传递到/ pet / {petID}端点来找到您的宠物的名字:在您的mypet.json文件中,复制第一个id值。

6 s$ h# c/ ?+ q" {% v' V4 ? N

使用此curl命令获取有关该宠物ID的信息,将51231236替换为您的宠物IDcurl -X GET --header "Accept: application/json""http://petstore.swagger.io/v2/pet/51231236"。

# t$ V/ x/ a; w

回复中包含您宠物的名字和其他信息:{"id":51231236,"category":{"id":4,"name":"test"},"name":"mr. fluffernutter","photoUrls"

4 a" j( a3 x4 O O

:["string"],"tags":[{"id":0,"name":"string"}],"status":"available"}您可以通过将JSON粘贴到JSON格式化工具中来对其进行格式化:{

& J, M, w2 | V9 r5 C6 h! Q- H# B

"id": 51231236, "category": { "id": 4, "name": "test" }, "name": "mr. fluffernutter", "photoUrls"

5 V, L! ^3 c% i

: [ "string" ], "tags": [ { "id": 0, "name": "string" } ], "status": "available"

: O* E, l& l$ |& s" G- }

}删除你的宠物不幸的是,您的宠物已经死亡现在是时候从宠物注册表中删除您的宠物了1.使用DELETE方法删除您的宠物将5123123替换为您的宠物ID:curl -X DELETE --header "Accept: application/json"

1 {! k' N. S% w `8 R4 `' k! }

"http://petstore.swagger.io/v2/pet/5123123"2.现在检查以确保您的宠物已被移除使用GET请求查找具有该ID的宠物:curl -X GET --header "Accept: application/json"

" b. r# K% q0 Z, y8 Y* [

"http://petstore.swagger.io/v2/pet/5123123"您应该看到以下错误消息:{"code":1,"type":"error","message":"Pet not found"

" h7 r8 m1 u4 j( m

}此示例使您能够了解如何使用curl创建,读取,更新和删除资源这四个操作称为CRUD,几乎对每种编程语言都通用尽管Postman可能更易于使用,但是curl有助于提高功耗质量保证团队通常会构建高级测试场景,这些场景会通过大量的curl请求进行迭代。

9 w/ z- Z4 _/ `7 s# h

将curl导入Postman您可以通过执行以下操作将curl命令导入Postman:1.在Postman中打开一个新标签,然后单击左上角的导入按钮2.选择粘贴原始文本并插入curl命令:curl -X GET --header 。

% ]8 }7 f) ]+ g

"Accept: application/json""http://petstore.swagger.io/v2/pet/5123123"请确保一开始没有多余的空格。

) ?' \4 x* I. }% `( t0 S( `

‌3.单击导入4.关闭对话框5.单击发送(如果删除了宠物,您将看到与以前相同的“找不到宠物”错误消息)从Postman中导出curl您还可以通过执行以下操作将Postman导出curl:1.如果需要,请在Postman中选择您的OpenWeatherMap API请求之一。

# q; M# k) l0 ]3 D4 W

2.点击代码按钮(位于保存下方)。

5 t7 }) ?* }4 t

3. 从下拉菜单中选择curl4. 复制代码段curl -X GET \ https://api.openweathermap.org/data/2.5/weather?lat=37.3565982&lon=-121.9689848&units=imperial&appid=fd4698c940c6d1da602a70ac34f0b147。

: P: D6 h9 P$ @! w# r/ P

\ -H Postman-Token: de0da6b7-1dbc-44d6-acc1-9741f05a7bf1 \ -H cache-control: no-cache您可以看到Postman向请求中添加了一些额外的标头信息(-HPostman-Token:

$ w- u, l, E3 E6 u

de0da6b7-1dbc-44d6-acc1-9741f05a7bf1 -Hcache-control:no-cache)多余的标题信息是不必要的,可以删除5. 删除反斜杠和换行符如果您使用的是Windows,请将单引号更改为双引号。

Q( @. m) _/ I" M( z- H5 m

6. 将curl命令插入终端,然后观察结果curl -X GET "https://api.openweathermap.org/data/2.5/weather?lat=37.3565982&lon=-121.9689848&units=imperial&appid=fd4698c940c6d1da602a70ac34f0b147"。

7 P4 @/ p/ F0 i: a' d

通过Postman的导入和编码功能,您可以轻松地在Postman和curl之间切换。

2 @# L" R6 t9 Y8 g , ]1 {: N' v! t2 t; o' d4 V! h ; F% X! u) Y. C- B4 Y7 N+ b3 E' E* Q' m! T# e ( V. C' R" g& J8 p5 i
回复

使用道具 举报

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

    本版积分规则

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

    GMT+8, 2026-4-4 08:17 , Processed in 0.067942 second(s), 23 queries , Gzip On.

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

    Powered by Discuz! X3.5

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