logo 范 · 拾光录
网址收集 关于作者 Github Gitee
杂文随笔5
Hexo博客:基础使用Hexo博客:Next主题Hexo博客:Next进阶使用Hexo博客:Next高级配置基于Node的WIKI管理
前端知识16
HTML常用知识CSS常用知识CSS美化checkbox复选框JavaScript常用知识JavaScript格式化时间戳JavaScript窗口宽高处理JavaScript黑夜主题切换实现方案JavaScript数字转大写简易图片查看器TypeScript基础知识Threejs基础三要素Threejs网格辅助和轨道控制器Threejs物体绘制Electron基础使用Nodejs基础知识animate.css页面动画
Vue框架19
Vite的使用及扩展Vue3父子组件Vue3使用Marked解析MarkdownMermaid图表生成库初始化页面加载动画Axios表单提交二维码解决方案NProgress加载进度条Vue3动态菜单实现Vue3使用ECharts图表Vue3处理Excel导入导出keep-alive页面缓存及setup问题Element:文件上传Element:结合Pinia实现动态菜单Element:图片上传组件Element:自定义统一弹窗组件Element:表格自定义指令控制按钮显示(鉴权)可视化大屏使用缩放适配分辨率
UniApp15
UniApp的基础使用封装网络请求工具及文件上传uni-app的开发记录微信小程序分享原生文件上传Pinia取消滚动条(兼容小程序)tabbar消息数量显示scroll-view上滑到底部加载数据状态栏高度动态设配数据共享与传递uview-plus导航栏实现背景融合Wot UIWot UI实现顶部背景图融合uni-app x
Java基础知识10
基础知识面向对象Lambda表达式常用API常用知识积累try-with-resource注解反射多线程经纬度距离计算
SpringBoot31
application配置Maven创建聚合项目全局异常处理锁机制项目启动初始化数据方式邮件功能集成原生定时任务异步集成阿里云OSS阿里OSS预签名上传基于hutool读excelJSR303WebSocketWebSocket版AI接口流式调用Smart-Doc接口文档生成器application配置信息加密雪花算法工具AOP实现请求参数脱敏思路JWT生成Token及工具类SpringBoot默认JSON与对象转换若依框架:安装使用若依框架:优化和调整文件上传若依框架:管理后台页面优化若依框架:后端接口代码优化SpringAISpringBoot实现AI接口流式调用服务启动时创建MySQL连接自建项目工程树形结构处理工具微信支付代码微信手机号登录
SpringMVC14
跨域处理拦截器RESTful风格伪前后端分离Jackson转换器调整Thymeleaf基于拦截器做权限校验AOP打印接口请求响应日志AOP打印接口请求响应耗时文件上传和回显POST请求加解密实现(AES)POST请求加解密实现(RSA+AES)参数动态校验实现方案真实IP和归属地
MyBatis8
MyBatis基本使用与配置Mapper使用相关MaBatis多数据源配置MyBatisPlus数据统计类处理方案MyBatisPlus条件查询正向工程的实现(H2)mybatis-plus-join
SpringCloud15
Netflix:微服务与搭建Netflix:服务的消费与提供Netflix:EurekaNetflix:ActuatorNetflix:RibbonNetflix:FeignNetflix:HystrixNetflix:ZuulAlibaba:简介与搭建Alibaba:Nacos注册中心Alibaba:RibbonAlibaba:OpenFeignAlibaba:Nacos配置中心Alibaba:GetewayAlibaba:Sentinel
MySQL6
MySQL基础知识MySQL多表查询与事务MySQL常用函数及解决方案MySQL视图MySQL索引安装MySQL
Redis7
Redis介绍和安装Redis配置文件Redis持久化Redis集群Redis语法基础Redis相关问题及解决方案SpringBoot集成Redis使用记录
MongoDB10
Linux安装MongoDBMongoDB基础语法MongoTemplate及SpringBoot配置MongoTemplate中Update操作MongoTemplate中聚合查询MongoTemplate日期归档示例项目使用相关知识归纳地理位置存储与距离查询MongoDB副本集与事务获取类名和属性名工具类
其他数据库1
H2数据库
Python编程6
Python基础知识Python语法yolo目标检测OpenCV的使用及树莓派平台condauv
工具集合13
IDEAMavenGradleGitNginx安装Nginx配置VSCodeJMeter压测DockerOllamaRustFSPicGoObs录制
Linux知识11
Linux常用命令Jar启动脚本VirtualBox安装CentOSVirtualBox安装Ubuntu树莓派安装及使用frp内网穿透ArchLinux:基础系统安装ArchLInux:图形化界面安装ArchLinux:常用软件ArchLinux:深度优化ArchLinux:Niri
创意设计2
Blender:入门知识UI设计基础知识
AI相关9
Claude CodeHermes AgentOpenAI基本使用OpenAI工具调用OpenAI记忆管理OpenAI推理执行OpenAI开发框架Langchainllama.cpp

上传实时进度

HTML

<el-upload
    :action="uploadUrl"
    :show-file-list="false"
    :on-error="uploadVideoError"
    :on-progress="uploadVideRunning"
    :before-upload="beforeFileUpload"
    :on-success="successFileUpload">
  <el-button size="small" type="primary">点击上传</el-button>
