PHP 使用 OSS上传文件

本文涉及的产品
对象存储 OSS,20GB 3个月
对象存储 OSS,内容安全 1000次 1年
对象存储 OSS,恶意文件检测 1000次 1年
简介: 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 官方错误排查

 

 

相关实践学习
借助OSS搭建在线教育视频课程分享网站
本教程介绍如何基于云服务器ECS和对象存储OSS,搭建一个在线教育视频课程分享网站。
目录
相关文章
|
2月前
|
PHP Android开发
android通过http上传文件,服务器端用php写(原创)
android通过http上传文件,服务器端用php写(原创)
35 4
|
2月前
|
存储 JavaScript 前端开发
oss使用SDK上传文件
oss使用SDK上传文件
674 2
|
2月前
|
弹性计算 前端开发 小程序
微信小程序上传文件至阿里云OSS直传(java后端签名+前端直传)
当前的通用文件上传方式是通过前端上传到服务器,再由服务器转存至对象存储。这种方式在处理小文件时效率尚可,但大文件上传因受限于服务器带宽,速度较慢。例如,一个100MB的文件在5Mbps带宽的阿里云ECS上上传至服务器需160秒。为解决此问题,可以采用后端签名的方式,使微信小程序直接上传文件到阿里云OSS,绕过服务器中转。具体操作包括在JAVA后端引入相关依赖,生成签名,并在微信小程序前端使用这个签名进行文件上传,注意设置正确的请求头和formData参数。这样能提高大文件上传的速度。
|
25天前
|
应用服务中间件 Linux 网络安全
PHP应用部署在App Service for Linux环境中,上传文件大于1MB时,遇见了413 Request Entity Too Large 错误的解决方法
在Azure App Service for Linux上部署的PHP应用遇到上传文件超过1MB时出现413 Request Entity Too Large错误的解决之法
|
2月前
|
Java 开发工具 对象存储
SpringBoot项目中使用阿里云Oss上传文件
SpringBoot项目中使用阿里云Oss上传文件
533 1
|
8月前
|
前端开发 JavaScript Java
阿里云OSS临时凭证前后端配合上传文件
阿里云OSS临时凭证前后端配合上传文件
152 0
|
小程序 JavaScript 前端开发
微信小程序:阿里云OSS直传实践-PHP实现服务端签名
微信小程序:阿里云OSS直传实践-PHP实现服务端签名
750 0
微信小程序:阿里云OSS直传实践-PHP实现服务端签名
|
安全 PHP 数据库
php环境无法上传文件的解决方法
php环境无法上传文件的解决方法
177 0
|
开发工具 对象存储
阿里云OSS SDK上传文件报错:String contains non ISO-8859-1 code point
阿里云OSS SDK上传文件报错:String contains non ISO-8859-1 code point
522 0