1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > 图片上传到阿里云服务器_07-文件上传到阿里云OSS实战(二)

图片上传到阿里云服务器_07-文件上传到阿里云OSS实战(二)

时间:2023-09-26 04:53:48

相关推荐

图片上传到阿里云服务器_07-文件上传到阿里云OSS实战(二)

1、创建Bucket

Bucket有点像电脑里面的盘符或者目录,我们文件的上传,必须指定上传到哪个Bucket里面。因此,在上传之前必须创建它。

在阿里云控制台点击OSS服务,然后点击【Bucket列表】就可以看到如下界面:

然后点击【创建Bucket】按钮,按下图填写:

Bucket名称:需要自己要进行命名,相当于自己文件的存储目录。

区域:这个选择很重要,因为后面调用api接口上传文件的时候需要使用。

Endpoint:这个也很重要,因为后面调用api接口上传文件的时候也需要使用。

上述选择完成后,就可以点击【确定】按钮进行创建了。

创建成功后,进入Bucket信息页面,可以点击左侧的【文件管理】按钮,出现如下界面:

好了,到此为止,阿里云的OSS配置就算完成了,新手对于这个过程感觉十分困惑,因此我这里说的比较详细。

2、OSS流式上传

下面是官网文档地址以及官方代码,我摘抄了几个入门级的代码。

/document_detail/84781.html?spm=a2c4g.11186623.6.787.101245dcJzaFge

(1)上传字符串

// Endpoint以杭州为例,其它Region请按实际情况填写。String endpoint = "http://oss-cn-";// 阿里云主账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM账号进行API访问或日常运维,请登录 https://ram. 创建RAM账号。String accessKeyId = "";String accessKeySecret = "";// 创建OSSClient实例。OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);// 创建PutObjectRequest对象。String content = "Hello OSS";// 表示上传文件到OSS时需要指定包含文件后缀在内的完整路径,例如abc/efg/123.jpg。PutObjectRequest putObjectRequest = new PutObjectRequest("", "", new ByteArrayInputStream(content.getBytes()));// 如果需要上传时设置存储类型与访问权限,请参考以下示例代码。// ObjectMetadata metadata = new ObjectMetadata();// metadata.setHeader(OSSHeaders.OSS_STORAGE_CLASS, StorageClass.Standard.toString());// metadata.setObjectAcl(CannedAccessControlList.Private);// putObjectRequest.setMetadata(metadata);// 上传字符串。ossClient.putObject(putObjectRequest);// 关闭OSSClient。ossClient.shutdown();

(2)上传Byte数组

// Endpoint以杭州为例,其它Region请按实际情况填写。String endpoint = "http://oss-cn-";// 阿里云主账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM账号进行API访问或日常运维,请登录 https://ram. 创建RAM账号。String accessKeyId = "";String accessKeySecret = "";// 创建OSSClient实例。OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId,accessKeySecret);// 上传Byte数组。byte[] content = "Hello OSS".getBytes();ossClient.putObject("", "", new ByteArrayInputStream(content));// 关闭OSSClient。ossClient.shutdown();

(3)上传网络流

// Endpoint以杭州为例,其它Region请按实际情况填写。String endpoint = "http://oss-cn-";// 阿里云主账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM账号进行API访问或日常运维,请登录 https://ram. 创建RAM账号。String accessKeyId = "";String accessKeySecret = "";// 创建OSSClient实例。OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);// 上传网络流。InputStream inputStream = new URL("/").openStream();ossClient.putObject("", "", inputStream);// 关闭OSSClient。ossClient.shutdown();

(4)上传文件流

// Endpoint以杭州为例,其它Region请按实际情况填写。String endpoint = "http://oss-cn-";// 云账号AccessKey有所有API访问权限,建议遵循阿里云安全最佳实践,创建并使用RAM子账号进行API访问或日常运维,请登录 https://ram. 创建。String accessKeyId = "";String accessKeySecret = "";// 创建OSSClient实例。OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);// 上传文件流。InputStream inputStream = new FileInputStream("");ossClient.putObject("", "", inputStream);// 关闭OSSClient。ossClient.shutdown();

3、简单文件上传

