群控系统服务端开发模式-应用开发-腾讯云上传工厂及七牛云上传工厂开发

记住业务流程图,要不然不清楚自己封装的是什么东西。

一、腾讯云工厂开发

切记在根目录下要安装腾讯云OSS插件,具体代码如下:

复制代码
composer require qcloud/cos-sdk-v5

在根目录下extend文件夹下Upload文件夹下channel文件夹中,我们修改TencentUpload业务控制器。具体代码如下:

复制代码
<?php
/**
 * 腾讯云上传工厂
 * User: 龙哥 三年风水
 * Date: 2024/11/2/0002
 * Time: 18:18
 */
namespace Upload\channel;
use Qcloud\Cos\Client;
use Upload\UploadHandle;
use Error\BaseError;
class TencentUpload extends UploadHandle
{
    protected $accessKey = '';//access_key
    protected $secretKey = '';//secret_key
    protected $bucket = '';//包
    protected $name = '';//访问地址
    protected $domainName = '';//访问地址

    public function __construct($param)
    {
        $this->accessKey = $param['access_key'];
        $this->secretKey = $param['secret_key'];
        $this->bucket = $param['bucket'];
        $this->name = $param['name'];
        $this->domainName = $param['domain_name'];
    }

    /**
     * 上传操作
     * @ param $object 加密后的文件
     * @ param $filePath 临时存放的文件路径
     * @ return mixed
     */
    public function uploadFile($object, $filePath)
    {
        $ossClient = new Client(array(
            'region' => 'ap-nanjing',
            'schema' => 'http', //协议头部,默认为http
            'credentials' => array(
                'secretId' => $this->accessKey,
                'secretKey' => $this->secretKey
            )
        ));
        try {
            $file = fopen($filePath,'rb');
            if ($file) {
                $res = $ossClient->Upload($this->bucket, $object,$file);
                if($res==true)return empty($this->domainName) ? $this->name.'/'.$res['Key'] : $this->domainName.'/'.$res['Key'];
            }
        } catch (\Exception $e) {
            throw new BaseError($e->getMessage(),50000,200);
        }
    }

    /**
     * 删除操作
     * @ param $object 具体的文件地址
     * @ return mixed
     */
    public function deleteFile($object)
    {
        // TODO: Implement deleteFile() method.
    }
}

二、七牛云工厂开发

切记在根目录下要安装七牛云OSS插件,具体代码如下:

复制代码
composer require qiniu/php-sdk

在根目录下extend文件夹下Upload文件夹下channel文件夹中,我们修改QiniuyunUpload业务控制器。具体代码如下:

复制代码
<?php
/**
 * 七牛云上传工厂
 * User: 龙哥 三年风水
 * Date: 2024/11/2/0002
 * Time: 18:19
 */
namespace Upload\channel;
use Qiniu\Auth;
use Qiniu\Storage\UploadManager;
use Upload\UploadHandle;
use Error\BaseError;
class QiniuyunUpload extends UploadHandle
{
    protected $accessKey = '';//access_key
    protected $secretKey = '';//secret_key
    protected $bucket = '';//包
    protected $name = '';//访问地址
    protected $domainName = '';//访问地址

    public function __construct($param)
    {
        $this->accessKey = $param['access_key'];
        $this->secretKey = $param['secret_key'];
        $this->bucket = $param['bucket'];
        $this->name = $param['name'];
        $this->domainName = $param['domain_name'];
    }

    /**
     * 上传操作
     * @ param $object 加密后的文件
     * @ param $filePath 临时存放的文件路径
     * @ return mixed
     */
    public function uploadFile($object, $filePath)
    {
        $auth = new Auth($this->accessKey,$this->secretKey);
        $token = $auth->uploadToken( $this->bucket);
        $uploadMgr = new UploadManager();
        list($info, $error) = $uploadMgr->putFile($token, $object, $filePath);
        if(!empty($error) && empty($info['key']))throw new BaseError($error,50000,200);
        return $this->name.'/'.$info['key'];
    }

    /**
     * 删除操作
     * @ param $object 具体的文件地址
     * @ return mixed
     */
    public function deleteFile($object)
    {
        // TODO: Implement deleteFile() method.
    }
}

三、提前说明

明天开发上传接口及调试,如果有时间的情况下,就将删除补充起来。

相关推荐
cts61813 分钟前
Milvus分布式数据库工作职责
数据库·分布式·milvus
笑衬人心。17 分钟前
TCP 拥塞控制算法 —— 慢启动(Slow Start)笔记
笔记·tcp/ip·php
2401_831501731 小时前
Linux之Zabbix分布式监控篇(二)
数据库·分布式·zabbix
cui_win10 小时前
Kafka 配置参数详解:ZooKeeper 模式与 KRaft 模式对比
分布式·zookeeper·kafka
liux352812 小时前
Zabbix 分布式监控系统架构设计与优化
分布式·zabbix
cui_win14 小时前
深入理解 Kafka 核心:主题、分区与副本的协同机制
网络·分布式·kafka
iblade14 小时前
网络:TCP序列号和滑动窗口,顺序保证
网络·tcp/ip·php
淦暴尼14 小时前
基于spark的二手房数据分析可视化系统
大数据·分布式·数据分析·spark
工控小楠16 小时前
CCLink IE转ModbusTCP网关配置无纸记录器(中篇)
服务器·网络·php
黄雪超17 小时前
Kafka——无消息丢失配置怎么实现?
大数据·分布式·kafka