使用thinkphp6 根据阿里云跨域图片url 下载到浏览器 并且修改文件名
时间: 2024-04-28 13:21:10 浏览: 171
要使用 ThinkPHP6 根据阿里云跨域图片 URL 下载到浏览器并修改文件名,可以使用以下代码:
```php
use think\facade\Http;
// 需要下载的图片地址
$url = 'https://your-bucket.oss-cn-hangzhou.aliyuncs.com/your-object';
// 获取图片文件名
$filename = basename(parse_url($url, PHP_URL_PATH));
// 发送 HTTP 请求,获取图片文件流
$response = Http::get($url);
// 修改文件名
$newFilename = 'new-' . $filename;
// 设置文件下载头信息
header('Content-Type: application/octet-stream');
header('Content-Disposition: attachment; filename="' . $newFilename . '"');
// 输出文件流到浏览器
echo $response->getBody();
```
其中,`$url` 是需要下载的图片地址,`$filename` 是图片文件名,`$newFilename` 是修改后的文件名,可以根据实际需求进行修改。使用 `Http::get` 方法发送 HTTP 请求获取图片文件流,然后使用 `header` 函数设置文件下载头信息,最后将文件流输出到浏览器即可。
相关问题
使用thinkphp6 下载阿里云跨域图片到浏览器 并且修改文件名
要使用 ThinkPHP6 下载阿里云跨域图片到浏览器并修改文件名,可以使用以下代码:
```php
use think\facade\Http;
use think\facade\Config;
// 阿里云 OSS 相关配置
$oss = Config::get('oss');
// 需要下载的图片地址
$url = 'https://your-bucket.oss-cn-hangzhou.aliyuncs.com/your-object';
// 获取图片文件名
$filename = basename(parse_url($url, PHP_URL_PATH));
// 发送 HTTP 请求,获取图片文件流
$response = Http::get($url);
// 修改文件名
$newFilename = 'new-' . $filename;
// 保存文件到本地
file_put_contents($newFilename, $response->getBody());
// 输出文件给浏览器下载
return Http::download($newFilename, $newFilename);
```
其中,`$oss` 是阿里云 OSS 相关配置,可以在 `config/oss.php` 文件中定义,例如:
```php
<?php
return [
'accessKeyId' => 'your-access-key-id',
'accessKeySecret' => 'your-access-key-secret',
'endpoint' => 'your-endpoint',
'bucket' => 'your-bucket',
];
```
`$url` 是需要下载的图片地址,`$filename` 是图片文件名,`$newFilename` 是修改后的文件名,可以根据实际需求进行修改。最后,使用 `Http::download` 方法将文件输出给浏览器下载。
使用thinkphp6 根据url完整路径 下载阿里云oss图片到当前访问浏览器中 并且修改下载文件名称
好的,我理解了你的要求。根据你的需求,需要使用PHP的curl库来下载阿里云oss图片,同时使用header()函数修改下载文件名称。下面是代码示例:
```php
// 获取完整的url路径
$url = 'http://' . $_SERVER['HTTP_HOST'] . $_SERVER['REQUEST_URI'];
// 根据url路径解析文件名
$filename = basename(parse_url($url)['path']);
// 设置下载文件名称
header('Content-Disposition: attachment; filename="' . $filename . '"');
// 初始化curl
$ch = curl_init($url);
// 设置curl选项
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HEADER, false);
// 执行curl请求
$data = curl_exec($ch);
// 关闭curl
curl_close($ch);
// 输出文件内容
echo $data;
```
在上述代码中,我们首先获取完整的url路径,然后使用parse_url()函数解析出文件名。接着,我们使用header()函数设置下载文件名称,并且开启curl的CURLOPT_RETURNTRANSFER选项,以确保curl请求返回的数据被赋值给$data变量。最后,我们输出文件内容即可。
注意:在使用该代码时,请确保你已经配置好了阿里云oss的访问凭证,并且将图片的URL替换成你自己的URL。
阅读全文