文件预览时避免暴漏文件服务器地址解决方案

文件预览避免暴漏文件服务器地址解决方案

一、背景

我们在做管理系统时避免不了要进行文件的预览和下载,但是有些文件是绝密的只限于预览,不能让下载,用户鼠标右击选择在新窗口打开该图片这时会暴漏文件服务器的地址。我们不希望暴漏文件服务器的地址,以防用户估计修改url查看不属于自己的文件。

二、原因

在做文件预览时后端直接文件服务保存文件的url地址返回给了前端,导致文件服务器url直接暴漏给前端

三、解决方案

前端处理思路如下,让后端返回二进制流,前端将文件流进行处理,生成一个临时的url地址供用户进行预览,这样就避免了url地址的暴漏

axios.get('后端返回文件流的url接口地址',{
       params:{
        id:文件id
       },
       responseType: 'blob',   //这里是声明期望返回的数据类型,为blob
    }).then(res => {
      const blob = new Blob([res], { type: "image/jpeg" })//必须指定类型  pdf为type: 'application/pdf'
       this.photoPath = window.URL.createObjectURL(blob);   //这里调用window的URL方法
      console.log(this.photoPath );
      window.open(this.photoPath)
    })
log打印结果:
blob:http://127.0.0.1/3458d892-c292-4d16-9ea8-3a8f94bb5fe6

在这里插入图片描述
完美解决 peace!!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值