上岛上咖啡
2015-05-19 02:17
采纳率: 100%
浏览 25.3k
已采纳

MultipartFile上传文件时,中文文件名乱码怎么解决?

package com.upload;

import java.io.File;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;

import javax.servlet.http.HttpServletRequest;

import org.springframework.stereotype.Controller;
import org.springframework.ui.ModelMap;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.multipart.commons.CommonsMultipartFile;
@Controller
public class UploadContronller {

@RequestMapping("/toUpload.shtml")

public String toUpload(){

    return "upload";

}

@RequestMapping(value="/upload.shtml")

public String upload(@RequestParam(value="file",required=false)CommonsMultipartFile file,

        HttpServletRequest request,ModelMap model) throws Throwable{

// request.setCharacterEncoding("UTF-8");

    if (request.getCharacterEncoding() == null) {
        request.setCharacterEncoding("UTF-8");
    }

// String type=file.getContentType();

    //获取存储路径
    String path=request.getSession().getServletContext().getRealPath("upload");

    //上传文件名称
    String fileName=file.getOriginalFilename();

    System.out.println(fileName);

    //转义拆分重命名文件
    String[] strArr=fileName.split("\\.");

    System.out.println(strArr[0]);

    System.out.println(strArr[1]);

    SimpleDateFormat sdf=new SimpleDateFormat("YYYYMMDDHHmmss");

    String strName=sdf.format(new Date());

    fileName=strName+"."+strArr[1];

    System.out.println("------文件路径:"+path);

    //创建存储目录
    File targetFile=new File(path,fileName.toString());

    if(!targetFile.exists()){
        targetFile.mkdirs();
    }

    //文件上传
    try {

        file.transferTo(targetFile);

        //将文件路径转发到页面
        model.addAttribute("fileUrl", request.getContextPath()+"/upload/"+fileName);

    } catch (IllegalStateException e) {

        e.printStackTrace();

    } catch (IOException e) {

        e.printStackTrace();

    }

    return "result";
}

}

  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

5条回答 默认 最新

  • 黄金刺 2015-05-19 02:41
    已采纳
    try {
        fileName = new String(fileName.getBytes(), "UTF-8");
    } catch (UnsupportedEncodingException e1) {
        // TODO Auto-generated catch block
        e1.printStackTrace();
    }
    
    
    1 1 打赏 评论
  • lianghexyz 2015-05-19 02:27

    如果页面没有要求编码格式用gb2312可以吗 用中文编码格式试试应该可以的

    1 打赏 评论
  • 逝_去_的_光_阴 2015-05-19 02:33

    new String(strArr[1].getBytes(), "UTF-8")

    打赏 评论
  • g8520750 2015-05-19 02:41

    new String(strArr[1].getBytes(), "UTF-8")

    打赏 评论
  • 想要飞的企鹅 2015-09-21 00:53

    在网页和jS页面预先采用UTF-8的编码,再加上对header的判定,可以实现读取原始的文件名。中文不会出现乱码

    打赏 评论

相关推荐 更多相似问题