将S3 URL存储在数据库表中


Store S3 URL in database table

我正在Laravel 5.2 中构建一个小型资产管理系统

用户可以将图像、视频等上传到应用程序,资产元数据存储在资产表中。在这种情况下,资产被重命名以匹配资产id(我也存储原始文件名),我存储mime类型并将文件上传到S3。

我遇到的问题是将S3 url存储在数据库中。

这是我的方法

public function store(AssetRequest $request)
    {
        // Initialise new asset and set the name
        // from the form
        $asset = new Asset(array(
            'name' => $request->get('name')
        ));
        $asset->user_id = Auth::user()->id;
        // save the asset to the db
        $asset->save();
        // set the file var = form input
        $file = $request->file('asset_path');
        $extension = $file->getClientOriginalExtension();
        // modify the asset name
        $assetFile = $asset->id . '.' . $request->file('asset_path')->getClientOriginalExtension();
        // push the new asset to s3
        Storage::disk('s3')->put('uploads/' . $assetFile, file_get_contents($file));
        $asset->mime = $file->getClientMimeType();
        $s3Url = Storage::url($file);
        $asset->s3_url = $s3Url;
        $asset->original_filename = $file->getClientOriginalName();
        $asset->filename = $assetFile;
        $asset->file_extension = $extension;
        // return ok
        $asset->save();
        return 'Redirect::route('asset.create')->with('message', 'Asset added!');
    }

与我尝试存储S3 url 有关的行

$s3Url = Storage::url($file); $asset->s3_url = $s3Url; 似乎只存储了一个临时路径/storage//tmp/php8su2r0,而不是实际的S3 url。我想避免手动设置bucket,而是希望我可以使用config/filesystem.php 中配置的内容

有什么想法吗?

您可以使用config(key)函数助手从配置中获取所有内容因此,要获得文件的s3公共url,请执行以下操作:

function publicUrl($filename){
        return "http://".config('filesystems.disks.s3.bucket').".s3-website.".config('filesystems.disks.s3.region').".amazonaws.com/".$filename;
    }

或者你可以使用底层的S3Client:(取自此处)

$filesystem->getAdapter()->getClient()->getObjectUrl($bucket, $key);

您正在努力实现的目标,我已经在许多项目中做到了。

您所需要做的就是在数据库中创建image_url列。并传递s3 bucket链接+文件名+扩展名。

你应该知道对我来说不变的一点,比如:https://s3-eu-west-1.amazonaws.com/backnine8/fitness/events/那么我有身份证和分机号。在您的情况下,它可以是名称和扩展名。

if(Input::get('file')) {
        $extension = pathinfo(Input::get('filename'), PATHINFO_EXTENSION);
        $file = file_get_contents(Input::get('file'));
        $s3 = AWS::get('s3');
        $s3->putObject(array(
            'ACL'        => 'public-read',
            'Bucket'     => 'backnine8',
            'Key'        => '/fitness/events/'.$event->id.'.'.$extension,
            'Body' => $file,
        ));
        $event->image_url = 'https://s3-eu-west-1.amazonaws.com/backnine8/fitness/events/'.$event->id.'.'.$extension;
        $event->save();
        }