关于根据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把//也转为字符了,然后报错没有协议

相关推荐
Kiyra39 分钟前
从上传到可问答:Interview Agent 的知识库 RAG 链路
java·人工智能·后端·spring·职场和发展
直奔標竿1 小时前
MySQL与Redis数据一致性实战方案(避坑指南)
java·数据库·spring boot·redis·mysql·spring·缓存
java小白小2 小时前
Spring循环依赖深度解析:从原理到源码,一次性搞懂
spring
dllxhcjla3 小时前
Spring全套
java·后端·spring
IT 行者3 小时前
Spring AI 2.0.0-M5 发布:全面转向 OpenAI Java SDK
java·人工智能·spring
电商API_180079052474 小时前
淘宝商品评论数据获取指南|批量自动化|api应用
java·爬虫·spring·性能优化·自动化
java1234_小锋4 小时前
Spring AI 2.0 开发Java Agent智能体 - 对话与提示词工程(Prompt)
java·人工智能·spring
小新同学^O^5 小时前
初步了解--> SpringCloud
java·学习·spring·spring cloud
二哈赛车手1 天前
新人笔记---Spring AI的Advisor以及其底层机制讲解(涉及源码),包含一些遇见的Spring AI的Advisor缺陷问题的解决方案
java·人工智能·spring boot·笔记·spring
薪火铺子1 天前
Redis 缓存三大问题与解决方案
redis·spring·缓存