前后端实现上传图片功能(JAVA代码)

1.前端大概

请求头必须为AJAX请求头: 'X-Requested-With': 'XMLHttpRequest'

一般是指网页中存在的Content-Type,用于定义网络文件的类型和网页的编码,决定文件接收方将以什么形式:
                                                  application/x-www-form-urlencoded:数据被编码为名称/值对。这是标准的编码格式。
                                                  multipart/form-data: 数据被编码为一条消息,页上的每个控件对应消息中的一个部分。

 

2.设置请求头格式

Vue.prototype.$sendFormData = axios.create({
  baseURL: baseUrl,
  timeout: 60000,
  headers: {
    'X-Requested-With': 'XMLHttpRequest',
    'Content-Type': 'multipart/form-data'
  },
})

3.AJAX请求代码:

submitUpload() {
            // this.$refs.upload.submit();
             if(this.imageFileName.length>5){
                this.$message('图片不能超过5张');
                return false
           }
            let data  = {};  
            let files = this.imageFileName;  
            console.log(files)
            let param = new FormData(); //创建form对象  
            if(files!=''){  
                files.forEach((n,i)=>{
                    console.log(n)
                    n['isFormField']=true;
                    param.append('broadcastName',n.raw)
                    // param.append('isFormField',true)
                })
                param.append('strusercode',this.pubFuc.user.strusercode)
                ; //单个图片 ,多个用循环 append 添加   
                console.log(param)
            }else{  
                this.$message.error("图片不对");  
                return false
            }   
            this.$sendFormData.post('broadcast/uploadPicture',param)
            .then(data=>{
                if(data.data.result==1000){
                    this.imageFileName=[];
                }else{
                    this.$message({
                        type:"error",
                        message:data.data.msg
                    })
                }
            })
      },
 

4.JAVA后台代码(比较长:原因是一个方法,为方便大家看)

@GET
    @POST
    @Path("/uploadPicture")
    @Produces("application/json;charset=UTF-8")
    @Consumes("multipart/form-data")
    public String uploadPicture(@Context HttpServletRequest request, @Context HttpServletResponse response){
        JSONObject resultJson = new JSONObject();
        String imgName=null;//给图片定义名称
        String imgPath = null;//给图片指定的上传路径
        String strusercode=null;
        List<Map<String,Object>> list = new ArrayList<Map<String,Object>>();
        try{
            //创建服务器路径存储图片
            imgPath=THESERVERURL+"broadcast\\";
            //创建文件夹
            File file = new File(imgPath);
            if (!file.exists()){// 创建文件夹
                file.mkdirs();
            }else{
                //删除文件中的所有图片
                String name[]=file.list();
                for (int i=0; i<name.length; i++){  
                    File f=new File(imgPath,name[i]);//此时就可得到文件夹中的文件  
                    f.delete();//删除文件  
                }  
            }
            DiskFileItemFactory factory = new DiskFileItemFactory(); // 设置工厂
            factory.setRepository(new File(imgPath)); // 设置文件存储位置
            factory.setSizeThreshold(1024 * 1024); // 设置大小,如果文件小于设置大小的话,放入内存中,如果大于的话则放入磁盘中,单位是byte
            ServletFileUpload upload = new ServletFileUpload(factory);
            upload.setHeaderEncoding("utf-8"); // 这里就是中文文件名处理的代码,其实只有一行
            List<FileItem> listform = upload.parseRequest(request);
            if (listform != null && !listform.isEmpty()){
                int sort=0;
                for (FileItem fileItem : listform){
                    sort++;
                    Map<String,Object> map =new HashMap<String,Object>();
                    // 判断表单数据是否为普通字段 不是则为图片字段
                    if (fileItem.isFormField()){
                        String fieldName = fileItem.getFieldName();// 获取表单字段名称
                        String value = fileItem.getString("utf-8");// 获取表单字段值
                        strusercode=value;//获取用户编码
                    }else{
                        // 上传图片的保存
                        String value = fileItem.getName();//值
                        //String fieldName = fileItem.getFieldName();// 获取表单字段名称
                        if(value!=null && !"".equals(value)){
                            // 保存的图片名称  currentTimeMillis时间搓
                            imgName = System.currentTimeMillis()+ fileItem.getName().substring(fileItem.getName().lastIndexOf("."));
                            // 保存(写)
                            fileItem.write(new File(imgPath, imgName));
                            map.put("broadcastUrl", "broadcast/" + imgName);//图片路径
                            map.put("booleans", "1");//是否显示图片
                            map.put("sort", sort);//图片路径
                            map.put("dtnoticetime", PublicTools.gettime());//上传时间
                            list.add(map);
                        }
                    }
                }
                //删除表里面的图片记录
                userDaoImpl.delete("delete from t_broadcast");
                //往表里插入数据
                userDaoImpl.insertinto(BroadcastSql.insertSql(list, strusercode));
            }else{
                return this.returnError(resultJson,ResMessage.Server_Abnormal.code,request);
            }
        } catch (Exception e){
            logger.info("登录信息异常",e);
            return this.returnError(resultJson,ResMessage.Server_Abnormal.code,request);
        }
        return this.response(resultJson, request);
    }

