PHP 使用 OSS上传文件
一、安装阿里云 oss sdk
1、在网站根目录执行下面命令,安装oss sdk。
composer require aliyuncs/oss-sdk-php
安装后,会在 网站根目录/vendor 下找到一个名为 aliyuncs
的文件夹。
注:阿里云 oss - sdk 文档(可不用关注) "官方 oss - sdk 文档"
二、使用
1、获取 OSS AccessKeyId、AccessKeySecret
如果没有这两个数据可以参考 如何获取 OSS AccessKeyId、AccessKeySecret 。
2、简易上传 Html 处理
upload.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>小卜丢个人站 - oss图片上传</title> </head> <body> <form action="oss-image/upload-image.json" method="post" enctype="multipart/form-data"> <label for="file">文件名:</label> <input type="file" name="image" id="file"><br> <input type="submit" name="submit" value="提交"> </form> </body> </html>
3、控制器处理 OssImageController.php(直接将请求发送到service,不用关注此层)
<?php declare(strict_types = 1); namespace app\controllers; use app\services\OssImageService; class OssImageController extends BaseController { /** * oss上传图片 * * @return string * @throws \OSS\Core\OssException */ public function actionUploadImage() { return $this->response(OssImageService::service()->uploadImage()); } }
4、service层处理 OssImageService.php(PHP处理在此层,关注此层即可)
<?php declare(strict_types = 1); namespace app\services; use app\extensions\AliOss; class OssImageService extends BaseService { /** * oss上传图片 * * @return array * @throws \OSS\Core\OssException */ public function uploadImage() { $ossClient = AliOss::getOssClient(); $bucketName = AliOss::getBucketName(); // 文件名 $fileName = $_FILES['image']['name']; // 临时文件位置 $tmpFile = $_FILES['image']['tmp_name']; // 定义文件存储的oss位置 $ossPath = 'test/'.date('Y-m-d').'/'.date('Hi') .mt_rand(10000,99999); // 定义oss object $object = $ossPath .'.' .$this->getExtension($fileName); // 执行上传并获取返回 oss 信息 $info = $ossClient->uploadFile($bucketName, $object, $tmpFile); $ossUrl = $info['oss-request-url']; // 如果图片的协议是http,则转换成https if (substr($ossUrl, 0, 4) == 'http') { $ossUrl = substr_replace($ossUrl, 'https', 0, 4); } $data = [ 'file_url' => $ossUrl, 'file_name' => basename($ossUrl) ]; return $data; } /** * 返回文件扩展名 * * @param $fileName * @return mixed */ private function getExtension($fileName) { return pathinfo($fileName)['extension']; } }
5、oss 实例及参数获取封装 AliOss.php
<?php declare(strict_types = 1); namespace app\extensions; use OSS\OssClient; use OSS\Core\OssException; /** *阿里云oss文件上传 */ class AliOss { const endpoint = 'oss-cn-hongkong.aliyuncs.com'; const accessKeyId = 'LSDFskkdDDSSdkfg'; const accessKeySecret = 'LT9cG3JkGKffRPalgk4n33lk8Ll41d'; const bucket = 'hk-server'; /** * 根据Config配置,得到一个OssClient实例 * * @return OssClient 一个OssClient实例 */ public static function getOssClient() { try { $ossClient = new OssClient(self::accessKeyId, self::accessKeySecret, self::endpoint, false); } catch (OssException $e) { printf(__FUNCTION__ . "creating OssClient instance: FAILED\n"); printf($e->getMessage() . "\n"); return null; } return $ossClient; } public static function getBucketName() { return self::bucket; } }
6、结果是可以上传成功并返回图片在oss中的完整访问url的
{ status: 1, msg: "success", data: { file_url: "http://hk-server.oss-cn-hongkong.aliyuncs.com/test/2018-08-22/211753008.jpg", file_name: "211753008.jpg" } }
这时,我们访问 http://hk-server.oss-cn-hongkong.aliyuncs.com/test/2018-08-22/211753008.jpg 就可以正常获取到图片了,并且在oss管理控制台也是可以找到上传的文件的。
这只是将文件上传到 oss 上,并将 文件的 url 返给前端,但还没有将文件的信息存在本地。这里建议前端接收到该url后,连同文件的其他数据(比如分类、文件名等)再请求后端的另外的接口,进行本地数据库的信息存储。
三、问题说明
可能会出现 The OSS Access Key Id you provided does not exist in our records 等问题,不要慌,重新生成一下就好了。
另外,遇到这类 阿里云 oss 官方返回的错误时,我们可以参考 oss 官方错误排查 。

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
《菜鸟程序员成长之路:从技术小白到阿里巴巴Java工程师》
《菜鸟程序员成长之路:从技术小白到阿里巴巴Java工程师》 国庆节快乐!一年一度长度排第二的假期终于来了。 难得有十一长假,作者也想要休息几天啦。 不管你是选择出门玩,还是在公司加班,在学校复习,都希望你过好这个长假。 没有出去玩的也不用羡慕别人,利用这段时间充充电,不比去旅游看人头要好的多吗? 最近终于把我的原创文章整理成一本电子书了,趁着国庆开始之前发布出来,希望对你有所帮助。 这本电子书整理了我过去一年时间里在微信公众号【黄小斜】里创作的文章,包括Java学习、求职面试、成长心得、感悟思考、程序人生等多个主题的内容,这些内容的主线,就是告诉读者,我是如何从一个技术小白一步步自学成为阿里巴巴工程师的,我把我一路的学习历程、成长经历、求职和工作的心得都记录了下来,并且通过写作的方式分享给更多走在这条路上的人们,希望对你们有所帮助。 我于2016年本科毕业,跨专业考上985软件工程,而后经过两年时间的自学,在2019年秋招期间拿到了BAT等10家互联网大厂的研发offer,顺利成为阿里巴巴的一名Java工程师,谨以本书把我的所学,所思,所得所想分享给有需要的人。 如果想看及时看到我的最...
- 下一篇
JavaScript ~ 排序算法(选择排序)
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <link type="text/css" rel="stylesheet" href="style/flex.css"> <style> body{ } #sort{ width: 1200px; height: auto; background: #FFFFFF; color: #606060; position: relative; } #title{ width: 100%; height: 60px; background: #9dc4d4; color: #FFFFFF; font-size: 28px; } #nav{ width: 100%; height: 60px; background: #ff6600; } .nav_item{ width: 70px; height: 50px; line-heigh...
相关文章
文章评论
共有0条评论来说两句吧...