ホームページ >バックエンド開発 >PHPチュートリアル >Laravel 5でリモート画像をローカルに保存するにはどうすればよいですか?
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
file_get_contents
を使用する場合、HTTPS ウェブサイトの場合、SSL 検証失敗エラーが発生しますが、このエラーは無視できません。 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