JAVA 上传图片功能的更多相关文章

  1. JSP+java上传图片到服务器,并将地址保存至MYSQL + JSP网页显示服务器的图片

    这两天遇到个需求——用户头像修改功能. 查了好多资料,不是代码不全,就是某些高端框架,卡了好久,今已实现,分享给大家,如果有更好的方法,非常感谢可以在下方评论区写出 一.整体项目架构 二.web.xm ...

  2. 配置Django-TinyMCE组件支持上传图片功能

    Django自带的Admin后台,好用,TinyMCE作为富文本编辑器,也蛮好用的,这两者结合起来在做博客的时候很方便(当然博客可能更适合用Markdown来写),但是Django-TinyMCE这个 ...

  3. JAVA文件下载功能问题解决日志

    今天给报告系统做了个下载功能,遇到了挺多问题,通过查资料一一解决了. 1.首先遇到的问题是:java后台的输出流输出之后,没有任何报错,浏览器端不弹出保存文件的对话框,原本是ajax请求到后台的con ...

  4. python面向对象进阶 反射 单例模式 以及python实现类似java接口功能

    本篇将详细介绍Python 类的成员.成员修饰符.类的特殊成员. 类的成员 类的成员可以分为三大类:字段.方法和特性. 注:所有成员中,只有普通字段的内容保存对象中,即:根据此类创建了多少对象,在内存 ...

  5. Atitit.java eval功能的实现  Compiler API

    Atitit.java eval功能的实现  Compiler API 输出echo2 输出目录配置2 针对编译器,JDK 设计了两个接口,分别是 JavaCompiler 和JavaCompiler ...

  6. MVC ueditor的使用(实现上传图片功能)

    之前使用ckeditor不能实现上传图片功能,只要是我不知道怎么使用啦o( ̄ε ̄*),然后就换了ueditor~~,可以实现上传图片功能啦~\(≧▽≦)/~~ 下面是我的步骤:去官网下载最新版uedi ...

  7. aspx页面中用Input 标签实现上传图片功能

    实现上传图片功能需单独的建立一个aspx页面, 其中前台页面需要注意两点: a)实现上传功能的input的type="file" b)设置请求报文头为 enctype=" ...

  8. Android 虚拟机Dalvik、Android各种java包功能、Android相关文件类型、应用程序结构分析、ADB

    Android虚拟机Dalvik Dalvik冲击 随着Google 的AndroidSDK 的发布,关于它的API 以及在移动电话领域所带来的预期影响这些方面的讨论不胜枚举.不过,其中的一个话题在J ...

  9. JNI的替代者—使用JNA访问Java外部功能接口

    摘自:http://www.cnblogs.com/lanxuezaipiao/p/3635556.html JNI的替代者-使用JNA访问Java外部功能接口 1. JNA简单介绍 先说JNI(Ja ...

随机推荐

  1. TRIZ系列-创新原理-8-重量补偿原理

    重量补偿原理的表述例如以下: 1)将某一物体与还有一种提供上升力的物体组合,以补偿其重量:2)通过与环境(利用空气动力,流体动力或其他力等)的相互作用.实现对物体的重量补偿: 重力使得我们能够稳稳的依 ...

  2. 本地jar安装至maven仓库

    本地jar安装至maven仓库 一般不建议通过这种方式配置依赖,通常做法建议你把本地包安装到maven仓库,命令如下: mvn install:install-file-DgroupId=com.ht ...

  3. linux下怎样将sheduler绑定到制定的cpu核上

    作者:张昌昌   1.顺序绑定 erl +sbt db 是按从前到后的顺序来绑定调度器的,如: erl +sbt db +S 3含义是启动erlang虚拟机,开启3个调度器,按顺序绑定在0,1.2号核 ...

  4. Test Doubles - Fakes, Mocks and Stubs.

    https://dev.to/milipski/test-doubles---fakes-mocks-and-stubs This text was originally posted at Prag ...

  5. 怎样才是一个基本水平的java程序员?

    怎样才是一个基本水平的java程序员? 熟悉常用的数据结构,包括数组,链表,树,哈希表等. 熟悉结构化编程和面向对象编程. 能够阅读UML设计图,根据UML语义进行编码 了解RDBMS和SQL的使用, ...

  6. hihoCoder-1633 ACM-ICPC北京赛区2017 G.Liaoning Ship’s Voyage 线段与三角形规范相交

    题面 题意:给你一个20*20的地图,起点(0,0),终点(n-1,n-1),有障碍的点为‘#’,每次可以向8个方向走一步,还给了一个三角形,除了障碍以外,到这8个方向上的点的线段如果没有与三角形相交 ...

  7. vue开发的项目中遇到的警告,报错,配置项目文件等合集(长期更新)

    1. Vue组件里面data()里面没有return时触发错误:Vue components Cannot read property '__ob__' of undefined 这个警告不解决会触发 ...

  8. 大数字运算——1、BigInteger

    package com.wh.BigInteger; import java.math.BigInteger; import java.util.Arrays; /** * @author 王恒 * ...

  9. (C++)错误提示 c2352 :非静态成员函数的非法调用

    静态成员函数相当于全局函数,只是有一个类名字空间的限制.而类成员函数是成员内部的函数,同一个类的对象实例可以有很多,每一个实例都有自已不同的成员变量值,成员函数一般都是对成员自已的成员变量值在操作.所 ...

  10. javascript中模块化知识总结

    JavaScript 模块化开发 1. 模块化介绍 掌握模块化基本概念以及使用模块化带来的好处 当你的网站开发越来越复杂的时候,会经常遇到什么问题? 恼人的命名冲突 繁琐的文件依赖 历史上,JavaS ...