在开发中,我们会经常会遇到一些,类似于导入文件,导出文件的情况,这时候再导出文件的时候就会出现一种情况,我们在后台生成好的excel文件先生成到了本地,然后前台直接拿地址进行下载时,浏览器会提示我们不允许下载本地的文件,这时候我们可以通过映射,将后台的地址映射到一个路径,然后前台拿到这个映射的路径进行下载,这时候浏览器就不会提示我们浏览器不能直接下载本地文件的错了,话不多说,直接上代码。
1、首先,先贴上后台配置的映射的图片
当然了 此处不能缺少代码,这里特别强调,不能缺少类上面的注解哦!!!
@Configuration public class FilePathConfig extends WebMvcConfigurerAdapter { private final static String rootPath = new String("src/main/resources/"); // @Value("${img.path}") private String locationPath = rootPath; // 3.文件本地路径 private static final String netPath = "/down/**"; // 映射路径 // 目前发现如果本地路径不是以分隔符结尾,在访问时否需要把在最后一个文件夹名添加在映射路径后面 // 如: // locationPath-->F:\img\ 访问路径-->ip:port/img/1.png // locationPath-->F:\img 访问路径-->ip:port/img/img/1.png // locationPath-->F:\img\123\ 访问路径-->ip:port/img/1.png // locationPath-->F:\img\123 访问路径-->ip:port/img/123/1.png @Override public void addResourceHandlers(ResourceHandlerRegistry registry) { // 目前在本地Win系统测试需要在本地路径前添加 "file:" // 有待确认Linux系统是否需要添加(已确认) // Linux系统也可以添加 "file:" registry.addResourceHandler(netPath).addResourceLocations("file:"+locationPath); } }
2、此时我们需要去前台设置路径,这里我们使用的是绝对路径,就是不是后台又返回给前台的地址,是我们直接使用的地址,小伙伴们如果需要的话就需要自己把地址传给前台哦,前台实际上很简单,就是在你的方法里面写上window.open就可以了
相信大家看到这里也能看出来了吧,这里写上http://ip:port/down/所需要下载的文件
就可以避开浏览器不能下载本地文件的问题了,如果大家还有疑问,请留言,看到会第一时间回复大家的,谢谢谢谢。
接下来的一篇文件会为大家分享一下如果使用POI向excel写入数据,和这一章结合就可以实现某些数据的导出功能了
我是小韩,谢谢大家