博客
关于我
MultipartFile.getOriginalFilename()方法在IE浏览器下返回结果文件名不正确
阅读量:243 次
发布时间:2019-03-01

本文共 952 字,大约阅读时间需要 3 分钟。

在使用Bootstrap框架进行文件上传功能时,某些用户可能会遇到文件名无法正确获取的问题,尤其是在IE浏览器下。此问题主要源于文件路径的不同分隔符处理方式。

首先,了解问题的具体表现。在IE浏览器中,使用form表单上传文件时,file.getOriginalFilename()可能会返回包含路径信息的字符串,而其他主流浏览器(如Chrome和Firefox)则会直接返回文件名。这种差异导致在处理文件时,特别是在需要获取文件名的场景下,可能会出现问题。

为了解决这个问题,可以采用以下方法。在文件处理逻辑中,引入一个自定义的工具类FileUtils,用于根据不同的文件系统路径分隔符提取文件名。该类的具体实现如下:

public class FileUtils {    public static String getFileName(MultipartFile file) {        String fileName = file.getOriginalFilename();        int unixSep = fileName.lastIndexOf('/');        int winSep = fileName.lastIndexOf('\\');        int pos = (winSep > unixSep) ? winSep : unixSep;        if (pos != -1) {            fileName = fileName.substring(pos + 1);        }        return fileName;    }}

在实际应用中,确保在服务层调用此方法,这样无论是在IE浏览器还是其他主流浏览器下,都能正确获取文件名。这个方法通过检查文件路径的不同分隔符(如斜杠和反斜杠),有效地提取出文件名。

如果你在开发过程中遇到类似问题,记得检查文件上传的前端逻辑是否正确配置了文件类型,特别是IE浏览器对 multipart/form-data 的支持。正确配置前端的accept属性,可以避免在后端处理时出现路径包含的问题。

希望这些建议能帮助你解决文件名获取问题,提升文件上传功能的稳定性和兼容性。

转载地址:http://ixav.baihongyu.com/

你可能感兴趣的文章
OA系统选型:选择好的工作流引擎
查看>>
OA让企业业务流程管理科学有“据”
查看>>
OA项目之会议通知(查询&是否参会&反馈详情)
查看>>
Vue.js 学习总结(13)—— Vue3 version 计数介绍
查看>>
OA项目之我的会议(会议排座&送审)
查看>>
OA项目之我的会议(查询)
查看>>
OA项目之我的审批(会议查询&会议签字)
查看>>
OA项目之项目简介&会议发布
查看>>
ObjC的复制操作
查看>>
Object c将一个double值转换为时间格式
查看>>
object detection之Win10配置
查看>>
object detection训练自己数据
查看>>
object detection错误Message type "object_detection.protos.SsdFeatureExtractor" has no field named "bat
查看>>
object detection错误之Could not create cudnn handle: CUDNN_STATUS_INTERNAL_ERROR
查看>>
object detection错误之no module named nets
查看>>
Object of type 'ndarray' is not JSON serializable
查看>>
Object Oriented Programming in JavaScript
查看>>
object references an unsaved transient instance - save the transient instance before flushing
查看>>
Object 类的常见方法有哪些?
查看>>
Object-c动态特性
查看>>