当前位置: 首页 > news >正文

电子商务网站设计的原则和内容嘉定网站建设哪家便宜

电子商务网站设计的原则和内容,嘉定网站建设哪家便宜,wordpress做图片站的可能性,网站后台显示连接已重置文件服务使用 minio,使用 nginx 反向代理。 将文件存放在 minio 上,如果是公开的文件,则统一放到一个桶,设置为公开只读。 如果是私有文件,则使用临时链接,给有权限的用户查看和打印。 要实现在 html 页…

文件服务使用 minio,使用 nginx 反向代理。

将文件存放在 minio 上,如果是公开的文件,则统一放到一个桶,设置为公开只读。

如果是私有文件,则使用临时链接,给有权限的用户查看和打印。

要实现在 html 页面上,弹框显示 pdf 和打印。

遇到问题:

问题 1 跨域安全问题,浏览器不允许加载

由于我的某个主页面上加了安全标签(<meta http-equiv="Content-Security-Policy" content="upgrade-insecure-requests">),导致报错:“Failed to load resource: net::ERR_CONNECTION_RESET”, 请求头出现警告信息:"Provisional headers are shown Learn more"

demo 页面就可以正常下载文件,排查了好久才发现是安全标签的问题。

问题 2 显示 pdf 文件

从后端把 minio 中的 pdf 文件链接(使用 minio 的客户端生产的临时链接)返回给前端,但是 浏览一直不显示文件,直接就下载了保存到了本地,使用 embed 标签或者 iframe 都不行。以为是 nginx 问题,不管如何配置,都不行。后来使用 pdf.js 来处理,果然可以显示 pdf 文件。

问题 3 打印 pdf 文件。

打印 pdf ,并没有达到效果,打印的竟然是网页页面,折腾了好久,都不能实现打印 pdf 原文件。

最后决定后端把 pdf 文件下载到 tomcat 的目录,再把这个 tomcat 中的文件链接返回给前端。使用 spring 的 restTemplate 来下载文件(临时链接),结果遇到 403 ,真奇怪。不管我如何处理,始终报 403。后面参考(设置 user agent)了别人的做法,终于可以下载了。

String u = URLDecoder.decode(addr, StandardCharsets.UTF_8.name());URL url = new URL(u);HttpURLConnection connection = ((HttpURLConnection)url.openConnection());connection.addRequestProperty("User-Agent", "Mozilla/4.0"); // 这里是用来处理 403 错误的。InputStream input = null;try {if (connection.getResponseCode() == 200) {Map<String, List<String>> headerFields = connection.getHeaderFields();headerFields.forEach((key,list)->{if (key != null) {response.setHeader(key, list.get(0));}});input = connection.getInputStream();// 文件流复制/转发StreamUtils.copy(input, response.getOutputStream());} else {input = connection.getErrorStream();}} finally {try {input.close();} catch (Exception e) {}}

后来我一想,直接新开文件下载接口,把 pdf 文件下载文件流直接转发给前端 iframe ,看看如何。 结果成功显示并且还可以打印。此时我并没设置 Content-Type 返回头 header。让我顿然开朗,马上检查在 minio 中的文件的 content type 为 application/octet-stream ,不是 pdf 类型。原来文件上传到 minio 时没有处理好文件类型。导致下载文件时,浏览器直接把文件下载。处理好后,重新上传 pdf 文件,文件类型为 application/pdf。在文件下载文件流转发给前端时,把下载时返回 header 也全部转发给前端,达到想要的效果。

然后我再重新把 pdf 文件的 minio 的临时链接给 iframe 的 src,成功达到效果。

总结:要注意跨域问题,即使在本地开发,localhost 和 本机 Ip 两个方式也会存在跨域问题。

文件流可以直接转发。文件类型要正确,否则浏览器不会打开显示文件,会直接下载。

http://www.yayakq.cn/news/384129/

相关文章:

  • 凌源网站建设ae如何做视频模板下载网站
  • 关于网站建设的工作计划公司logo查询网站
  • 泰州网站设计公司网站建设托管公司
  • 上海知名的网站公司做影视网站版权问题
  • 杭州网站建设公司慕枫手机网店开店网站
  • 上海网站建设公司 珍岛建设营销型网站模板
  • 帮人做网站的公司建立网站有哪些步骤?
  • html如何做购物网站大型网站架构实战
  • 搭建网站的过程wordpress云储存缩略图
  • 推荐六款适合做小说阅读站及小说下载站的wordpress 模板赣州人才网最新招聘信息网
  • 做网站需要服务器和什么佛山 网站开发
  • 国外空间做网站怎么样网站开发程序
  • 铁岭哪家做营销型网站网页游戏排行榜20
  • 济南制作网站的公司广告制作公司合同
  • 分类信息网站怎么建设广州安全教育平台软件
  • 南平网站seo线上网课
  • 夜狼seo贵阳网站排名优化
  • 网站建设移动网络网站结构优化包括哪些
  • 网站加速器推荐青岛建设银行网站
  • 网站首页翻转效果什么模块如何建设网站济南兴田德润o简介电话
  • 网站已经备案更换主机申请免费网站注册
  • 快速搭建网站的工具有哪些wordpress的插件目录
  • 自己怎样做海外网站有哪些高端的网站
  • 网站登录窗口怎么做有教做路桥质检资料的网站吗
  • 网站中的分享怎么做c 做网站源码实例
  • 店铺设计图纸及效果图大全windows优化大师卸载不掉
  • 地方网站系统建立网站 营业执照
  • 网站免费获取验证码怎么做手机网站开发 pdf
  • 上上海网站设计建设dedecms网站根目录
  • 电商网站变化wordpress数据包