spatie/laravel-google-cloud-storage

Google Cloud Storage文件系统驱动程序,用于Laravel

2.3.0 2024-03-14 22:16 UTC

This package is auto-updated.

Last update: 2024-09-20 09:13:18 UTC


README

Latest Version on Packagist run-tests Total Downloads

Laravel 9及更高版本(使用Flysystem v3及其自己的GCS适配器)的Google Cloud Storage文件系统驱动程序。

需要Laravel 8支持?使用v1分支!

支持我们

我们在创建最佳开源软件包上投入了大量资源。您可以通过购买我们的付费产品之一来支持我们。

我们非常感谢您从家乡寄给我们明信片,说明您正在使用我们的哪个包。您可以在我们的联系页面上找到我们的地址。我们将所有收到的明信片发布在我们的虚拟明信片墙上

安装

您可以通过composer安装此包

composer require spatie/laravel-google-cloud-storage

接下来,在您的filesystems.php配置中添加一个新的磁盘

'gcs' => [
    'driver' => 'gcs',
    'key_file_path' => env('GOOGLE_CLOUD_KEY_FILE', null), // optional: /path/to/service-account.json
    'key_file' => [], // optional: Array of data that substitutes the .json file (see below)
    'project_id' => env('GOOGLE_CLOUD_PROJECT_ID', 'your-project-id'), // optional: is included in key file
    'bucket' => env('GOOGLE_CLOUD_STORAGE_BUCKET', 'your-bucket'),
    'path_prefix' => env('GOOGLE_CLOUD_STORAGE_PATH_PREFIX', ''), // optional: /default/path/to/apply/in/bucket
    'storage_api_uri' => env('GOOGLE_CLOUD_STORAGE_API_URI', null), // see: Public URLs below
    'api_endpoint' => env('GOOGLE_CLOUD_STORAGE_API_ENDPOINT', null), // set storageClient apiEndpoint
    'visibility' => 'public', // optional: public|private
    'visibility_handler' => null, // optional: set to \League\Flysystem\GoogleCloudStorage\UniformBucketLevelAccessVisibility::class to enable uniform bucket level access
    'metadata' => ['cacheControl' => 'public,max-age=86400'], // optional: default metadata
],

用法

$disk = Storage::disk('gcs');

$disk->put('avatars/1', $fileContents);
$exists = $disk->exists('file.jpg');
$time = $disk->lastModified('file1.jpg');
$disk->copy('old/file1.jpg', 'new/file1.jpg');
$disk->move('old/file1.jpg', 'new/file1.jpg');
$url = $disk->url('folder/my_file.txt');
$url = $disk->temporaryUrl('folder/my_file.txt', now()->addMinutes(30));
$disk->setVisibility('folder/my_file.txt', 'public');

有关完整功能列表,请参阅https://laravel.net.cn/docs/master/filesystem

身份验证

Google客户端使用几种方法来确定如何与Google API进行身份验证。

  1. 如果您在磁盘配置中指定了key_file_path键的路径,则将使用该json凭证文件。

  2. 如果设置了GOOGLE_APPLICATION_CREDENTIALS环境变量,它将使用该变量。

    putenv('GOOGLE_APPLICATION_CREDENTIALS=/path/to/service-account.json');
  3. 然后它会尝试从“已知路径”加载密钥文件

    • Windows:%APPDATA%/gcloud/application_default_credentials.json
    • 其他:$HOME/.config/gcloud/application_default_credentials.json
  4. 如果在Google App Engine上运行,将使用与应用程序关联的内置服务帐户。

  5. 如果在Google Compute Engine上运行,将使用与虚拟机实例关联的内置服务帐户。

  6. 如果您想直接身份验证而不使用json文件,您可以在磁盘配置中指定key_file的数组,并使用以下数据

    'key_file' => [
        'type' => env('GOOGLE_CLOUD_ACCOUNT_TYPE'),
        'private_key_id' => env('GOOGLE_CLOUD_PRIVATE_KEY_ID'),
        'private_key' => env('GOOGLE_CLOUD_PRIVATE_KEY'),
        'client_email' => env('GOOGLE_CLOUD_CLIENT_EMAIL'),
        'client_id' => env('GOOGLE_CLOUD_CLIENT_ID'),
        'auth_uri' => env('GOOGLE_CLOUD_AUTH_URI'),
        'token_uri' => env('GOOGLE_CLOUD_TOKEN_URI'),
        'auth_provider_x509_cert_url' => env('GOOGLE_CLOUD_AUTH_PROVIDER_CERT_URL'),
        'client_x509_cert_url' => env('GOOGLE_CLOUD_CLIENT_CERT_URL'),
    ],

