玩转curl指令—测试简单的HTTP接口

简介: 玩转curl指令—测试简单的HTTP接口

官网:https://curl.se/

GitHub:https://github.com/curl/curl

Doc.:https://everything.curl.dev/

昨天在测试一个HTTP接口的时候,发现是添加功能,按照Restful风格应该是POST请求,但是经常使用的curl指令,如curl http://xxxx:xxx则默认是GET请求,因此又在搜索引擎上查询curl相关请求方法的指令,发现还挺丰富的,因此今天将这部分总结成一个文章,以便后续的使用。

1 初步介绍

curl主要使用C/C++编写,是一个开源的命令行工具,用于传输使用URL语法指定的数据。

支持的网络协议

文件、FTP、FTPS、MQTT、POP3、POP3S、RTMP、RTMPS、RTSP、SCP、SFTP、SMB、SMBS、SMTP、SMTPS、TELNET 和TFTP

支持HTTP情况

curl 支持 SSL 证书、HTTP POST、HTTP PUT、基于 HTTP 表单的上传、代理、HTTP/2、HTTP/3、cookie、用户+密码身份验证(Basic、Plain、Digest、CRAM-MD5、SCRAM-SHA、 NTLM、Negotiate 和 Kerberos)、文件传输恢复、代理隧道等。

2 安装curl工具

2.1 Linux
# Ubuntu
apt install curl
# CentOS
yum install curl
2.2 Windows

下载:https://curl.se/windows/

下载完成后配置环境变量即可

2.3 Mac OS
brew install curl
2.4 Docker
docker run -it --rm curlimages/curl www.example.com
2.5 验证安装

3 接口环境搭建和curl的使用

3.1 接口搭建

为了方便我们本次实验就使用Spring Boot搭建Http接口吧

@RestController
@RequestMapping("/hello")
public class CurlController {
    @GetMapping("/get")
    public Object get() {
        return "This is GET Method API.";
    }
    @PostMapping("/post")
    public Object post(@RequestParam("id") Integer id, @RequestParam("name") String name) {
        return "This is POST Method API,Your name is " + name + " and id is " + id + ".";
    }
    @PutMapping("/put")
    public Object put() {
        return "This is PUT Method API.";
    }
    @PostMapping("/postJSON")
    public Object postJSON(@RequestBody String str)   {
        System.out.println(str);
        return "This is POST Method API,Your Req(JSON) is " + str + ".";
    }
    @DeleteMapping("/delete/{id}")
    public Object delete(@PathVariable("id") String id) {
        return "This is DELETE Method API,Your ID is " + id+ ".";
    }
}
3.2 curl简单使用
3.2.1 GET请求
C:\Users\sb_curl>curl http://localhost:8080/hello/get
This is GET Method API.
3.2.2 POST请求

(1)一般POST请求

C:\Users\sb_curl>curl -X POST http://localhost:8080/hello/post -d "id=1&name=zs"
This is POST Method API,Your name is zs and id is 1.
  • -X:代表指定请求方法
  • -d:代表请求的数据

(2)带JSON参数的POST请求

C:\Users\sb_curl>curl -H "Content-Type:application/json" -X POST -d '{"uid":"123"}' http://127.0.0.1:8080/hello/postJSON
This is POST Method API,Your Req(JSON) is '{uid:123}'.
  • -H:代表请求头
3.2.3 PUT请求
C:\Users\sb_curl>curl -X PUT http://localhost:8080/hello/put
This is PUT Method API.
3.2.4 DELETE请求
C:\Users\sb_curl>curl -X DELETE http://localhost:8080/hello/delete/1
This is DELETE Method API,Your ID is 1.

4 结语

PS:注意事项分享下

因为把String类型改成了Object类型,查了好长时间,debug了好几次都没发现正确的解决方式,最后看见之前的代码才反应过来…

OK,文章到这里就结束了,本文只分享了最常用最简单的curl的使用,日常测试HTTP接口应该够用,当然其他更复杂的操作需要读者朋友按需学习,Bye~

相关文章
|
5天前
|
Java API Spring
SpringBoot项目调用HTTP接口5种方式你了解多少?
SpringBoot项目调用HTTP接口5种方式你了解多少?
111 2
|
5天前
|
算法 API UED
基于Gin框架的HTTP接口限速实践
基于Gin框架的HTTP接口限速实践
40 0
|
5天前
|
前端开发 小程序 测试技术
前端后端测试接口mork神器,Apifox使用一分钟入门
前端后端测试接口mork神器,Apifox使用一分钟入门
13 0
|
5天前
|
前端开发 API 网络架构
RESTful接口与http协议状态表述
该文介绍了RESTful风格API的好处和设计原则。RESTful API以资源为中心,通过HTTP方法(GET, POST, PUT, DELETE)表示操作,利用状态码反馈操作结果。它简化了客户端与服务端的交互,提供了一种通用规范,减少沟通成本。设计要点包括:URI描述资源,HTTP方法体现操作,使用标准HTTP状态码,GET不改变数据,使用复数名词,支持复杂资源关系,可选实现HATEOAS,以及接口版本管理。
|
5天前
|
弹性计算 运维 监控
|
5天前
|
机器学习/深度学习 存储 人工智能
人工智能平台PAI产品使用合集之是否可以在模型部署发布后以http接口形式提供给业务开发人员使用
阿里云人工智能平台PAI是一个功能强大、易于使用的AI开发平台,旨在降低AI开发门槛,加速创新,助力企业和开发者高效构建、部署和管理人工智能应用。其中包含了一系列相互协同的产品与服务,共同构成一个完整的人工智能开发与应用生态系统。以下是对PAI产品使用合集的概述,涵盖数据处理、模型开发、训练加速、模型部署及管理等多个环节。
|
5天前
Swagger基本使用与RestTemplate发送http接口测试
Swagger基本使用与RestTemplate发送http接口测试
21 1
|
5天前
|
JSON 前端开发 数据格式
糊涂工具类真是场景下请求http接口的案例
糊涂工具类真是场景下请求http接口的案例
29 0
|
5天前
|
DataWorks NoSQL MongoDB
DataWorks常见问题之如何集成离线数据
DataWorks是阿里云提供的一站式大数据开发与管理平台,支持数据集成、数据开发、数据治理等功能;在本汇总中,我们梳理了DataWorks产品在使用过程中经常遇到的问题及解答,以助用户在数据处理和分析工作中提高效率,降低难度。
49 1

热门文章

最新文章