首页 > 其他分享 >个别用户电脑上传某些格式视频无法预览/播放

个别用户电脑上传某些格式视频无法预览/播放

时间:2023-02-09 10:36:38浏览次数:45  
标签:audio 预览 text image application video file 播放 上传

场景:某些电脑用户上传同一视频,却发现无法预览/播放该视频,如mov/f4v/vob/rm/rmvb...等格式

原因:使用同一个文件上传出现通过获取到的file对象type属性为"",系统中所安装的Microsoft Excel软件或注册表的原因,不常见的文件扩展名会返回空字符串,最好不要依靠这个type属性作为唯一的验证方案

方法:用file.type做匹配同时用file.name,把常见的type文件后缀name做个配对
var fileTypeList = { 
  docx:"application/vnd.openxmlformats-officedocument.wordprocessingml.document",
  doc:"application/msword",
  pdf:"application/pdf",
  rtf:"application/rtf",
  xls:"application/vnd.ms-excel",
  xlsx:"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",
  ppt:"application/vnd.ms-powerpoint",
  pptx:"application/vnd.openxmlformats-officedocument.presentationml.presentation",
  rar:"application/x-rar-compressed",
  swf:"application/x-shockwave-flash",
  zip:"application/zip",
  mid:"audio/midi",
  midi:"audio/midi",
  kar:"audio/midi",
  mp3:"audio/mpeg",
  ogg:"audio/ogg",
  m4a:"audio/x-m4a",
  ra:"audio/x-realaudio",
  gif:"image/gif",
  jpeg:"image/jpeg",
  jpg:"image/jpeg",
  png:"image/png",
  tif:"image/tiff",
  tiff:"image/tiff",
  wbmp:"image/vnd.wap.wbmp",
  ico:"image/x-icon",
  jng:"image/x-jng",
  bmp:"image/x-ms-bmp",
  svg:"image/svg+xml",
  svgz:"image/svg+xml",
  webp:"image/webp",
  css:"text/css",
  html:"text/html",
  htm:"text/html",
  shtml:"text/html",
  txt:"text/plain",
  css:"text/css",
  xml:"text/xml",
  "3gpp":"video/3gpp",
  "3gp":"video/3gpp",
  mp4:"video/mp4",
  mpeg:"video/mpeg",
  mpg:"video/mpeg",
  mov:"video/quicktime",
  webm:"video/webm",
  flv:"video/x-flv",
  m4v:"video/x-m4v",
  wmv:"video/x-ms-wmv",
  avi:"video/x-msvideo",
}

  

export function fileTypeFormat(file){
  return file.type || fileTypeList[file.name.substring(file.name.lastIndexOf('.') + 1)]
}

  

相关文档解析见https://blog.csdn.net/wuhuama_/article/details/118699195

标签:audio,预览,text,image,application,video,file,播放,上传
From: https://www.cnblogs.com/taojiejun/p/17104336.html

相关文章

  • 磁盘空间不足导致ftp文件上传失败
    今天用ftp准备将相应文件上传至服务器中,但是却无法上传,也没有什么报错语言,就是一个failed。换给软件上传也没用,报同样的错误。 后来发现,是服务器根目录磁盘空间不足,显示......
  • postman如何测试上传文件
    小伙伴们知道postman如何测试上传文件吗?今天小编就来讲解postman测试上传文件的方法,感兴趣的快跟小编一起来看看吧,希望能够帮助到大家呢。第一步:首先,打开电脑上的postman......
  • ASP.NET WEB项目大文件上传下载解决方案
    ​ 以ASP.NETCoreWebAPI 作后端 API ,用 Vue 构建前端页面,用 Axios 从前端访问后端 API,包括文件的上传和下载。 准备文件上传的API #region 文件上传......
  • JAVA WEB项目大文件上传下载解决方案
    ​ 这里只写后端的代码,基本的思想就是,前端将文件分片,然后每次访问上传接口的时候,向后端传入参数:当前为第几块文件,和分片总数下面直接贴代码吧,一些难懂的我大部分都加上......
  • 前端报表如何实现无预览打印解决方案或静默打印
    在前端开发中,除了将数据呈现后,我们往往需要为用户提供,打印,导出等能力,导出是为了存档或是二次分析,而打印则因为很多单据需要打印出来作为主要的单据来进行下一环节的票据支撑......
  • JAVA WEB项目大文件上传下载源代码
    ​ 1、介绍enctypeenctype 属性规定发送到服务器之前应该如何对表单数据进行编码。enctype作用是告知服务器请求正文的MIME类型(请求消息头content-type的作用一样)1、......
  • Unity音乐播放
    1.Unity场景搭建  2.脚本编码usingSystem.Collections;usingSystem.Collections.Generic;usingUnityEngine;publicclassAudioPlay:MonoBehaviour{......
  • Blazor文件上传异常:Did not receive any data in the allotted time
    最近使用Blazor做文件上传,无论是Page还是Service处理,使用以下代码,都会报异常错误Didnotreceiveanydataintheallottedtime。//Page页面微软官网文档:https://learn......
  • JAVA WEB项目大文件上传下载问题
    ​需求:支持大文件批量上传(20G)和下载,同时需要保证上传期间用户电脑不出现卡死等体验;内网百兆网络上传速度为12MB/S服务器内存占用低支持文件夹上传,文件夹中的文件数量......
  • docker搭建yapi接口文档系统、Idea中上传接口、在线调用
    一、前言在我们后端开发中,必不可少的是接口的交接,有很多种方式,常见的就是swagger,不过这个侵入性太强了。还有就是接口文档的框架,比如今天小编带大家一起搭建的yapi,在公司......