ajax上传图片到服务器

前台代码:

html代码:

<div style="position: relative">

      <button type="button" style="margin-left: 10px;" class="btn btn-primary" data-toggle="modal">      <i class="fa fa-plus"></i> 上传图片

        </button>

        <form id="imgForm">

            <input type="file" id="uploadProductImg" class="EditImg"

                    style="bottom: 0;position: absolute;left: 100px;opacity: 0;margin-left: -60px;height: 50px;width: 140px;" name="file"/>

      </form>

</div>

js代码

//图片上传

    $("#uploadProductImg").on("change", function () {

        var v = this.value;

        if (!v) return;

        var sz = this.files[0].size / 1024 / 1024;

        var n = v.substring(v.lastIndexOf('.')).toLowerCase();

        //不能大于5M

        if (sz > 5) {

            alert("图片大小不能超过5MB!");

            return;

        }

        if (n == '.jpg' || n == '.jpeg' || n == '.png') {

            //如果格式正确,上传图片过程中页面按钮不可点击

            var formData = new FormData(document.getElementById("imgForm"));

            $.ajax({

                type: "POST",

                url: constant.url.sc_platform.imgSubmit,

                enctype: "multipart/form-data",

                contentType: false,

                processData: false,

                cache: false,

                data: formData,

                success: function (result) {

                    $.modal.alertSuccess('上传成功');

                    var imgUrl = constant.url.sc_platform.tool.getResourceUrl(result.data.relatPath);

                    console.log('======'+imgUrl);

                },

                error: function (err) {

                    alert("图片上传失败!");

                }

            });

        } else {

            alert("您选择的文件类型只能是图片(jpg、jpeg或png)");

        }

    });

common.js

imgSubmit: basePlatform + "/api/v1/product/sampling/temp/imgSubmit",//上传图片

tool: {

    //解析URL

    getQueryString: function (name) {

        var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i");

        var r = window.location.search.substr(1).match(reg);

        if (r != null) return unescape(r[2]);

        return null;

    },

    getResourceUrl: function (filePath) {

        //获取图片的全路径,兼容旧版路径和新版路径

        if (!filePath) {

            return filePath;

        }

        if (filePath.indexOf("group1/M00") >= 0) {

            //fastdfs路径

            return JNHC_RESOURCE_PATH + "/" + filePath;

        }

        return JNHCpath + "/img/" + filePath;

    }

},

后台代码:

controller:

@Value("${imageBaseUrl}")

    String imageBaseUrl;

    @PostMapping("/imgSubmit")

    public Result imgSubmit(@RequestParam(value = "file", required = false) MultipartFile file, HttpServletRequest request) throws Exception {

        String contentType = file.getContentType();//类型

        String fileName = file.getOriginalFilename();

        String suffix = fileName.substring(fileName.lastIndexOf(".") + 1);

        //String newName = "jcbg" + "." + suffix;

        String newName = "jcbg.png";

        String filePath = imageBaseUrl;

        Map<String, String> map = new HashMap<>();

        try {

            uploadFile(file.getBytes(), filePath, newName);

            map.put("imgName", newName);

            map.put("realPath", newName);

        } catch (Exception e) {

            // TODO: handle exception

        }

        return ResultGenerator.genSuccessResult(map);

    }

    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();

    }

application设置储存路径

#服务器图片地址

imageBaseUrl = /home/Qd/FarmersPlatformFront/img/jcbgImg/

#本地测试

#imageBaseUrl = D:/AA/

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,254评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,875评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,682评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,896评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,015评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,152评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,208评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,962评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,388评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,700评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,867评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,551评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,186评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,901评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,689评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,757评论 2 351

推荐阅读更多精彩内容