关于根据url下载文件之空格符报错

前言

描述:本文主要是记录后端代码根据url获取文件时发生报错的解决方案

一、遇到的报错

java 复制代码
Serverreturned HTTPresponse code: 400 for URL

分析:由于我上传的Excel文件中存在空格符,导致代码在获取文件时发生报错

1、项目初始代码

java 复制代码
public Workbook generateExcelObject(String fileUrl) {
    try {
        // 获取文件数据
        URL url = new URL(fileUrl);
        InputStream inputStream = url.openStream();
        if (!(inputStream.markSupported())) {
            inputStream = new PushbackInputStream(inputStream, 8);
        }

        // 生成excel对象
        Workbook book = WorkbookFactory.create(inputStream);
        return book;
    } catch (Exception e) {
        e.printStackTrace();
        return null;
    }
}

二、解决方案

1、直接替换

java 复制代码
	URL url = new URL(fileUrl.replace(" ", "%20"));

2、使用 URLEncoder.encode

java 复制代码
        // 对文件链接中的空格进行URL编码处理
        String encodedUrl = URLEncoder.encode(fileUrl, "UTF-8");

总结

实际测下来,方法1 可以成功,方法2不行,依然会在 InputStream inputStream = url.openStream(); 发生报错。原因是方法2把//也转为字符了,然后报错没有协议

相关推荐
sxlishaobin3 小时前
Spring Bean生命周期详解
java·后端·spring
yyovoll4 小时前
Java包和权限的知识点介绍
java·spring
二十雨辰4 小时前
[SSM]SpringMVC请求与响应
java·spring·http
今天有个Bug5 小时前
【计算机毕业设计】流浪动物救助平台 - SpringBoot+Vue
sql·mysql·spring·vue·毕业设计·课程设计
韩立学长5 小时前
【开题答辩实录分享】以《基于SSM的电影售票管理系统的设计与实现》为例进行选题答辩实录分享
java·spring·servlet
程序员阿鹏6 小时前
@Autowired和@Resource的区别
java·开发语言·spring
请告诉他10 小时前
【实战经验】Dell Inspiron 7560 升级 BIOS 支持 DDR4-2666 内存,解决 Spring Cloud 多模块开发内存瓶颈
后端·spring·spring cloud
爱吃牛肉的大老虎10 小时前
Spring WebFlux与SpringMVC 对比讲解
java·后端·spring
海南java第二人12 小时前
Spring Bean作用域深度解析:从单例到自定义作用域的全面指南
java·后端·spring
cike_y12 小时前
Spring5入门&IOC容器
java·开发语言·spring·jdk·ioc·jdk1.8