当前位置:首页 >  站长 >  编程技术 >  正文

基于SpringBoot利用ajax实现上传图片功能

 2020-11-25 14:51  来源: 脚本之家   我来投稿 撤稿纠错

  【推荐】海外独服/站群服务器/高防

这篇文章主要介绍了Spring Boot利用 ajax实现上传图片功能,本文图文实例相结合,给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下

SpringBoot重写addResourceHandlers映射文件路径

@Override
 public void addResourceHandlers(ResourceHandlerRegistry registry) {
   registry.addResourceHandler("/imctemp-rainy/**").addResourceLocations("file:D:/E/");
 }

设置静态资源路径

2. 表单 前端 页面

<input type="file" name="file" id="file">
<p id="url"><img src="" width=200></p>
<input type="button" id="button" value="上传" >
$(function () {
    $("#button").click(function () {
      var form = new FormData();
      form.append("file", document.getElementById("file").files[0]);
       $.ajax({
         url: "/stu/upload",    //后台url
         data: form,
         cache: false,
         async: false,
         type: "POST",          //类型,POST或者GET
         dataType: 'json',       //数据返回类型,可以是xml、json等
         processData: false,
         contentType: false,
         success: function (data) {   //成功,回调函数
           if (data) {
           var pic="/imctemp-rainy/"+data.fileName;
           $("#url img").attr("src",pic);
           // alert(JSON.stringify(data));
           } else {
           alert("失败");
           }
         },
         error: function (er) {     //失败,回调函数
         alert(JSON.stringify(data));
         }
       });
    })
  })

控制器

public static void uploadFile(byte[] file, String filePath, String fileName) throws Exception {   
 File targetFile = new File(filePath);
 if (!targetFile.exists()) {
   targetFile.mkdirs(); 
 }   
 FileOutputStream out = new FileOutputStream(filePath +"/"+ fileName);
 out.write(file);  
 out.flush(); 
 out.close();
 }
 //处理文件上传
  @ResponseBody //返回json数据
  @RequestMapping(value = "upload", method = RequestMethod.POST)
  public JSONObject uploadImg(@RequestParam("file") MultipartFile file,HttpServletRequest request) {   
    String contentType = file.getContentType();
    System.out.print(contentType);
  String fileName = System.currentTimeMillis()+file.getOriginalFilename(); 
  String filePath = "D:/E";
   JSONObject jo = new JSONObject();//实例化json数据
 
  if (file.isEmpty()) { 
   jo.put("success", 0);
   jo.put("fileName", "");
  }   
  try {
    uploadFile(file.getBytes(), filePath, fileName);
    jo.put("success", 1);
    jo.put("fileName", fileName);
   // jo.put("xfileName", filePath+"/"+fileName);
  } catch (Exception e) {
  // TODO: handle exception   
 
  } 
 
  //返回json
    return jo; 
  } 

总结

以上所述是小编给大家介绍的基于Spring Boot利用 ajax实现上传图片功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

来源:脚本之家

链接:https://www.jb51.net/article/174084.htm

申请创业报道,分享创业好点子。点击此处,共同探讨创业新机遇!

相关标签
ajax

相关文章

  • Ajax实现页面无刷新留言效果

    这篇文章主要为大家详细介绍了Ajax实现页面无刷新留言效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

    标签:
    ajax
  • AJAX检测用户名是否存在的方法

    这篇文章主要为大家详细介绍了AJAX检测用户名是否存在,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

    标签:
    ajax
  • 使用AJAX 包含正则表达式 验证用户登录的步骤

    这篇文章主要介绍了使用AJAX(包含正则表达式)验证用户登录的步骤,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下

    标签:
    ajax
  • ajax使用formdata上传文件流

    这篇文章主要为大家详细介绍了ajax使用formdata上传文件流,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

    标签:
    ajax
  • Spring MVC+ajax进行信息验证的方法

    AJAX不是新的编程语言,而是一种使用现有标准的新方法。这篇文章主要介绍了SpringMVC+ajax进行信息验证,需要的朋友可以参考下

    标签:
    ajax

热门排行

信息推荐