pdf预览引发的vue项目只允许Chrome浏览器访问

本文记录了一个Vue项目中实现PDF在线预览功能的过程,由于预览效果只在Chrome浏览器生效,因此设置了项目仅允许Chrome浏览器访问。通过后端返回流文件,前端利用window.open打开PDF并隐藏工具栏。同时,通过判断浏览器内核,当检测到非Chrome浏览器时显示提示信息。此外,还介绍了在用户无token情况下阻止页面访问的实现,通过router.beforeEach进行权限检查。
摘要由CSDN通过智能技术生成

前言

项目中需要把原本下载pdf功能改成在线预览,只能预览不能进行其他操作,通过在地址后面拼接参数可以隐藏掉工具栏,但是只对chrome生效,所以又增加了访问权限,只对chrome浏览器开放,记录一下

一、pdf在线预览,后端返回流文件,前端window.open打开

通过添加"#view=FitH,top&toolbar=0"

interface OPTIONSTYPE {
    url: String,
    method: String,
    params: Object
}
export function onlineViewPdf(optionsz:OPTIONSTYPE) {
    const { url, method, params } = options;
    let config = {
        url: url,
        method: method,
        responseType: "blob",
        params: params,
        headers: {
            "X-Access-Token": getStore("token") ? getStore("token") : ""
        }
    };

    axios(config).then(response => {
        let data = response.data;
        // 请求失败,后台返回json
        if (data.type.includes("application/json")) {
            let 
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值