input type='file' 安卓手机 h5 bmp图片格式上传 踩坑日记

一、场景

h5页面

实现一个上传组件,这个组件仅支持上传PDF, DOC, DOCX, JPG, JPEG, PNG, BMP, XLS, XLSX, CSV格式的文件

发版的前一天临近下班之际,测试提了一个bug,说安卓手机上传bmp文件提示格式错误,pc和ios都木有问题

丸辣,这不得真机调试,以前有用过LightProxy进行真机调试,但是新电脑还没有条件马上真机调试(接近下班了,懂的都懂

尽管到点了,还是安装了LightProxy,捣鼓了半小时,没代理成功,先放弃(有问题就告诉产品去掉这个类型的文件,又不是不能用.jpg

二、真机调试条件准备

  1. 安装LightProxy
    LightProxy官网
    window直接下载
    mac直接下载

    安装成功后:

  2. 关闭电脑防火墙

  3. 手机和电脑连上同一个WIFI

  4. 设置手机代理

    长按已连接的WIFI-修改网络-代理选择手动,输入对应的代理地址

  5. 手机扫码下载证书

    以华为手机为例:主屏幕滑到负一层,右上角有一个扫码入口,或者设置-账号点进去-右上角也有扫码入口
    这里要确保证书已安装成功

    如何查看是否安装成功:

    设置-安全-更多安全设置-加密和凭据-受信任的凭据-用户
    若安装受限,例如提示 在"设置"中安装CA证书

    设置-安全-更多安全设置-加密和凭据-从存储设备安装-CA证书-任然安装-搜索root-安装已下载的rootAC证书即可

  6. 到这里手机尝试一下直接访问localhost:3000/xxx,发现未能正常进入页面,这时候需要进行第7步

  7. 设置ip映射:

  8. 到此,手机地址换成test.h5:3000/xxx,就可以正常访问了

三、项目添加vconsole

如果项目没有添加vconsole,手机没法查看console.log

所以添加一下vconsole

js 复制代码
npm i vconsole -D
js 复制代码
// 入口文件
import VConsole from 'vconsole';

if (process.env.NODE_ENV !== 'production') {
  new VConsole();
}

添加之后,手机上就会出现绿色vConsole入口

四、发现问题

pc端:type为正常的image/bmp

安卓手机端:type并不是image/bmp

五、兼容处理bmp文件类型代码片段

js 复制代码
import { invert } from "lodash";

export const MINE_TYPE = {
  COMMON: "application/octet-stream",
  PDF: "application/pdf",
  DOC: "application/msword",
  DOCX: "application/vnd.openxmlformats-officedocument.wordprocessingml.document",
  XLS: "application/vnd.ms-excel",
  XLSX: "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",
  PNG: "image/png",
  JPG: "image/jpeg",
  GIF: "image/gif",
  BMP: "image/bmp",
  APK: "application/vnd.android.package-archive",
  TXT: "text/plain",
  HTML: "text/html",
  CSV: "text/csv",
};


// 获取文件名后缀
const getFileSuffix = (filename: string) => {
  const index = filename.lastIndexOf(".");
  if (index !== -1) {
    return filename.substr(index + 1);
  }
  return false;
};

/** 获取文件类型 - 即获取MINE_TYPE的key */
export const getFileType = (type: string) => {
  return type.includes('bmp') ? 'BMP' : invert(MINE_TYPE)[type]
}

// 检查上传文件类型
export const checkTypes = (
  file: RcFile,
  typeList: string[],
  forceSuffix: boolean = false
) => {
  const type = typeList;
  if (type && file && file.type && !forceSuffix) {
    // 兼容安卓手機上傳bmp類型時,file.type !== image/bmp
    if (type.includes(MINE_TYPE.BMP) && file.type.includes('bmp')) {
      return true
    }
    return type.includes(file.type);
  }

  const suffix = getFileSuffix(file.name);
  if (suffix && file && file.name) {
    let pass = false;
    const mine = invert(MINE_TYPE);
    typeList.forEach((item) => {
      if (!pass) {
        pass = suffix.toLocaleUpperCase() === mine[item];
      }
    });
    return pass;
  }
  return false;
};
js 复制代码
// 拿到MINE_TYPE的key传给后端
const type = getFileType(file.type)

参考文章:

抓包、代理、请求拦截、手机端页面调试?通通拿下!

相关推荐
dy17174 小时前
element-plus表格默认展开有子的数据
前端·javascript·vue.js
2501_915918418 小时前
Web 前端可视化开发工具对比 低代码平台、可视化搭建工具、前端可视化编辑器与在线可视化开发环境的实战分析
前端·低代码·ios·小程序·uni-app·编辑器·iphone
程序员的世界你不懂8 小时前
【Flask】测试平台开发,新增说明书编写和展示功能 第二十三篇
java·前端·数据库
索迪迈科技8 小时前
网络请求库——Axios库深度解析
前端·网络·vue.js·北京百思可瑞教育·百思可瑞教育
gnip9 小时前
JavaScript二叉树相关概念
前端
attitude.x9 小时前
PyTorch 动态图的灵活性与实用技巧
前端·人工智能·深度学习
β添砖java10 小时前
CSS3核心技术
前端·css·css3
空山新雨(大队长)10 小时前
HTML第八课:HTML4和HTML5的区别
前端·html·html5
猫头虎-前端技术10 小时前
浏览器兼容性问题全解:CSS 前缀、Grid/Flex 布局兼容方案与跨浏览器调试技巧
前端·css·node.js·bootstrap·ecmascript·css3·媒体