pdf格式文件下载不预览,云存储的跨域解决

这篇具有很好参考价值的文章主要介绍了pdf格式文件下载不预览,云存储的跨域解决。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

需求背景

后端接口中返回的是pdf文件路径比如:

pdf文件路径 (https://wangzhendongsky.oss-cn-beijing.aliyuncs.com/wzd-test.pdf)

前端适配是这样的

 <a
        href="https://wangzhendongsky.oss-cn-beijing.aliyuncs.com/wzd-test.pdf"
      >
        超链接预览pdf
      </a>

点击后预览

pdf格式文件下载不预览,云存储的跨域解决,javascript,pdf,javascript

但是客户方要求不预览点击后直接下载

示例演示  (pdf下载 - 码上掘金)

项目准备

有pdf链接的可以跨过该阶段

准备一个线上的pdf文件链接

登陆阿里云平台

1. 点击又上角的控制台

pdf格式文件下载不预览,云存储的跨域解决,javascript,pdf,javascript

 2. 点击左上角的三道杠图标

pdf格式文件下载不预览,云存储的跨域解决,javascript,pdf,javascript

 3. 点击左侧的对象云存储oss

pdf格式文件下载不预览,云存储的跨域解决,javascript,pdf,javascript

 4. 点击bucket

pdf格式文件下载不预览,云存储的跨域解决,javascript,pdf,javascript

5. 创建 bucket

pdf格式文件下载不预览,云存储的跨域解决,javascript,pdf,javascript

pdf格式文件下载不预览,云存储的跨域解决,javascript,pdf,javascript

 6. 创建成功后

pdf格式文件下载不预览,云存储的跨域解决,javascript,pdf,javascript

 7. 上传文件

点击红框处

pdf格式文件下载不预览,云存储的跨域解决,javascript,pdf,javascript

 点击上传文件

pdf格式文件下载不预览,云存储的跨域解决,javascript,pdf,javascript

 pdf格式文件下载不预览,云存储的跨域解决,javascript,pdf,javascript

8. 上传完成后为了方便访问可以把文件的访问属性修改为公共的

pdf格式文件下载不预览,云存储的跨域解决,javascript,pdf,javascript

pdf格式文件下载不预览,云存储的跨域解决,javascript,pdf,javascript

pdf格式文件下载不预览,云存储的跨域解决,javascript,pdf,javascript

到这里文件链接就创建好了,可以直接复制链接访问

pdf格式文件下载不预览,云存储的跨域解决,javascript,pdf,javascript

解决文件链接跨域问题

点击数据安全中的跨域设置

pdf格式文件下载不预览,云存储的跨域解决,javascript,pdf,javascript

规则设置

pdf格式文件下载不预览,云存储的跨域解决,javascript,pdf,javascript pdf格式文件下载不预览,云存储的跨域解决,javascript,pdf,javascript

设置完成后就可以随意访问了啦

实现(js)

HML

<!DOCTYPE html>
<html lang="CH-EN">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>下载</title>
  </head>
  <body>
    <div class="content">
      <a
        href="https://wangzhendongsky.oss-cn-beijing.aliyuncs.com/wzd-test.pdf"
      >
        超链接预览pdf
      </a>

      <button id="btn" type="submit" onclick="download()">点击下载pdf</button>
    </div>
  </body>
</html>

script

<script>
  const filePath =
    "https://wangzhendongsky.oss-cn-beijing.aliyuncs.com/wzd-test.pdf";
  //  fileName是pdf名称 、filePath是pdf地址
  function downloadFil(fileName, filePath) {
    var ajax = new XMLHttpRequest();
    ajax.open("GET", filePath, true);
    ajax.responseType = "blob";
    ajax.onload = (e) => {
      console.log(e);
      let res = e.target.response;
      let blob = new Blob([res]);
      let aLink = document.createElement("a");
      aLink.download = `${fileName}.pdf`; // 下载文件的名字
      aLink.href = URL.createObjectURL(blob);
      aLink.click();
    };
    ajax.send();
  }
  function download() {
    downloadFil("test", filePath);
  }
</script>

style

<style>
  * {
    margin: 0;
    padding: 0;
  }
  body {
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .content {
    height: 300px;
    width: 500px;
    border: solid #ddd 1px;
    text-align: center;
    padding: 20px;
  }
  .content input {
    height: 24px;
    line-height: 24px;
    font-size: 18px;
    border: 1px solid #dcdfe6;
  }
  .content input:focus {
    outline: none;
    border-color: #409eff;
  }
  .content input:focus-visible {
    outline-offset: 0px;
  }
</style>

实现(vue)

downloadjs

github地址:https://github.com/rndme/download

安装


npm install downloadjs -S

导入

import download from "downloadjs"


使用

download(url, strFileName, strMimeType);
download第一个参数为URL,第二个参数为文件名称,第三个参数文件类型,url必填,另外两个选填

遇到的问题

1.下载的文件打不开,且大小不对 // 中文名称文件下载 download(encodeURI(URL))
2.不能自定义名称
在URL进行转码后虽然可以下载PDF文件了,但名称却是转码后的名称,而不是原本的名称,这时我们用第二个参数进行命名时,名称是对了,可文件却出现打不开,大小不对的情况,暂时没找到解决方法。

file-saver

github地址:https://github.com/eligrey/FileSaver.js

该库是我之前写页面转PDF时使用到的库,既然之前可以保存pdf文件,那现在是不是也可以呢,上网一搜还真可以

安装

npm i file-saver

使用 文章来源地址https://www.toymoban.com/news/detail-665296.html

const that = this
var oReq = new XMLHttpRequest()
var URL= '' // URL 为URL地址
oReq.open('GET', URL, true)
oReq.responseType = 'blob'
oReq.onload = function() {
  var file = new Blob([oReq.response], {
    type: 'blob'
  })
  FileSaver.saveAs(file, that.name) // that.name为文件名
}
oReq.send()

到了这里,关于pdf格式文件下载不预览,云存储的跨域解决的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包