腾讯云对象存储上传图片小结

首先在pom文件中添加

<dependency>
    <groupId>com.qcloud</groupId>
    <artifactId>cos_api</artifactId>
    <version>5.6.8</version>
</dependency>

注意低配版本不支持130开头的APPID,会报错的

public class QCloudUtil {

    private static String bucketName;

    private static String secretId;

    private static String secretKey;

    private static String regionName;

    static {
        secretId = "SECRETID";//在腾讯云上查看
        secretKey = "SECRETKEY";
        bucketName = "存储桶的id";
        regionName = "服务器所在地区 例如:ap-chengdu";
    }

    /**
     * 上传文件到bucket
     *
     * @param in     文件流
     * @param uploadName 上传文件名
     * @return 访问地址
     */
    public static String uploadFile(InputStream in, String uploadName,Long contentLength){
        // 生成图片的唯一标识名
        String uuid = UUID.randomUUID().toString();
        int pointIndex = uploadName.lastIndexOf('.');
        // 图片名有后缀,没有就有问题了
        if (pointIndex == -1) {
            throw new CheckException("上传文件类型出错");
        }
        // 生成最终的图片名
        String filename = uuid + uploadName.substring(pointIndex);
        // 1 初始化用户身份信息(secretId, secretKey)
        COSCredentials cred = new BasicCOSCredentials(secretId, secretKey);
        // 2 设置bucket的区域
        ClientConfig clientConfig = new ClientConfig(new Region(regionName));
        // 3 生成cos客户端
        COSClient cosclient = new COSClient(cred, clientConfig);
        // bucket的命名规则为{name}-{appid} ,此处填写的存储桶名称必须为此格式
        ObjectMetadata metadata = new ObjectMetadata();
        Date expiration = new Date(new Date(System.currentTimeMillis()).getTime() + 3600L * 1000 * 24 * 365 * 100);
        metadata.setContentLength(contentLength);
        metadata.setExpirationTime(expiration);
        PutObjectRequest putObjectRequest = new PutObjectRequest(bucketName,filename,in,metadata);
        PutObjectResult putObjectResult = cosclient.putObject(putObjectRequest);
        cosclient.shutdown();
        //通过以下地址可访问到上传的图片
        return "https://" + bucketName + ".cos." + regionName +".myqcloud.com/" + filename;
    }

}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值