curl开发常用方法总结
- 
- 
- 
- [1、cURL 是什么?](#1、cURL 是什么?)
- 2、cURL常用参数及说明
- 3、cURL常见用法示例
- [4、cURL POST 请求示例](#4、cURL POST 请求示例)
 
 
- 
 
- 
在开发中,后端与前端联调、后端与API联调,需要说明接口是否可用,千言万语,最好的方式就是丢给对方一个curl执行命令。
1、cURL 是什么?
cURL 是一个在命令行下使用的工具,用来:
- 访问网站
- 测试接口
- 下载文件
- 上传数据
2、cURL常用参数及说明
            
            
              powershell
              
              
            
          
          -X, --request: 指定请求方法,如GET、POST、PUT、DELETE等。
-H, --header: 设置请求头,可以多次使用此参数来设置多个头信息。
-d, --data: 设置请求体数据,通常用于POST或PUT请求。默认情况下,使用此参数会使得请求方法为POST。
-F, --form: 用于模拟表单提交,可以上传文件等。
-G, --get: 将-d参数指定的数据作为URL的查询参数,强制使用GET请求。
-i, --include: 在输出中包含响应头。
-I, --head: 只获取响应头信息(HEAD请求)。
-k, --insecure: 允许不验证SSL证书。
-L, --location: 如果服务器返回重定向,自动跟随重定向。
-o, --output: 将响应输出到文件,而不是标准输出。
-O, --remote-name: 将输出保存为远程文件的文件名。
-s, --silent: 静默模式,不显示进度和错误信息。
-u, --user: 设置用户名和密码,用于服务器认证。
-v, --verbose: 显示更详细的信息,包括请求和响应的头信息等。
-A, --user-agent: 设置User-Agent头。
-b, --cookie: 设置Cookie。
-c, --cookie-jar: 将服务器返回的Cookie保存到文件。
--connect-timeout: 设置连接超时时间。
--max-time: 设置整个请求的最大时间。3、cURL常见用法示例
            
            
              powershell
              
              
            
          
          基本用法:获取网页内容
最简单的使用CURL的方式是直接输入URL,它会将获取的内容输出到标准输出。
示例:curl https://www.example.com
保存输出到文件
使用-o选项可以将输出保存到指定的文件。
示例:curl -o example.html https://www.example.com
这会将https://www.example.com的内容保存到example.html文件中。
跟随重定向
如果遇到重定向,可以使用-L选项让CURL跟随重定向。
示例:curl -L https://www.example.com
发送GET请求(默认)
CURL默认发送GET请求,但也可以显式指定-X GET。
示例:curl -X GET https://api.example.com/data
发送POST请求
使用-X POST可以发送POST请求,通常与-d选项一起使用来发送数据。
示例:curl -X POST -d "name=John&age=30" https://api.example.com/users
也可以发送JSON数据:
curl -X POST -H "Content-Type: application/json" -d '{"name":"John","age":30}' https://api.example.com/users
设置请求头
使用-H选项可以设置请求头。
示例:curl -H "Authorization: Bearer token123" https://api.example.com/protected
使用代理
使用-x选项可以指定代理服务器。
示例:curl -x http://proxy-server:port https://www.example.com
下载文件
使用-O选项可以下载文件并保留远程文件的文件名。
示例:curl -O https://www.example.com/file.zip
同时指定多个选项
可以组合多个选项,比如同时使用-H设置多个头,使用-d发送数据,使用-X指定方法等。
示例:curl -X PUT -H "Content-Type: application/json" -H "Authorization: Bearer token" -d '{"key":"value"}' https://api.example.com/resource
调试模式
使用-v选项可以启用详细模式,显示整个请求和响应的过程,便于调试。
示例:curl -v https://www.example.com
限制带宽
使用--limit-rate选项可以限制CURL使用的带宽。
示例:curl --limit-rate 100k -O https://www.example.com/largefile.zip
忽略SSL证书验证
使用-k选项可以忽略SSL证书验证(不推荐在生产环境使用,仅用于测试)。
示例:curl -k https://www.example.com
使用cookie
使用-b选项可以发送cookie,使用-c选项可以保存服务器返回的cookie。
示例:发送cookie:curl -b "name=value" https://www.example.com
保存cookie:curl -c cookies.txt https://www.example.com
使用用户认证
使用-u选项可以进行基本的HTTP认证。
示例:curl -u username:password https://www.example.com
上传文件
使用-T选项可以上传文件。
示例:curl -T localfile.txt ftp://ftp.example.com/upload/4、cURL POST 请求示例
完整命令示例
            
            
              powershell
              
              
            
          
          curl -X POST https://api.example.com/users \
  -H "Content-Type: application/json" \
  -H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9" \
  -d '{
    "name": "张三",
    "email": "zhangsan@example.com",
    "age": 28,
    "department": "技术部"
  }'更简洁的写法
            
            
              powershell
              
              
            
          
          curl -X POST https://api.example.com/users -H "Content-Type: application/json" -H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9" -d '{"name": "张三","email": "zhangsan@example.com","age": 28,"department": "技术部"}'命令分解说明
| 部分 | 说明 | 示例 | 
|---|---|---|
| 请求方法 | -X POST指定POST请求 | -X POST | 
| 请求URL | 接口地址 | https://api.example.com/users | 
| 内容类型 | -H "Content-Type: application/json"声明发送JSON数据 | -H "Content-Type: application/json" | 
| 认证头 | -H "Authorization: ..."携带访问令牌 | -H "Authorization: Bearer ..." | 
| 请求体 | -d '...'包含实际的JSON数据 | -d '{"name":"张三",...}' |