yodawy/laravel-google-cloud-storage

为 Laravel 的 Google Cloud Storage 文件系统

v1.0.0 2023-12-03 14:56 UTC

This package is auto-updated.

Last update: 2024-09-03 16:42:45 UTC


README

为 Laravel 的 Google Cloud Storage 文件系统。

Author Build Status Software License Packagist Version Total Downloads

此包是一个包装器,它将 flysystem-google-storage 集成到 Laravel 中,作为一个可用的存储磁盘。

安装

composer require superbalist/laravel-google-cloud-storage

如果你使用的是 Laravel 5.4 或更早版本,请在 app.php 中注册服务提供者

'providers' => [
    // ...
    Superbalist\LaravelGoogleCloudStorage\GoogleCloudStorageServiceProvider::class,
]

如果你使用的是 Laravel 5.5 或更高版本,Composer 会自动为你注册提供者。

filesystems.php 配置文件中添加一个新的磁盘

'gcs' => [
    'driver' => 'gcs',
    'project_id' => env('GOOGLE_CLOUD_PROJECT_ID', 'your-project-id'),
    'key_file' => env('GOOGLE_CLOUD_KEY_FILE', null), // optional: /path/to/service-account.json
    'bucket' => env('GOOGLE_CLOUD_STORAGE_BUCKET', 'your-bucket'),
    'path_prefix' => env('GOOGLE_CLOUD_STORAGE_PATH_PREFIX', null), // optional: /default/path/to/apply/in/bucket
    'storage_api_uri' => env('GOOGLE_CLOUD_STORAGE_API_URI', null), // see: Public URLs below
    'visibility' => 'public', // optional: public|private
],

身份验证

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

  1. 如果你在磁盘配置中的 key_file 键中指定了一个路径,则将使用该 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

使用方法

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

// create a file
$disk->put('avatars/1', $fileContents);

// check if a file exists
$exists = $disk->exists('file.jpg');

// get file modification date
$time = $disk->lastModified('file1.jpg');

// copy a file
$disk->copy('old/file1.jpg', 'new/file1.jpg');

// move a file
$disk->move('old/file1.jpg', 'new/file1.jpg');

// get url to file
$url = $disk->url('folder/my_file.txt');

// Set the visibility of file to public
$disk->setVisibility('folder/my_file.txt', 'public');


// See https://laravel.net.cn/docs/5.3/filesystem for full list of available functionality