Day09-课程管理-添加小节上传视频-p145、p146,web编程开发学习

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Web前端全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024c (备注前端)
img

正文

}

4、创建controller,service实现上传小节功能

=============================================================================================

在这里插入图片描述

4.1、controller代码


在这里插入图片描述

package com.nonglin.vod.controller;

import com.nonglin.commonutils.R;

import com.nonglin.vod.service.VodService;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.web.bind.annotation.CrossOrigin;

import org.springframework.web.bind.annotation.PostMapping;

import org.springframework.web.bind.annotation.RequestMapping;

import org.springframework.web.bind.annotation.RestController;

import org.springframework.web.multipart.MultipartFile;

/**

  • @Description :

  • @Author :lenovo

  • @Date :2021/3/23 20:13

*/

@RestController

@RequestMapping(“/eduvod/video”)

@CrossOrigin

public class VodController {

@Autowired

private VodService vodService;

//上传视频到阿里云

@PostMapping(“uploadAlyiVideo”)

public R uploadAlyiVideo(MultipartFile file) {

//返回上传视频id

String videoId = vodService.uploadVideoAly(file);

return R.ok().data(“videoId”,videoId);

}

}

4.2、service代码


接口

在这里插入图片描述

package com.nonglin.vod.service;

import org.springframework.web.multipart.MultipartFile;

/**

  • @Description :

  • @Author :lenovo

  • @Date :2021/3/23 20:17

*/

public interface VodService {

String uploadVideoAly(MultipartFile file);

}

service实现类:

package com.nonglin.vod.service.impl;

import com.aliyun.vod.upload.impl.UploadVideoImpl;

import com.aliyun.vod.upload.req.UploadStreamRequest;

import com.aliyun.vod.upload.resp.UploadStreamResponse;

import com.nonglin.vod.service.VodService;

import com.nonglin.vod.utils.ConstantVodUtils;

import org.springframework.stereotype.Service;

import org.springframework.web.multipart.MultipartFile;

import java.io.InputStream;

/**

  • @Description :

  • @Author :lenovo

  • @Date :2021/3/23 20:18

*/

@Service

public class VodServiceImpl implements VodService {

@Override

public String uploadVideoAly(MultipartFile file) {

try {

//accessKeyId, accessKeySecret

//fileName:上传文件原始名称

// 01.03.09.mp4

String fileName = file.getOriginalFilename();

//title:上传之后显示名称

String title = fileName.substring(0, fileName.lastIndexOf(“.”));

//inputStream:上传文件输入流

InputStream inputStream = file.getInputStream();

UploadStreamRequest request = new UploadStreamRequest(ConstantVodUtils.ACCESS_KEY_ID,ConstantVodUtils.ACCESS_KEY_SECRET, title, fileName, inputStream);

UploadVideoImpl uploader = new UploadVideoImpl();

UploadStreamResponse response = uploader.uploadStream(request);

String videoId = null;

if (response.isSuccess()) {

videoId = response.getVideoId();

} else { //如果设置回调URL无效,不影响视频上传,可以返回VideoId同时会返回错误码。其他情况上传失败时,VideoId为空,此时需要根据返回错误码分析具体错误原因

videoId = response.getVideoId();

}

return videoId;

}catch(Exception e) {

e.printStackTrace();

return null;

}

}

}

5、工具类

====================================================================

在这里插入图片描述

package com.nonglin.vod.utils;

import org.springframework.beans.factory.InitializingBean;

import org.springframework.beans.factory.annotation.Value;

import org.springframework.stereotype.Component;

/**

  • @Description :

  • @Author :lenovo

  • @Date :2021/3/23 20:28

*/

@Component

public class ConstantVodUtils implements InitializingBean {

@Value(“${aliyun.vod.file.keyid}”)

private String keyid;

@Value(“${aliyun.vod.file.keysecret}”)

private String keysecret;

public static String ACCESS_KEY_SECRET;

public static String ACCESS_KEY_ID;

@Override

public void afterPropertiesSet() throws Exception {

ACCESS_KEY_ID = keyid;

ACCESS_KEY_SECRET = keysecret;

}

}

Vue 编码基础

2.1.1. 组件规范

2.1.2. 模板中使用简单的表达式

2.1.3 指令都使用缩写形式

2.1.4 标签顺序保持一致

2.1.5 必须为 v-for 设置键值 key

2.1.6 v-show 与 v-if 选择

2.1.7 script 标签内部结构顺序

2.1.8 Vue Router 规范

Vue 项目目录规范

2.2.1 基础

2.2.2 使用 Vue-cli 脚手架

2.2.3 目录说明

2.2.4注释说明

2.2.5 其他

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注前端)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
-cli 脚手架

2.2.3 目录说明

2.2.4注释说明

2.2.5 其他

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注前端)
[外链图片转存中…(img-SP39Z7MV-1713292568740)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值