公共URL

适配器实现了一个getUrl($path)方法,该方法返回一个文件的公共URL。

注意:此方法适用于Laravel 5.2及以上版本。如果用于5.1,将引发异常。

$disk = Storage::disk('gcs');
$url = $disk->url('folder/my_file.txt');
// http://storage.googleapis.com/bucket-name/folder/my_file.txt

如果您在配置中配置了path_prefix

$disk = Storage::disk('gcs');
$url = $disk->url('folder/my_file.txt');
// http://storage.googleapis.com/bucket-name/path-prefix/folder/my_file.txt

如果您在配置中配置了自定义的storage_api_uri

$disk = Storage::disk('gcs');
$url = $disk->url('folder/my_file.txt');
// http://your-custom-domain.com/bucket-name/path-prefix/folder/my_file.txt

对于自定义域名(存储API URI),您需要配置一个指向storage.googleapis.com的CNAME DNS条目。

有关进一步说明,请参阅https://cloud.google.com/storage/docs/xml-api/reference-uris#cname

临时/签名URL

使用最新版本的适配器,您可以轻松地为默认情况下不可公开查看的文件生成签名URL。

$disk = Storage::disk('gcs');
$url = $disk->temporaryUrl('folder/my_file.txt', now()->addMinutes(30));
// https://storage.googleapis.com/test-bucket/folder/my_file.txt?GoogleAccessId=test-bucket%40test-gcp.iam.gserviceaccount.com&Expires=1571151576&Signature=tvxN1OS1txkWAUF0cCR3FWK%seRZXtFu42%04%YZACYL2zFQxA%uwdGEmdO1KgsHR3vBF%I9KaEzPbl4b7ic2IWUuo8Jh3IoZFqdTQec3KypjDtt%02DGwm%OO6pWDVV421Yp4z520%o5oMqGBtV8B3XmjW2PH76P3uID2QY%AlFxn23oE9PBoM2wXr8pDXhMPwZNJ0FtckSc26O8PmfVsG7Jvln%CQTU57IFyB7JnNxz5tQpc2hPTHbCGrcxVPEISvdOamW3I%83OsXr5raaYYBPcuumDnAmrK%cyS9%Ky2fL2B2shFO2cz%KRu79DBPqtnP2Zf1mJWBTwxVUCK2jxEEYcXBXtdOszIvlI6%tp2XfVwYxLNFU

统一存储桶级别的访问

Google Cloud Storage允许在存储桶级别设置权限,即“统一存储桶级别访问”。

最初,观察到错误“当启用统一存储桶级别访问时,无法插入对象的旧版ACL”。

上传文件到此类存储桶时,请确保配置文件中的visibility_handler设置如下

'visibility_handler' => \League\Flysystem\GoogleCloudStorage\UniformBucketLevelAccessVisibility::class,

请参阅https://cloud.google.com/storage/docs/access-control/signed-urlshttps://laravel.net.cn/docs/6.x/filesystem获取更多信息。

测试

composer test

变更日志

有关最近更改的详细信息,请参阅CHANGELOG

贡献

有关详细信息,请参阅CONTRIBUTING

安全漏洞

请查看我们关于如何报告安全漏洞的安全策略

鸣谢

许可证

MIT许可证(MIT)。有关更多信息,请参阅许可证文件