ajax異步提交圖片文本信息

ajax異步提交圖片文本信息

以上傳一個商品爲例:

在這裏插入圖片描述
會用到兩個jar包
commons-io-2.6-bin.tar.gz
commons-fileupload-1.4-bin.tar.gz
把這兩個導入到WEB-INF下的lib目錄中

html頁面的代碼

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <link rel="stylesheet" type="text/css" href="css/register.css">
    <link rel="stylesheet" type="text/css" href="css/style.css">
    <link rel="stylesheet" type="text/css" href="css/bootstrap.min.css">
    <script src="js/jquery-3.3.1.js"></script>
    <script src="js/include.js"></script>
    <script>
        $(function () {
            $("#release_form").submit(function (e) {
                e.preventDefault(); //禁止刷新
                const file = $("#upfile")[0].files[0];//獲得圖片路徑
                const release_GoodsName = $("#release_GoodsName").val();//商品發佈的名字

                const release_gNameIntroduce = $("#release_gNameIntroduce").val();//發佈的商品簡介
                const release_price = $("#release_price").val();//發佈的商品的價格
                const release_gIntroduce = $("#release_gIntroduce").val();//發佈的商品的介紹
                const release_qq = $("#release_qq").val();//發佈的商品的聯繫方式
                const release_cid = $("#release_cid").val();//發佈的商品的聯繫方式


                let formData = new FormData();
                formData.append("upfile", file);
                formData.append("release_GoodsName", release_GoodsName);
                formData.append("release_gNameIntroduce", release_gNameIntroduce);
                formData.append("release_price", release_price);
                formData.append("release_gIntroduce", release_gIntroduce);
                formData.append("release_qq", release_qq);
                formData.append("release_cid", release_cid);


                $.post({
                    url: "goods/release",
                    dataType: "json",
                    async: false,
                    data: formData,
                    processData: false,
                    contentType: false,
                    success: function (data) {
                        console.log(data);
                    },
                    error: (err) => {
                        console.log(err);
                    }
                })

            });
        });
    </script>
</head>
<body>
<div id="header"></div>
<div class="user_login_register">
    <form id="release_form" ENCTYPE="multipart/form-data" method="post">
        <div class="form-group">
            <label for="release_GoodsName">商品的名稱</label>
            <input type="text" class="form-control" id="release_GoodsName" name="gName">
        </div>
        <div class="form-group">
            <label for="release_gNameIntroduce">商品的簡介</label>
            <input type="text" class="form-control" id="release_gNameIntroduce" name="gNameIntroduce">
        </div>
        <div class="form-group">
            <label for="release_price">商品的價格</label>
            <input type="text" class="form-control" id="release_price" name="price">
        </div>
        <div class="form-group">
            <label for="release_gImg">File input</label>
            <input id="upfile" class="form-control" accept="image/*" name="gImg" id="release_gImg" type="file"
                   value="上傳圖片"/><br>
        </div>
        <div class="form-group">
            <label for="release_gIntroduce">商品的介紹</label>
            <textarea class="form-control" id="release_gIntroduce" name="gIntroduce" rows="3"></textarea>
        </div>
        <div class="form-group"><label for="release_cid">商品的分類</label>
            <select id="release_cid" name="release_cid" class="form-control">
                <option value="1">手機</option>
                <option value="2">電腦</option>
                <option value="3">書籍</option>
                <option value="4">化妝品</option>
                <option value="5">其它</option>
            </select></div>
        <div class="form-group">
            <label for="release_qq">賣家的聯繫方式</label>
            <input type="text" class="form-control" id="release_qq" name="qq">
        </div>


        <div style="text-align: center;">
            <input type="submit" style="border:1px green solid;" class="btn btn-default" name="submit" value="提交">
        </div>
    </form>
</div>
<div id="footer"></div>

</body>
</html>

javaServlet中的代碼

  /**
     * 用戶發佈商品信息
     *
     * @param request
     * @param response
     */
    public void release(HttpServletRequest request, HttpServletResponse response) throws UnsupportedEncodingException {
        request.setCharacterEncoding("utf-8");
        AllGoodsPlus allGoodsPlus = new AllGoodsPlus();
        //解析和檢查請求,是否是post方式,是否是二進制流格式
        Boolean isMultipart = ServletFileUpload.isMultipartContent(request);

        try {

            //創建FileItemFactory對象
            FileItemFactory factory = new DiskFileItemFactory();


            //創建文件上傳的處理器
            ServletFileUpload upload = new ServletFileUpload(factory);


            //解析請求
            List<FileItem> items = upload.parseRequest(request);

            for (FileItem item : items) {
                String fileName = item.getFieldName();

                if (item.isFormField()) {
                    //普通的表單控件
                    String value = item.getString("utf-8");
                    //向AllGoods對象中封裝
                    if ("release_GoodsName".equals(fileName)) {
                        allGoodsPlus.setgName(value);//設置商品名稱
                    } else if ("release_gNameIntroduce".equals(fileName)) {
                        allGoodsPlus.setgNameIntroduce(value);//設置商品的名字簡介
                    } else if ("release_price".equals(fileName)) {
                        allGoodsPlus.setPrice(Double.parseDouble(value));//設置商品的價格
                    } else if ("release_gIntroduce".equals(fileName)) {
                        allGoodsPlus.setgIntroduce(value); // 設置商品的介紹
                    } else if ("release_qq".equals(fileName)) {
                        allGoodsPlus.setQq(value); //設置賣家的商品的聯繫方式
                    } else  if ("release_cid".equals(fileName)){
                        allGoodsPlus.setCid(Integer.parseInt(value));
                    }

                } else {
                    //上傳文件的控件
                    String RandomName = UUID.randomUUID().toString() + "." + FilenameUtils.getExtension(item.getName());
                    allGoodsPlus.setgImg("img/" + RandomName);
                    String path = super.getServletContext().getRealPath("/img");
                    item.write(new File(path, RandomName)); //把上傳的文件保存到某個文件中

                }
            }
            SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");


            allGoodsPlus.setGdate(sdf.format(new Date()));//設置發佈時間

            allGoodsPlus.setUsername(((User) request.getSession().getAttribute("user")).getUsername());
			//這時所有的信息都已封裝到了allGoodsPlus的對象中,傳到service去執行
            int flag = service.release(allGoodsPlus);

            writeValue(flag,response);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章