Java 上传文件到服务器

上传文件工具类

/**
 * 文件上传工具包
 */
public class FileUtils {
    /**
     *
     * @param file 文件
     * @param path 文件存放路径
     * @param fileName 源文件名
     * @return
     */
    public static String upload(MultipartFile file, String path, String fileName){

        //使用原文件名
        String realPath = path + "/" + fileName;

        File dest = new File(realPath);

        //判断文件父目录是否存在
        if(!dest.getParentFile().exists()){
            dest.getParentFile().mkdir();
        }

        try {

            //保存文件
            file.transferTo(dest);
            return fileName;
        } catch (IllegalStateException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
            return null;
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
            return null;
        }

    }


    public static boolean delFile(String url,String localPictures) {
        File dirFile = new File(localPictures);
        if (!dirFile.exists()) {
            dirFile.mkdirs();
        }
        //先获取最后一个  \ 所在的位置
        int index1 = url.lastIndexOf("/");
        //然后获取从最后一个\所在索引+1开始 至 字符串末尾的字符
        String path = localPictures + url.substring(index1+1);

        boolean flag = false;
        File file = new File(path);
        if (!file.exists()) {
            return flag;
        }
        try{
            flag = file.delete();
        }catch (Exception e){
            e.printStackTrace();
        }
        return flag;
    }

    /**
     * 删除文件
     * @param url
     * @param localPictures
     * @return
     */
    public static boolean deleteFile(String url,String localPictures) {
        boolean flag = false;
        File file = new File(localPictures+url);
        if (!file.exists()) {
            return flag;
        }
        try{
            flag = file.delete();
        }catch (Exception e){
            e.printStackTrace();
        }
        return flag;
    }
}

yml 上传配置

#文件上传
file:
  uploadFolder: /data/filesimg/
  httpUrl: http://127.0.0.1:9900/

  #文件后缀
  suffix: .png,.jpeg,.gif,.jpg,.webp,.WEBP

nginx 映射配置

  server {
        listen       9900;
        server_name  localhsot;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

    location ~ ^/demo/(.+\.(?:gif|jpe?g|png|webp|WEBP|apk))$ {
        alias /data/filesimg/demo$1;
    }
        # 由于路由的资源不一定是真实的路径,无法找到具体文件
        # 所以需要将请求重写到 index.html 中,然后交给真正的 Vue 路由处理请求资源
        location @router {
          rewrite ^.*$ /index.html last;
        } 
    }

nginx其他配置

http://t.csdnimg.cn/ZReCI

上传实现代码

    @Value("${file.uploadFolder}")
    private String uploadUrl;
    @Value("${file.httpUrl}")
    private String httpUrl;
    @Value("${file.suffix}")
    private String fileSuffix;

    /**
     * 图片文件上传
     *
     * @param file
     * @param imgType 1 管理后台文件上传
     * @return
     */
    @Override
    public Object addImg(MultipartFile file) {
        // 判断文件后缀
        String fileNameSuffix = FileNameUtils.getSuffix(file.getOriginalFilename());
        String url = JsonUtil.toJson(fileSuffix);
        if (!url.contains(fileNameSuffix)) {
            return "失败";
        }
        String shopping = "demo/";
        //商品类型图片上传服务器地址
        String localProductTypePictures = uploadUrl + shopping;
        //"商品类型图片上传访问地址"
        String imgServiceTypePath = httpUrl + shopping;
        //生成文件
        String name = FileNameUtils.getFileName(file.getOriginalFilename());
        if (Objects.nonNull(name)) {
            FileUtils.delFile(name, localProductTypePictures);
        }
        //上传图片
        boolean flag = false;
        String visit = FileUtils.upload(file, localProductTypePictures, name);
        if (visit != null) {
            flag = true;
        }
        if (flag) {
            //得到上传链接            
            return  "img:"+imgServiceTypePath + visit;
        }
        return "失败";
    }

    /**
     * 图片删除
     *
     * @param imgUrl 图片路径
     * @return
     */
    @Override
    public Object deleteImg(String imgUrl) {
        imgUrl = imgUrl.replace(httpUrl, "");
        return FileUtils.deleteFile(imgUrl, uploadUrl);
    }

post 清求

服务器 可以看到成功上传上去了

访问也能访问到该图片

  • 14
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要将文件上传到服务器的指定目录下,可以使用 Java Servlet 的文件上传功能。下面是一个示例代码: ```java import java.io.File; import java.io.IOException; import java.io.PrintWriter; import java.util.List; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.Part; @WebServlet("/UploadServlet") public class UploadServlet extends HttpServlet { private static final long serialVersionUID = 1L; /** * 上传数据及保存文件 */ protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html;charset=UTF-8"); PrintWriter out = response.getWriter(); // 获取上传的文件集合 List<Part> parts = (List<Part>) request.getParts(); // 上传的目标文件夹路径 String uploadDir = "C:/upload/"; // 如果目标文件夹不存在,则创建 File fileSaveDir = new File(uploadDir); if (!fileSaveDir.exists()) { fileSaveDir.mkdir(); } // 遍历上传的文件集合 for (Part part : parts) { // 获取上传文件的名称 String fileName = extractFileName(part); // 如果上传文件的名称不为空,则保存文件 if (fileName != null && !fileName.equals("")) { // 保存上传的文件 part.write(uploadDir + fileName); out.println(fileName + "上传成功!<br>"); } } } /** * 从上传的文件头中提取上传的文件名 */ private String extractFileName(Part part) { String contentDisp = part.getHeader("content-disposition"); String[] items = contentDisp.split(";"); for (String str : items) { if (str.trim().startsWith("filename")) { return str.substring(str.indexOf("=") + 2, str.length() - 1); } } return null; } } ``` 上面的代码中,我们首先获取上传的文件集合,然后遍历文件集合,逐个保存文件到指定目录下。在保存文件之前,我们需要判断上传的目标文件夹是否存在,如果目标文件夹不存在,则创建。最后,我们通过 HTTP 响应向客户端返回上传结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值