腾讯云cos 临时密钥 适用于前端直传等临时授权场景

composer添加

php 复制代码
"qcloud_sts/qcloud-sts-sdk": "^3.0",
 "tencentcloud/sts": "^3.0"

执行

php 复制代码
composer require qcloud_sts/qcloud-sts-sdk
composer require tencentcloud/sts

然后就可以直接使用了

$params参数可以看官网去设置:对象存储-临时密钥生成及使用指引

php 复制代码
try {
            // 实例化一个认证对象,入参需要传入腾讯云账户 SecretId 和 SecretKey,此处还需注意密钥对的保密
            // 代码泄露可能会导致 SecretId 和 SecretKey 泄露,并威胁账号下所有资源的安全性。以下代码示例仅供参考,建议采用更安全的方式来使用密钥,请参见:https://cloud.tencent.com/document/product/1278/85305
            // 密钥可前往官网控制台 https://console.cloud.tencent.com/cam/capi 进行获取
            $cred = new Credential(Env::get('COS_SECRET_ID'), Env::get('COS_SECRET_KEY'));
            // 实例化一个http选项,可选的,没有特殊需求可以跳过
            $httpProfile = new HttpProfile();
            $httpProfile->setEndpoint("sts.tencentcloudapi.com");

            // 实例化一个client选项,可选的,没有特殊需求可以跳过
            $clientProfile = new ClientProfile();
            $clientProfile->setHttpProfile($httpProfile);
            // 实例化要请求产品的client对象,clientProfile是可选的
            $client = new StsClient($cred, "ap-guangzhou", $clientProfile);

            // 实例化一个请求对象,每个接口都会对应一个request对象
            $req = new GetFederationTokenRequest();

            $params = array(
                "Name" => "test",
                "Policy" => "{\"version\":\"2.0\",\"statement\":[{\"effect\":\"allow\",\"action\":[\"name/cos:PutObject\",\"name/cos:DeleteObject\",\"name/cos:InitiateMultipartUpload\",\"name/cos:ListMultipartUploads\",\"name/cos:ListParts\",\"name/cos:UploadPart\",\"name/cos:CompleteMultipartUpload\"],\"resource\":\"*\"}]}",
                "DurationSeconds" => 1800
            );
            $req->fromJsonString(json_encode($params));

            // 返回的resp是一个GetFederationTokenResponse的实例,与请求对象对应
            $resp = $client->GetFederationToken($req);

            $return = [];
            $return['sts'] = $resp;
            $return['bucket'] = Env::get('COS_BUCKET').'-'.Env::get('COS_APP_ID');
            $return['start_time'] = strtotime(date('Y-m-d H:i:s'));
            $return['region'] = Env::get('COS_REGION');
            // 输出json格式的字符串回包
            return success($return);
        }
        catch(TencentCloudSDKException $e) {
            return failure(1, $e->getMessage());
        }
相关推荐
星晨雪海3 分钟前
优惠券秒杀的核心业务逻辑
java·前端·数据库
Bigger4 分钟前
第五章:我是如何剖析 Claude Code 的 MCP 服务与插件生态系统的
前端·ai编程·claude
买大橘子也用券5 分钟前
one_line_php-wp
web安全·网络安全·php
AI周红伟10 分钟前
Hermes Agent 工具-周红伟
linux·网络·人工智能·腾讯云·openclaw
许彰午15 分钟前
# 政务表单动态建表?运行时DDL引擎,前端拖完字段后端直接建
java·前端·后端·架构·政务
San30.17 分钟前
前端渲染:从 CSR、SSR 到同构与手写 Vite+React SSR 实践
前端·react.js·前端框架
三声三视18 分钟前
React 19 正式发布!17 个新特性深度解析与迁移指南(2026 实战版)
前端·javascript·reactjs·react
滴滴答答哒21 分钟前
c#将平铺列表转换为树形结构(支持孤儿节点作为独立根节点)
java·前端·c#
雨季mo浅忆21 分钟前
第四项目梳理
前端·面试·vue2
a11177621 分钟前
三维地图可视化 ThreeJS vue 开源项目
前端·javascript·vue.js