</el-upload>

<!--文件上传进度-->
<div class="upload-progress" v-show="uploadProgressFlag">
  <el-progress :percentage="uploadProgressNum"></el-progress>
</div>

JS

// 上传进度
uploadProgressFlag: false,
uploadProgressNum: 0,

// 文件上传前
beforeFileUpload() {
  this.uploadProgressFlag = true
  this.uploadProgressNum = 0
  //this.load('上传中')
},

// 文件上传计算
uploadVideRunning(event, file, fileList) {
  let uploadProgressNum = (event.loaded / event.total) * 100
  this.uploadProgressNum = parseInt(uploadProgressNum)
  if (this.uploadProgressNum == 100) {
    this.uploadProgressFlag = false
    this.load('等待服务器响应')
  }
},

也可直接使用progress.uploadProgressNum = parseInt(event.percent.toFixed(0))

文件过小无法显示,需要大文件

CSS

/*上传进度*/
.upload-progress {
  width: 100%;
  height: 100vh;
  z-index: 99999999999999;
  position: fixed;
  background-color: rgba(0,0,0,0.3);
  left: 0;
  top: 0;
}
.upload-progress .el-progress {
  width: 300px;
  margin: 48vh auto;
}
.el-progress__text{
  color: #fff !important;
}

上传到阿里OSS

下载阿里OSS的SDK

npm install ali-oss

在页面中导入

import ossItem from 'ali-oss'

利用elemenet提供的http-request覆盖原有的上传逻辑,改为走阿里OSS

<el-upload
    action=""
    :http-request="uploadHttp"
    :before-upload="beforeUploadVideo">
    // 此处添加按钮或图标
</el-upload>

然后处理上传逻辑

// 重写上传方式,走阿里oss
async uploadHttp(file) {
  let _this = this
  // 生产环境此处的信息从接口获取
  let client = ossItem({
    accessKeyId: 'xxx',
    accessKeySecret: '',
    bucket: 'banglin',
    region: 'oss-cn-shenzhen'
  })
  // 文件名处理
  let filename = file.file.name
  let index = filename.lastIndexOf('.')
  let suffix = filename.substr(index)
  let fileUrl = '/servlet/file/' + new Date().getTime().toString() + suffix
  /*
    此方式适用于不显示进度,较为方便,能直接拿到返回的地址
    client.put(new Date().getTime().toString() + suffix, file.file).then(res => {
      console.log(res)
      this.uploadVideoInfo.videoUrl = res.url
      this.uploadProgressFlag = false
      this.close()
    })
  */

  // 此方法能显示上传进度
  let res = await client.multipartUpload(fileUrl, file.file, {
    progress: async function (p) {
      let progress = (p * 100).toFixed(0)
      // 进度值
      _this.uploadProgressNum = parseInt(progress)
    }
  })
  // 显示进度条
  this.uploadProgressFlag = false
  // 处理数据
  if (res.res.status === 200) {
    // 上传成功,拼接URL,res中返回的比较长,也可以用
    this.uploadVideoInfo.videoUrl = 'https://xxxx' + fileUrl
  }
},
// 文件上传之前
beforeUploadVideo() {
  this.uploadProgressFlag = true
  this.uploadProgressNum = 0
},

Vue通用阿里上传方式

Vue2方式,Vue3同理

// 阿里OSS信息
let OSSClientInfo = {
  accessKeyId: 'xxxx',
  accessKeySecret: 'xxxx',
  bucket: 'xxxx',
  region: 'oss-cn-shenzhen',
  path: '/admin/file/', // 自定义文件上传路径
  url: 'https://oss.aroundme.tv', // OSS配置的访问域名
}

// 阿里OSS文件上传(无进度)
Vue.prototype.ossUpload = async (file) => {
  let client = ossItem({
    accessKeyId: OSSClientInfo.accessKeyId,
    accessKeySecret: OSSClientInfo.accessKeySecret,
    bucket: OSSClientInfo.bucket,
    region: OSSClientInfo.region
  })
  // 文件名处理
  let filename = file.file.name
  let index = filename.lastIndexOf('.')
  let suffix = filename.substr(index)
  let fileUrl = OSSClientInfo.path + new Date().getTime().toString() + suffix
  let url = ''
  await client.put(fileUrl, file.file).then(res => {
    if (res.res.status === 200) {
      // 上传成功,返回地址,更改为自定义域名
      url = OSSClientInfo.url + fileUrl
    } else {
      this.message({code: 1, msg: '文件上传失败'})
    }
  })
  return url
}

使用方式

// element上传组件
<el-upload
    action=""
    :http-request="uploadIcon">
  <img v-if="editData.iconUrl" :src="editData.iconUrl" class="avatar" alt="">
  <i v-else class="el-icon-plus avatar-uploader-icon"></i>
</el-upload>

// 回调
uploadIcon(file) {
  this.ossUpload(file).then(url => {
    this.editData.iconUrl = url
  })
},
上传实时进度
HTML
JS
CSS
上传到阿里OSS
Vue通用阿里上传方式