// Endpoint以杭州为例,其它Region请按实际情况填写。String endpoint = "http://oss-cn-";// 阿里云主账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM账号进行API访问或日常运维,请登录 https://ram. 创建RAM账号。String accessKeyId = "";String accessKeySecret = "";// 创建OSSClient实例。OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);// 创建PutObjectRequest对象。PutObjectRequest putObjectRequest = new PutObjectRequest("", "", new File(""));// 如果需要上传时设置存储类型与访问权限,请参考以下示例代码。// ObjectMetadata metadata = new ObjectMetadata();// metadata.setHeader(OSSHeaders.OSS_STORAGE_CLASS, StorageClass.Standard.toString());// metadata.setObjectAcl(CannedAccessControlList.Private);// putObjectRequest.setMetadata(metadata);// 上传文件。ossClient.putObject(putObjectRequest);// 关闭OSSClient。ossClient.shutdown();

4、通过自定义WEB接口上传文件

首先我们来定一个阿里云OSS文件上传的一个工具类,具体代码如下:

package com.shenmazong.utils;import com.aliyun.oss.OSS;import com.aliyun.oss.OSSClientBuilder;import com.aliyun.oss.model.PutObjectResult;import org.springframework.web.multipart.MultipartFile;import java.io.IOException;import java.util.UUID;public class UploadFileUtils { /*** TODO uploadAliyunOss 阿里云OSS文件上传* @param file* @param fileName* @return*/ public static String uploadAliyunOss(MultipartFile file, String fileName) { String url = null; // Endpoint以杭州为例,其它Region请按实际情况填写。 String endpoint = "http://oss-cn-"; // 阿里云主账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM账号进行API访问或日常运维,请登录 https://ram. 创建RAM账号。 // shenmazong@ String accessKeyId = "XXXX"; String accessKeySecret = "XXXX"; // 创建OSSClient实例。 OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret); // 创建PutObjectRequest对象。 // 上传文件流。 PutObjectResult result = null; String newName = UUID.randomUUID().toString(); try { result = ossClient.putObject("shenmazong", fileName, file.getInputStream()); url = "https://shenmazong.oss-cn-/" + fileName; } catch (IOException e) { e.printStackTrace(); return null; } // 关闭OSSClient。 ossClient.shutdown(); return url; }}

上面的工具类,是传输web上传的文件流,然后返回能够访问的url,这样我们web网上实现图片文件上传,就很容易了。

下面我们就可以编写service来实现我们的文件上传接口了。

/*** TODO 实现用户头像的上传* @param userId* @param file* @return*/ @Override public ResponseResult uploadHead(Integer userId, MultipartFile file) { ResponseResult result = ResponseResult.SUCCESS(); //--1 验证用户是否存在 TbUser user = iTbUserMapper.selectById(userId); if(user == null) { result.setCode(-1); result.setMessage("获取用户信息失败"); return result; } //--2 上传文件 if(file.isEmpty()){ log.info("上传文件为空"); result.setCode(-1); result.setMessage("上传文件为空"); return result; } String fileName = file.getOriginalFilename(); int size = (int) file.getSize(); log.info(fileName + "-->" + size); UUID uuid = UUID.randomUUID(); String suffix = fileName.substring(fileName.lastIndexOf(".")).toLowerCase(); String newName = uuid.toString() + suffix; String headUrl = UploadFileUtils.uploadAliyunOss(file, newName); if(headUrl == null) { result.setCode(-1); result.setMessage("上传文件到OSS失败"); return result; } //--3 修改用户头像链接 user.setHeadurl(headUrl); iTbUserMapper.updateById(user); return result; }

service写好以后,就需要编写controller了,具体代码如下:

/*** TODO uploadHead 上传头像图片* @param userId* @param file* @return*/ @ApiOperation(value = "头像上传", notes = "用户上传更新自己的头像") @ApiImplicitParams(value = { @ApiImplicitParam(name = "userId", value = "用户ID", required = true, dataType = "int", example = "0") }) @PostMapping(value = "/uploadHead", headers = "content-type=multipart/form-data") public ResponseResult uploadHead(@RequestParam("userId") Integer userId, @RequestParam("uploadFile") MultipartFile file) { return userService.uploadHead(userId, file); }

最后是html页面的示例代码,也一并贴上来:

选择文件

Example block-level help text here.

上传

最后的实例演示,是我在一个演示项目中拷贝过来的代码,没有针对咱们这个教程进行整理,但是作为参考资料,这部分代码是合格的。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。