阿里云OSS后端签名获取

/**
     * 获取授权签名
     * @return array
     * @throws \Exception
     * Created on 2020/9/29 3:42 下午
     * Create by liuyang
     */
public function actionGetOssUplosdconfig()
    {
        $data = \Yii::$app->request->post();
        $dir = ArrayHelper::getValue($data, 'dir', '');
        if (!$dir) return ['code' => 40001, 'msg' => '缺少上传前缀!'];//就是文件夹

        $allConfig = \Yii::$app->params['ossConfig'];
        $ossConfigKey = ArrayHelper::getValue($data, 'ossConfig', 'oss_01');
        $ossConfig = ArrayHelper::getValue($allConfig, $ossConfigKey);
        $accessKeyId = ArrayHelper::getValue($ossConfig, 'AccessKeyId');
        $accessKeySecret = ArrayHelper::getValue($ossConfig, 'AccessKeySecret');
        $host = ArrayHelper::getValue($ossConfig, 'host');
        $id = $accessKeyId;          //AccessKeyId。
        $key = $accessKeySecret;     //AccessKeySecret。
        /**屏蔽服务端回调
        $callbackUrl = 'http://88.88.88.88:8888/aliyun-oss-appserver-php/php/callback.php';
        $callback_param = array('callbackUrl' => $callbackUrl,
            'callbackBody' => 'filename=${object}&size=${size}&mimeType=${mimeType}&height=${imageInfo.height}&width=${imageInfo.width}',
            'callbackBodyType' => "application/x-www-form-urlencoded");
        $callback_string = json_encode($callback_param);
        $base64_callback_body = base64_encode($callback_string);
        **/
        $now = time();
        $expire = 30;  //设置该policy超时时间是10s. 即这个policy过了这个有效时间,将不能访问。
        $end = $now + $expire;
        $expiration = $this->gmt_iso8601($end);

        //最大文件大小.用户可以自己设置
        $condition = array(0 => 'content-length-range', 1 => 0, 2 => 1048576000);
        $conditions[] = $condition;

        // 表示用户上传的数据,必须是以$dir开始,不然上传会失败,这一步不是必须项,只是为了安全起见,防止用户通过policy上传到别人的目录。
        $start = array(0 => 'starts-with', 1 => '$key', 2 => $dir);
        $conditions[] = $start;

        $arr = array('expiration' => $expiration, 'conditions' => $conditions);
        $policy = json_encode($arr);
        $base64_policy = base64_encode($policy);
        $string_to_sign = $base64_policy;
        $signature = base64_encode(hash_hmac('sha1', $string_to_sign, $key, true));

        $response = array();
        $response['accessid'] = $id;
        $response['host'] = $host;
        $response['policy'] = $base64_policy;
        $response['signature'] = $signature;
        $response['expire'] = $end;
//      $response['callback'] = $base64_callback_body;
        $response['callback'] = '';
        $response['dir'] = $dir;  // 这个参数是设置用户上传文件时指定的前缀。
        return [
            'code' => 40000,
            'data' => $response
        ];
    }

    /**
     * 处理时间
     * @param $time
     * @return string
     * Created on 2020/9/29 11:04 上午
     * Create by liuyang
     * @throws \Exception
     */
    private function gmt_iso8601($time)
    {
        $dtStr = date("c", $time);
        $mydatetime = new DateTime($dtStr);
        $expiration = $mydatetime->format(DateTime::ISO8601);
        $pos = strpos($expiration, '+');
        $expiration = substr($expiration, 0, $pos);
        return $expiration . "Z";
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值