使用pdf.js预览实现读取服务器外部文件

不知道大家使用百度网盘的文件预览功能,f12看过控制台没有。


e91f2083-958b-32de-b81f-b1db0a194913.png

发现百度网盘使用的预览文件功能全是基于开源pdf .js的


接下来正题,我们在使用pdf.js默认是读取发布容器内部的文件,读取外部的文件需要自己实现,接下来拿读取桌面文件作为例子来展示。



实现原理:返回一个外部流文件给pdf.js实现加载预览文件。


步骤一:把pdf.js中的view.js中的改为DEFAULT_URL路径改为下载接口即可

2f87d26c-ae17-3931-89b6-d4594bcac326.png


效果:

步骤二:后端实现,这里后端是采用jersey,springmvc也是一样的原理


	@GET
	@Path("/d")
    @Produces(MediaType.APPLICATION_OCTET_STREAM)
	public Response  download(@QueryParam("filemd5") String viFileMd5,@QueryParam("filename") String viFileName,@QueryParam("fileid") String viFileId,@Context HttpServletResponse response,@Context HttpServletRequest request) {
		File nFile = null;
		String nFileName = null;
		try {
			nFile = new File("C:\\Users\\Administrator\\Desktop\\test.pdf");
			nFileName = URLEncoder.encode("大数据", "UTF-8");
			response.setCharacterEncoding("UTF-8");
		} catch (Exception e) {
			e.printStackTrace();
		}
		return Response.ok(nFile).header("Content-disposition","attachment;filename=" + nFileName+ ";filename*=utf-8''" + nFileName).header("Cache-Control", "no-cache").build();
	}


9cbd3b31-6538-3ec6-9871-4d2857114a69.png

转载于:https://www.cnblogs.com/baryon/p/9611378.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值