阿里对象存储OSS在laravel框架中的使用方法
最近比较忙,也没来得及写博客。加上最近也确实没有接触到什么新技术,有点尴尬。。。
在昨天算是第一次接触对象存储这个东西,研究了一天,算是在项目中走得通了,所以在此分享给大家,是最基础的OSS上传图片部分,希望能自己以后能少踩坑,也希望能帮助到大家。
首先呢,现在百度出来的,基本都是laravel大神自己封装的composer包,可惜我实在是不能用,所以只能老老实实的在项目中引入SDK了。。。
1、引入阿里的SDK文件
如图所示,其实我也不知道该放哪里合适,不过laravel的好处是命名空间比较好使,所以我直接把SDK重命名为OSS,然后目录路径为:App\Helpers\OSS
2、就是修改命名空间,主要是你能用得上的文件,大概有7-8个,把命名空间都定义好
3、修改配置文件,config.php,这个是SDK中的配置文件,需要把相应的配置写清楚
(坑:endpoint这个部分,前面一定不要加你的bucket,不然就重复了。。。例如,我的endpoint是
'oss-cn-shanghai.aliyuncs.com' )
4、都配置的差不多了,接下来就是上传文件了
public static function uploadOne($filename) { $file = \Illuminate\Support\Facades\Request::file($filename); if (!$file) { exit("请上传图片"); } // 文件是否上传成功 if ($file->isValid()) { // 获取文件相关信息 $originalName = $file->getClientOriginalName(); // 文件原名 $ext = $file->getClientOriginalExtension(); // 扩展名 $realPath = $file->getRealPath(); //临时文件的绝对路径 $type = $file->getClientMimeType(); // image/jpeg $content = date('Y-m-d-H-i-s') . '-' . uniqid() . '.' . $ext; require_once(base_path() . '/app/Helpers/Oss/autoload.php'); $bucket = Config::OSS_TEST_BUCKET; $accessKeyId = Config::OSS_ACCESS_ID; $accessKeySecret = Config::OSS_ACCESS_KEY; $endpoint = Config::OSS_ENDPOINT; $ossClient = Common::getOssClient(); /*var_dump($ossClient); exit;*/ $object = "user/" . $content; $filePath = $file; $result = $ossClient->UploadFile($bucket, $object, $filePath); if (!$result) { exit("上传图片失败"); } return $content; } }
上代码,主要从require_once开始的,引入SDK的加载文件,然后把各项配置通过config引入进来。
$object是你要存储的文件。比如楼主这里,就是相当于存储在bucket下的user文件下。然后通过
$filePath = $file来获得图片的内容,使用UploadFile方法进行上传。然后看返回值,成功即可。
5、遇到的坑:首先是SDK中的autoload.php一直报错,
function classLoader($class) { $path = str_replace('\\', DIRECTORY_SEPARATOR, $class); $file = __DIR__ . DIRECTORY_SEPARATOR .'src'. DIRECTORY_SEPARATOR . $path . '.php'; if (file_exists($file)) { require_once $file; } } /*spl_autoload_register('classLoader');*/
像这样的,我就直接注释了,也没什么后果,不过在后面可能会用得上吧,需要继续研究
其次就是上传的时候遇到的小问题了,这个根据错误提示修改即可,一般来说按我的走,能实现基本的上传图片,如果是上传文件的话,直接修改上传方法:$ossClient->putobj()就可以了
总结:我这个只是最基础的后台上传。未来做APP上传的时候,肯定是需要ajax先获取一个加密码,然后再url中加上这个加密码进行识别,,还有就是图片的删除等问题,仍需研究。。。以后如果研究好了,就再分享给大家。