WordPress运行在PHP环境中,因此要在WordPress中发送HTTP请求,是一件非常容易的事,很多PHP函数都能实现,比如fopen
、curl
等,但是不同的PHP环境中,这些函数可能是不被允许使用的。为了能为开发者提供一个稳定的,不受环境影响的发送HTTP请求工具,WordPress官方提供了WP_Http类。
WordPress 2.7 开始引入了一个新的 PHP Class:WP_Http(在 wp-includes 目录 http.php 文件中)。这个 Class 的强大之处是它会检测服务器的情况,选择最好的方法去实现 HTTP 请求,所以我们自己无须去检测 HTTP 扩展。
类方法
- _dispatch_request — 向支持传输发送HTTP请求。-弃用
- _get_first_available_transport —测试能够支持请求的传输。
- block_request — 确定是否应阻止对给定URL的HTTPAPI请求。
- browser_redirect_compatibility — 将重定向行为匹配到浏览器处理。
- buildCookieHeader — 传入一个request()参数,并检查cookie数组。
- chunkTransferDecode — 解码块传输-编码,基于HTTP1.1规范。
- get — 使用HTTP GET方式访问。
- handle_redirects — 处理HTTP重定向,并酌情遵循它。
- head — 使用Head HTTP方法。
- is_ip_address — 确定指定的字符串是否表示IP地址。
- make_absolute_url — 将相对URL转换为相对于给定URL的绝对URL。
- normalize_cookies — 规范用于请求的cookie。
- parse_url — 用作PHP解析_url()函数的包装器,该函数处理PHP 5.4.7中的EDgecase。-弃用
- post — 使用HTTP POST方法访问。
- processHeaders — 将头字符串转换为数组。
- processResponse — 解析响应并将部分拆分为标题和正文。
- request — 向URI发送HTTP请求。
- validate_redirects — 验证重定向URL。
简单使用
发送GET请求
复制
/** *使用 WP_Http 类发送简单的 GET 请求 */ $http = new WP_Http; $result = $http->request( 'https://www.daimadog.org' );
返回如下字段
- headers:返回的 headers 信息,是一个数组
- body:目标的内容,和在浏览器里直接看是一样的
- response:返回的代码,如果请求成功会返回 array( ‘code’=>200, ‘message’=>’OK’ )
- cookies:Cookie 信息,是一个数组
发送POST请求
复制
/** *使用 WP_Http 类发送简单的 POST 请求 *http://www.endskin.com/wp_http/ */ $http = new WP_Http; $parm = array( 'name' => 'daimadog', 'blog' => 'https://www.daimadog.org' ); $result = $http->request( 'https://www.daimadog.org', array( 'method' => 'POST', 'body' => $parm ) );
返回值参考GET方法。
评论 (0)