WordPress как на ладони
Недорогой хостинг для сайтов на WordPress: wordpress.jino.ru

download_url() WP 2.5.0

Загружает файл (УРЛ) во временный каталог PHP. Работает на основе WordPress HTTP API.

Имейте ввиду, при вызове функции всегда нужно удалять файл через unlink()

Во фронт-энде для работы функции нужны следующие файлы:

require_once ABSPATH . 'wp-admin/includes/file.php';
Является основой для: media_sideload_image()
Работает на основе: wp_safe_remote_get(), wp_tempnam()
Возвращает

Строку/WP_Error. Название файла (абсолютный путь до файла на сервере), если файл успешно загружен. WP_Error объект в случае ошибки.

Использование

download_url( $url, $timeout );
$url(строка) (обязательный)
УРЛ файла, который нужно загрузить во временную директорию.
$timeout(число)
Время после которого функция перестанет загружать файл.
По умолчанию: 300

Примеры

#1 Пример загрузки файла во временный каталог PHP

В этом примере загрузим логотип WordPress и проверим загрузку на ошибки. Также после обработки удалим временный файл на сервере.

require_once( ABSPATH . "wp-admin" . '/includes/file.php');

$tmp = download_url( 'https://s.w.org/style/images/wp-header-logo.png' );

if( is_wp_error( $tmp ) )
	echo $tmp->get_error_messages();
else
	echo $tmp; // выведет: /tmp/wp-header-logo.tmp

// делаем что-либо с файлом ...

// удаляем временный файл
@ unlink( $tmp );

Список изменений

С версии 2.5.0 Введена.
С версии 5.2.0 Signature Verification with SoftFail was added.

Код download url: wp-admin/includes/file.php WP 5.2.4

<?php
function download_url( $url, $timeout = 300, $signature_verification = false ) {
	//WARNING: The file is not automatically deleted, The script must unlink() the file.
	if ( ! $url ) {
		return new WP_Error( 'http_no_url', __( 'Invalid URL Provided.' ) );
	}

	$url_filename = basename( parse_url( $url, PHP_URL_PATH ) );

	$tmpfname = wp_tempnam( $url_filename );
	if ( ! $tmpfname ) {
		return new WP_Error( 'http_no_file', __( 'Could not create Temporary file.' ) );
	}

	$response = wp_safe_remote_get(
		$url,
		array(
			'timeout'  => $timeout,
			'stream'   => true,
			'filename' => $tmpfname,
		)
	);

	if ( is_wp_error( $response ) ) {
		unlink( $tmpfname );
		return $response;
	}

	$response_code = wp_remote_retrieve_response_code( $response );

	if ( 200 != $response_code ) {
		$data = array(
			'code' => $response_code,
		);

		// Retrieve a sample of the response body for debugging purposes.
		$tmpf = fopen( $tmpfname, 'rb' );
		if ( $tmpf ) {
			/**
			 * Filters the maximum error response body size in `download_url()`.
			 *
			 * @since 5.1.0
			 *
			 * @see download_url()
			 *
			 * @param int $size The maximum error response body size. Default 1 KB.
			 */
			$response_size = apply_filters( 'download_url_error_max_body_size', KB_IN_BYTES );
			$data['body']  = fread( $tmpf, $response_size );
			fclose( $tmpf );
		}

		unlink( $tmpfname );
		return new WP_Error( 'http_404', trim( wp_remote_retrieve_response_message( $response ) ), $data );
	}

	$content_md5 = wp_remote_retrieve_header( $response, 'content-md5' );
	if ( $content_md5 ) {
		$md5_check = verify_file_md5( $tmpfname, $content_md5 );
		if ( is_wp_error( $md5_check ) ) {
			unlink( $tmpfname );
			return $md5_check;
		}
	}

	// If the caller expects signature verification to occur, check to see if this URL supports it.
	if ( $signature_verification ) {
		/**
		 * Filters the list of hosts which should have Signature Verification attempteds on.
		 *
		 * @since 5.2.0
		 *
		 * @param array List of hostnames.
		 */
		$signed_hostnames       = apply_filters( 'wp_signature_hosts', array( 'wordpress.org', 'downloads.wordpress.org', 's.w.org' ) );
		$signature_verification = in_array( parse_url( $url, PHP_URL_HOST ), $signed_hostnames, true );
	}

	// Perform signature valiation if supported.
	if ( $signature_verification ) {
		$signature = wp_remote_retrieve_header( $response, 'x-content-signature' );
		if ( ! $signature ) {
			// Retrieve signatures from a file if the header wasn't included.
			// WordPress.org stores signatures at $package_url.sig

			$signature_url = false;
			$url_path      = parse_url( $url, PHP_URL_PATH );
			if ( substr( $url_path, -4 ) == '.zip' || substr( $url_path, -7 ) == '.tar.gz' ) {
				$signature_url = str_replace( $url_path, $url_path . '.sig', $url );
			}

			/**
			 * Filter the URL where the signature for a file is located.
			 *
			 * @since 5.2.0
			 *
			 * @param false|string $signature_url The URL where signatures can be found for a file, or false if none are known.
			 * @param string $url                 The URL being verified.
			 */
			$signature_url = apply_filters( 'wp_signature_url', $signature_url, $url );

			if ( $signature_url ) {
				$signature_request = wp_safe_remote_get(
					$signature_url,
					array(
						'limit_response_size' => 10 * 1024, // 10KB should be large enough for quite a few signatures.
					)
				);

				if ( ! is_wp_error( $signature_request ) && 200 === wp_remote_retrieve_response_code( $signature_request ) ) {
					$signature = explode( "\n", wp_remote_retrieve_body( $signature_request ) );
				}
			}
		}

		// Perform the checks.
		$signature_verification = verify_file_signature( $tmpfname, $signature, basename( parse_url( $url, PHP_URL_PATH ) ) );
	}

	if ( is_wp_error( $signature_verification ) ) {
		if (
			/**
			 * Filters whether Signature Verification failures should be allowed to soft fail.
			 *
			 * WARNING: This may be removed from a future release.
			 *
			 * @since 5.2.0
			 *
			 * @param bool   $signature_softfail If a softfail is allowed.
			 * @param string $url                The url being accessed.
			 */
			apply_filters( 'wp_signature_softfail', true, $url )
		) {
			$signature_verification->add_data( $tmpfname, 'softfail-filename' );
		} else {
			// Hard-fail.
			unlink( $tmpfname );
		}

		return $signature_verification;
	}

	return $tmpfname;
}

Cвязанные функции

Из метки: upload download (файловая система file загрузка)

Еще из раздела: Без рубрики

Комментариев нет
    Здравствуйте, !     Войти . Зарегистрироваться