Laravel 5でリモート画像をローカルに保存するにはどうすればよいですか?

不言
リリース: 2023-03-01 06:36:02
オリジナル
6381 人が閲覧しました

Laravel の FileSystem はこれをサポートしていますか (特にコピーなどの機能)?

file_get_contents を使用する場合、HTTPS Web サイトの場合、SSL 検証失敗エラーが発生しますが、このエラーは無視できません。 file_get_contents的话,如果是HTTPS网站会遇到SSL验证失败的错误,但又不能忽略掉这个错误。

回复内容:

Laravel的FileSystem是否支持这样做(尤其是copy等函数)?
file_get_contents的话,如果是HTTPS网站会遇到SSL验证失败的错误,但又不能忽略掉这个错误。

用GuzzleHttp即可。
加上:

use GuzzleHttp\Client;
use GuzzleHttp\Exception\GuzzleException;
ログイン後にコピー
$client = new Client(['verify' => false]);  //忽略SSL错误
$response = $client->get($url, ['save_to' => public_path($file)]);  //保存远程url到文件
ログイン後にコピー

可以用try catch写。

GuzzleHttp获取远程资源。Storage处理文件存储。

try {
    $client = new \GuzzleHttp\Client();
    $data = $client->request('get','http://xxxx')->getBody()->getContents();
    Storage::disk('local')->put('filename', $data);
} catch (\GuzzleHttp\RequestException $e) {
    echo 'fetch fail';
}
ログイン後にコピー
SSL证书验证失败的问题是以为你本地没有最新的ca证书列表,下载一个就行了
ログイン後にコピー
$client = new \GuzzleHttp\Client($url,[
    'curl.options' => [
        CURLOPT_SSL_VERIFYPEER=>2,
        CURLOPT_SSL_VERIFYHOST=true,
    ]
]);
ログイン後にコピー

用curl可以搞定

file_put_contents('/tmp/logo.gif',file_get_contents('https://www.baidu.com/img/bdlogo.gif'));
ログイン後にコピー

只要你的PHP添加了OpenSSL支持(--with-openssl

返信内容:


Laravel のファイルシステムはこれをサポートしていますか (特にコピーなどの機能)?

file_get_contents を使用する場合、HTTPS ウェブサイトの場合、SSL 検証失敗エラーが発生しますが、このエラーは無視できません。

🎜GuzzleHttp を使用してください。 🎜追加: 🎜
wget https://curl.haxx.se/ca/cacert.pem
php.ini:
openssl.cafile=/path/to/cacert.pem

var_export(openssl_get_cert_locations());
array (
  'default_cert_file' => '/opt/phpdroid/deps/ssl/cert.pem',
  'default_cert_file_env' => 'SSL_CERT_FILE',
  'default_cert_dir' => '/opt/phpdroid/deps/ssl/certs',
  'default_cert_dir_env' => 'SSL_CERT_DIR',
  'default_private_dir' => '/opt/phpdroid/deps/ssl/private',
  'default_default_cert_area' => '/opt/phpdroid/deps/ssl',
  'ini_cafile' => '',
  'ini_capath' => '',
)
ログイン後にコピー
rrreee🎜はtry catchを使用して記述できます。 🎜🎜GuzzleHttp はリモート リソースを取得します。ストレージはファイル ストレージを扱います。 🎜rrreeerrreeerrreee🎜curl を使用して実行できます🎜rrreee🎜PHP が OpenSSL サポート (--with-openssl) を追加している限り、file_get_contents は確実に HTTPS をサポートします。🎜 エラー メッセージが表示された場合:🎜 SSL 操作はコード 1 で失敗しました。 OpenSSL エラー メッセージ:🎜error:14090086:SSL ルーチン:ssl3_get_server_certificate:certificate verify failed🎜次に、cacert.pem ファイルをダウンロードし、php.ini で指定して、PHP サービスを再起動します:🎜rrreee
関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!