wp_get_http

函式
wp_get_http ( $url, $file_path = false, $red = 1 )
引數
  • (string) $url URL to fetch.
    Required:
  • (string|bool) $file_path Optional. File path to write request to. Default false.
    Required:
    Default: false
  • (int) $red Optional. The number of Redirects followed, Upon 5 being hit, returns false. Default 1.
    Required:
    Default: 1
返回值
  • (Requests_Utility_CaseInsensitiveDictionary|false) Headers on success, false on failure.
相關
  • WP_Http
定義位置
相關方法
wp_get_ext_typeswp_get_http_headerswp_get_siteswp_get_themewp_get_themes
引入
2.5.0
棄用
4.4.0

wp_get_http: 這個函式是WP_Http類的一個封裝器,它用於WordPress的HTTP請求。它返回一個WP_Http類的例項,可以用來進行HTTP請求。

執行HTTP HEAD或GET請求。

如果$file_path是一個可寫的檔名,這將執行一個GET請求並將檔案寫入該路徑。

function wp_get_http( $url, $file_path = false, $red = 1 ) {
	_deprecated_function( __FUNCTION__, '4.4.0', 'WP_Http' );

	@set_time_limit( 60 );

	if ( $red > 5 )
		return false;

	$options = array();
	$options['redirection'] = 5;

	if ( false == $file_path )
		$options['method'] = 'HEAD';
	else
		$options['method'] = 'GET';

	$response = wp_safe_remote_request( $url, $options );

	if ( is_wp_error( $response ) )
		return false;

	$headers = wp_remote_retrieve_headers( $response );
	$headers['response'] = wp_remote_retrieve_response_code( $response );

	// WP_HTTP no longer follows redirects for HEAD requests.
	if ( 'HEAD' == $options['method'] && in_array($headers['response'], array(301, 302)) && isset( $headers['location'] ) ) {
		return wp_get_http( $headers['location'], $file_path, ++$red );
	}

	if ( false == $file_path )
		return $headers;

	// GET request - write it to the supplied filename.
	$out_fp = fopen($file_path, 'w');
	if ( !$out_fp )
		return $headers;

	fwrite( $out_fp,  wp_remote_retrieve_body( $response ) );
	fclose($out_fp);
	clearstatcache();

	return $headers;
}

常見問題

FAQs
檢視更多 >