【在线教育】课程封面上传图片到阿里云OSS(二)

本文涉及的产品
对象存储 OSS,OSS 加速器 50 GB 1个月
简介: 【在线教育】课程封面上传图片到阿里云OSS

1.3 快速入门


1.3.1 下载SDK


  • 在“常用入口”中,点击“SDK下载”
  • image.png

image.png

1.3.2 搭建环境


  • 创建项目:zx-test-oss31
  • 添加坐标
<dependency><groupId>com.aliyun.oss</groupId><artifactId>aliyun-sdk-oss</artifactId><version>3.15.0</version></dependency>

1.3.2 创建存储空间[可选]


例如:packagecom.czxy;
importcom.aliyun.oss.OSS;
importcom.aliyun.oss.OSSClientBuilder;
importorg.junit.Test;
/*** @author 桐叔* @email liangtong@itcast.cn*/publicclassTestOss {
@TestpublicvoidtestCreateBucket() {
// Endpoint以杭州为例,其它Region请按实际情况填写。Stringendpoint="oss-cn-shanghai.aliyuncs.com";
// 阿里云主账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM账号进行API访问或日常运维,请登录RAM控制台创建RAM账号。StringaccessKeyId="这里是账号";
StringaccessKeySecret="这里是密码";
StringbucketName="czxy-lt-01";
// 创建OSSClient实例。OSSossClient=newOSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);
// 创建存储空间。ossClient.createBucket(bucketName);
// 关闭OSSClient。ossClient.shutdown();
    }
}

image.png

1.3.3 上传图片


  • 参考代码位置:

image.png

  • 例如:
@TestpublicvoidtestUpload() throwsFileNotFoundException {
// yourEndpoint填写Bucket所在地域对应的Endpoint。以华东1(杭州)为例,Endpoint填写为https://oss-cn-hangzhou.aliyuncs.com。Stringendpoint="oss-cn-shanghai.aliyuncs.com";
// 阿里云账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM用户进行API访问或日常运维,请登录RAM控制台创建RAM用户。StringaccessKeyId="这是账号";
StringaccessKeySecret="这是密码";
// 创建OSSClient实例。OSSossClient=newOSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);
Stringpath="avatar/"+System.currentTimeMillis() +".png";
// 数据流InputStreaminputStream=newFileInputStream("C:/Users/Administrator/Desktop/1/cz.png");
// 填写Bucket名称和Object完整路径。Object完整路径中不能包含Bucket名称。ossClient.putObject("czxy-lt", path, inputStream);
// 关闭OSSClient。ossClient.shutdown();
// https://czxy-lt.oss-cn-shanghai.aliyuncs.com/avatar/1616253283637.pngStringurl="https://czxy-lt.oss-cn-shanghai.aliyuncs.com/"+path;
System.out.println(url);
}

2. 课程管理--课程封面


2.1 需求


image.png

2.2 前端实现


2.2.1 上传成功处理


  • 添加上传组件和头像组件
<el-form-itemlabel="课程封面"><el-uploadclass="upload-demo"            :action="updateUrl"list-type="picture-card"            :limit="1"            :on-exceed="handleExceed"            :on-success="avatarUploadSuccess"><el-buttonsize="small"type="primary">点击上传</el-button><divslot="tip"class="el-upload__tip">只能上传jpg/png文件,且不超过500kb</div></el-upload><el-avatarshape="square" :size="50" :src="course.cover"></el-avatar></el-form-item>编写上传路径data() {
return {
updateUrl: process.env.VUE_APP_BASE_API+'/course-service/course/avatar/upload',   //上传路径    }
}
编写处理函数:上传成功后,显示头像handleExceed(files, fileList) {     //默认this.$message.warning(`当前限制选择3个文件,本次选择了${files.length} 个文件,共选择了${files.length+fileList.length} 个文件`);
    },
avatarUploadSuccess(response) {
// 设置头像this.course.cover=response.data    }



相关实践学习
对象存储OSS快速上手——如何使用ossbrowser
本实验是对象存储OSS入门级实验。通过本实验,用户可学会如何用对象OSS的插件,进行简单的数据存、查、删等操作。
相关文章
|
5月前
|
存储 人工智能 Cloud Native
阿里云渠道商:OSS与传统存储系统的差异在哪里?
本文对比传统存储与云原生对象存储OSS的架构差异,涵盖性能、成本、扩展性等方面。OSS凭借高持久性、弹性扩容及与云服务深度集成,成为大数据与AI时代的优选方案。
|
7月前
|
存储 运维 安全
阿里云国际站OSS与自建存储的区别
阿里云国际站对象存储OSS提供海量、安全、低成本的云存储解决方案。相比自建存储,OSS具备易用性强、稳定性高、安全性好、成本更低等优势,支持无限扩展、自动冗余、多层防护及丰富增值服务,助力企业高效管理数据。
|
7月前
|
存储 域名解析 前端开发
震惊!不买服务器,还可以用阿里云国际站 OSS 轻松搭建静态网站
在数字化时代,利用阿里云国际站OSS可低成本搭建静态网站。本文详解OSS优势及步骤:创建Bucket、上传文件、配置首页与404页面、绑定域名等,助你快速上线个人或小型业务网站,操作简单,成本低廉,适合初学者与中小企业。
|
机器学习/深度学习 人工智能 专有云
人工智能平台PAI使用问题之怎么将DLC的数据写入到另一个阿里云主账号的OSS中
阿里云人工智能平台PAI是一个功能强大、易于使用的AI开发平台,旨在降低AI开发门槛,加速创新,助力企业和开发者高效构建、部署和管理人工智能应用。其中包含了一系列相互协同的产品与服务,共同构成一个完整的人工智能开发与应用生态系统。以下是对PAI产品使用合集的概述,涵盖数据处理、模型开发、训练加速、模型部署及管理等多个环节。
|
弹性计算 数据管理 应用服务中间件
活动实践 | 借助OSS搭建在线教育视频课程分享网站
本教程指导用户在阿里云ECS实例上搭建在线教育网站,包括重置ECS密码、配置安全组、安装Nginx、创建网站页面、上传数据至OSS、开通OSS传输加速、配置生命周期策略及清理资源等步骤,实现高效、低成本的数据管理和网站运营。
活动实践 | 借助OSS搭建在线教育视频课程分享网站
|
SQL 分布式计算 Serverless
基于阿里云 EMR Serverless Spark 版快速搭建OSS日志分析应用
基于阿里云 EMR Serverless Spark 版快速搭建OSS日志分析应用
315 0
|
分布式计算 Java 开发工具
阿里云MaxCompute-XGBoost on Spark 极限梯度提升算法的分布式训练与模型持久化oss的实现与代码浅析
本文介绍了XGBoost在MaxCompute+OSS架构下模型持久化遇到的问题及其解决方案。首先简要介绍了XGBoost的特点和应用场景,随后详细描述了客户在将XGBoost on Spark任务从HDFS迁移到OSS时遇到的异常情况。通过分析异常堆栈和源代码,发现使用的`nativeBooster.saveModel`方法不支持OSS路径,而使用`write.overwrite().save`方法则能成功保存模型。最后提供了完整的Scala代码示例、Maven配置和提交命令,帮助用户顺利迁移模型存储路径。
|
存储 机器学习/深度学习 弹性计算
阿里云EMR数据湖文件系统问题之OSS-HDFS全托管服务的问题如何解决
阿里云EMR数据湖文件系统问题之OSS-HDFS全托管服务的问题如何解决
277 1