curl 请求

/**
 * curl POST 请求
 */

function curlpost($url,$data = null,$cookie=null){ 
    $curl = curl_init(); 
    curl_setopt($curl, CURLOPT_URL, $url); 
    curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, FALSE); 
    curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, FALSE); 
    if (!empty($data)){ 
        curl_setopt($curl, CURLOPT_POST, 1); 
        curl_setopt($curl, CURLOPT_POSTFIELDS, $data); 
    }
    curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); 
    
    curl_setopt($curl, CURLOPT_ENCODING, 'gzip,deflate');
    curl_setopt($curl, CURLOPT_COOKIEFILE, $cookie);
    $output = curl_exec($curl); 
    curl_close($curl); 
    return $output; 
}

/**
 * curl GET 请求
 */
function curlget($url){
    $curl = curl_init();
    //设置抓取的url
    curl_setopt($curl, CURLOPT_URL, $url);
    //设置头文件的信息作为数据流输出
    curl_setopt($curl, CURLOPT_HEADER, 1);
    //设置获取的信息以文件流的形式返回,而不是直接输出。
    curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
    //执行命令
    $data = curl_exec($curl);
    //关闭URL请求
    curl_close($curl);
    //显示获得的数据
    return $data;
}

  

### cURL 请求示例 cURL 是一种强大的命令行工具,用于向服务器发送 HTTP 请求并接收响应数据。以下是几个常见的 cURL 请求示例: #### 1. GET 请求 最简单的 GET 请求可以用来获取资源。例如,查询 Elasticsearch 的文档数量: ```bash curl -XGET 'localhost:9200/_count?pretty' -d '{ "query": { "match_all": {} } }' ``` 此请求会返回 `_count` API 的结果,并以漂亮的格式打印出来[^1]。 #### 2. POST 请求 POST 请求通常用于提交数据到服务端。以下是一个 JSON 数据的 POST 请求示例: ```bash curl -H "Content-Type: application/json" -X POST -d '{"relType":-1,"score":null,"objInfos":[{"id":"460015987424345","idType":5},{"id":"15588889345","idType":3},{"id":"460015987424444","idType":5},{"id":"15588889999","idType":3}]}' "http://2.2.7.54:8083/service/rel/analyse" ``` 该请求将指定的数据结构作为负载传递给目标 URL 并执行分析操作[^2]。 #### 3. HTTPS 请求 当访问 HTTPS 接口时,可能会遇到证书验证失败的情况。可以通过 `--insecure` 参数忽略 SSL 验证错误继续请求: ```bash curl --insecure https://example.com/api/resource ``` 如果需要更详细的日志信息以便调试,则可启用 `-v` 或 `--verbose` 参数查看整个通信过程[^3]。 #### 4. 自定义 Header 和 PUT 请求 PUT 方法常被用作更新已有资源的操作;这里演示如何设置自定义头部字段再发起一个 PUT 请求: ```bash curl -H "Authorization: Bearer YOUR_ACCESS_TOKEN" \ -H "Content-Type: application/json" \ -X PUT \ -d '{"key":"value"}' \ http://api.example.com/v1/update-resource ``` 以上展示了不同类型下的基本用法模式供参考学习之需。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值