七牛云文件上传

七牛云文件上传

1 OSS

对象存储服务,非常适合存储静态资源,提供使用HTTP请求的方式访问资源,这样可以减轻业务服务器存储文件的压力。

很多公司都提供了存储服务,比如:阿里云,腾讯云等,这里选择了七牛云作为案例。

2 七牛云使用

如果想要使用七牛云进行 对象存储服务,需要注册账号,认证等。这些根据提示做即可。

下面直接说具体用法

1 首先找到对象存储

image-20231107160155957

2 新建空间

image-20231107160343009

3 根据SDK文档编码

image-20231107160813730

image-20231107160845795

在这里插入图片描述

这里使用maven,所以需要添加依赖

image-20231107160952068

image-20231107161020648

image-20231107161754740

直接将上面的代码复制到自己的项目中,略微修改一下即可

3 文件上传Demo

文件上传的逻辑

image-20231107161913725

1 导入依赖

<dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>com.qiniu</groupId>
            <artifactId>qiniu-java-sdk</artifactId>
            <version>[7.13.0, 7.13.99]</version>
        </dependency>
        <dependency>
            <groupId>com.google.code.gson</groupId>
            <artifactId>gson</artifactId>
            <version>2.9.1</version>
        </dependency>
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-lang3</artifactId>
        </dependency>
    </dependencies>

2 编写文件上传接口

@RestController
@RequestMapping("upload")
public class UploadController {
	
    @Autowired
    private FileUpload fileUpload;  // 自定义文件上传工具类
    @PostMapping
    public String upload(MultipartFile multipartFile) throws IOException {
        //获取到流
        InputStream inputStream = multipartFile.getInputStream();
        String url = fileUpload.upload(inputStream);
        return url;
    }
}

3 文件上传工具类

@Component
public class FileUpload {
    //文件上传路径
    private static final String FILE_URL_PREFIX="http://CDN 测试域名/";

    public String upload(InputStream inputStream){
        //构造一个带指定 Region 对象的配置类
        //注意 Region.huanan() 选择你的存储区域,这里选的是华南-广东
        Configuration cfg = new Configuration(Region.huanan());
        cfg.resumableUploadAPIVersion = Configuration.ResumableUploadAPIVersion.V2;// 指定分片上传版本
        //...其他参数参考类注释
        UploadManager uploadManager = new UploadManager(cfg);
        //...生成上传凭证,然后准备上传
        String accessKey = "你的密钥AK";
        String secretKey = "你的密钥SK";
        String bucket = "你的空间名称";
        //生成文件名  使用 fileName替换掉key
        String  fileName = System.currentTimeMillis()+""+ RandomUtils.nextInt(100,1000);
        fileName=LocalDate.now().getYear()+"/"+fileName+".webp";
        //默认不指定key的情况下,以文件内容的hash值作为文件名
//        String key = "";
        Auth auth = Auth.create(accessKey, secretKey);
        String upToken = auth.uploadToken(bucket);
        try {
            //文件上传
//                Response response = uploadManager.put(byteInputStream,key,upToken,null, null);
            Response response = uploadManager.put(inputStream, fileName, upToken,null,null);
            //解析上传成功的结果
//                DefaultPutRet putRet = new Gson().fromJson(response.bodyString(), DefaultPutRet.class);
//                System.out.println(putRet.key);
//                System.out.println(putRet.hash);
            if(response.statusCode==200){
                //上传成功,将文件的链接返回
                return FILE_URL_PREFIX+fileName;
            }
        } catch (QiniuException ex) {
            ex.printStackTrace();
            if (ex.response != null) {
                System.err.println(ex.response);
                try {
                    String body = ex.response.toString();
                    System.err.println(body);
                } catch (Exception ignored) {
                }
            }
        }
        return "失败";
    }
}

密钥获取方式:

image-20231107163525039

image-20231107163725812

CDN 测试域名的位置

image-20231107163828051

4 编写html页面

 <form action="/upload" method="post" enctype="multipart/form-data">
       <input type="file" name="multipartFile"> <br>
        <input type="submit" value="提交">
</form>

最后:项目结构

thod=“post” enctype=“multipart/form-data”>


```

最后:项目结构

image-20231107163934566

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值