玩转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 测试技术 容器
Jmeter工具使用:HTTP接口性能测试实战
希望这篇文章能够帮助你初步理解如何使用JMeter进行HTTP接口性能测试,有兴趣的话,你可以研究更多关于JMeter的内容。记住,只有理解并掌握了这些工具,你才能充分利用它们发挥其应有的价值。+
959 23
|
4月前
HI1105定频测试指令
HI1105模块在无线图传,特别是远距离无线图传领域有广泛应用,产品认证过程需要牵涉到定频测试,分享以下步骤参考! 主要牵涉到:11a测试、11n(H20)测试、11n(H40)测试、802.11ac 20测试、802.11ac 40测试、802.11ax 20测试、802.11ax 40M测试:
|
7月前
|
SQL 安全 测试技术
2025接口测试全攻略:高并发、安全防护与六大工具实战指南
本文探讨高并发稳定性验证、安全防护实战及六大工具(Postman、RunnerGo、Apipost、JMeter、SoapUI、Fiddler)选型指南,助力构建未来接口测试体系。接口测试旨在验证数据传输、参数合法性、错误处理能力及性能安全性,其重要性体现在早期发现问题、保障系统稳定和支撑持续集成。常用方法包括功能、性能、安全性及兼容性测试,典型场景涵盖前后端分离开发、第三方服务集成与数据一致性检查。选择合适的工具需综合考虑需求与团队协作等因素。
1015 24
|
7月前
|
SQL 测试技术
除了postman还有什么接口测试工具
最好还是使用国内的接口测试软件,其实国内替换postman的软件有很多,这里我推荐使用yunedit-post这款接口测试工具来代替postman,因为它除了接口测试功能外,在动态参数的支持、后置处理执行sql语句等支持方面做得比较好。而且还有接口分享功能,可以生成接口文档给团队在线浏览。
319 2
|
8月前
|
存储 JSON API
Python测试淘宝店铺所有商品接口的详细指南
本文详细介绍如何使用Python测试淘宝店铺商品接口,涵盖环境搭建、API接入、签名生成、请求发送、数据解析与存储、异常处理等步骤。通过具体代码示例,帮助开发者轻松获取和分析淘宝店铺商品数据,适用于电商运营、市场分析等场景。遵守法规、注意调用频率限制及数据安全,确保应用的稳定性和合法性。
|
8月前
|
监控 API 开发工具
Socket.IO介绍,以及怎么连接测试Socket.IO接口?
Socket.IO 是一个用于浏览器和服务器间实时双向通信的库,支持低延迟消息传递、跨平台运行及自动重连。文章介绍了其特点与调试需求,并详细说明如何使用 Apifox 工具创建、连接、发送/接收 Socket.IO 事件,以及团队协作和调试技巧。掌握这些技能可提升实时应用开发效率与质量。
|
9月前
|
小程序 测试技术 数据安全/隐私保护
微信公众号接口测试实战指南
微信公众号接口测试是确保系统稳定性和功能完整性的重要环节。本文详细介绍了测试全流程,包括准备、工具选择(如Postman、JMeter)、用例设计与执行,以及常见问题的解决方法。通过全面测试,可以提前发现潜在问题,优化用户体验,确保公众号上线后稳定运行。内容涵盖基础接口、高级接口、微信支付和数据统计接口的测试,强调了功能验证、性能优化、安全保护及用户体验的重要性。未来,随着微信生态的发展,接口测试将面临更多挑战和机遇,如小程序融合、AI应用和国际化拓展。
|
存储 Web App开发 监控
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html><head><meta http-equiv="Cont
我们以前使用过的对hbase和hdfs进行健康检查,及剩余hdfs容量告警,简单易用 1.针对hadoop2的脚本: #/bin/bashbin=`dirname $0`bin=`cd $bin;pwd`STATE_OK=...
1148 0
|
SQL Web App开发 前端开发
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html><head><meta http-equiv="Cont
在运行一个group by的sql时,抛出以下错误信息: Task with the most failures(4):  -----Task ID:  task_201411191723_723592_m_000004URL:  http://DDS0204.
1100 0