使用Webupload上傳圖片到FastDFS分佈式文件系統

使用Webupload插件上傳圖片到FastDFS分佈式文件系統。javascript

前提條件:1.已安裝FastDFS分佈式文件系統css

                  2.使用webuploader插件上傳文件html

                  3.maven工程已引入FastDFS依賴前端

 

圖片上傳及圖片回顯部分代碼以下:java

<!-- 添加商品頁面 -->

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
    <base th:href="|${#request.getContextPath()}/|"/>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>Insert title here</title>
    <link rel="stylesheet" href="resources/css/reset.css" type="text/css"
          media="screen" />
    <link rel="stylesheet" href="resources/css/style.css" type="text/css"
          media="screen" />
    <link rel="stylesheet" href="resources/css/invalid.css" type="text/css"
          media="screen" />
    <script type="text/javascript"
            src="resources/scripts/jquery-1.8.3.min.js"></script>

    <!-- 引入上傳控件 webuploader -->
    <link rel="stylesheet" href="resources/widget/webuploader/webuploader.css" type="text/css"
          media="screen" />
    <script type="text/javascript" src="resources/widget/webuploader/webuploader.min.js"></script>

    <script>
        var uploader;
        $(function(){
            //初始化webuploader插件
            uploader = WebUploader.create({
                // 選完文件後,是否自動上傳。
                auto: false,
                // swf文件路徑
                swf: 'resources/widget/webuploader/Uploader.swf',
                // 文件接收服務端。
                server: '/imgs/uploader',
                // 選擇文件的按鈕。可選。
                // 內部根據當前運行是建立,多是input元素,也多是flash.
                pick: '#filePicker',
                // 只容許選擇圖片文件。
                accept: {
                    title: 'Images',
                    extensions: 'gif,jpg,jpeg,bmp,png',
                    mimeTypes: 'image/*'
                }
            });

            //給webuploader綁定事件
            //fileQueued  當文件被加入隊列之後觸發
            uploader.on("fileQueued",function (file) {
                //生成圖片縮略圖
                uploader.makeThumb( file, function (error ,ret) {
                    if(error){
                        alert(file.name+"縮略圖生成失敗")
                    }else{
                        //將縮略圖展現到預覽圖div中
                        var img = "<img src=\""+ret+"\" style=\"height: 100px; width: 100px; margin-right: 5px;\"/>"
                        $("#imgs_div").append(img);
                    }
                    
                }, 100, 100 )
            });

            //給webupload綁定成功事件
            uploader.on("uploadSuccess",function (file,response) {
                var val = $("#image_paths").val();//獲取images_path標籤值
                if(val.length > 0){
                    val += "|";
                }
                val += response.imgUrl;
                $("#image_paths").val(val);//設置images_path標籤值
            })
        });

        /**
         * 上傳圖片
         */
        function upload_imgs(){
            if(uploader){
                uploader.upload();
            }
        }
    </script>

</head>
<body>
<div id="main-content">
    <div class="content-box">
        <div class="content-box-content">
            <div class="tab-content default-tab" id="tab2">
                <form action="/goods/insert" method="post">
                    <fieldset>
                        <!-- Set class to "column-left" or "column-right" on fieldsets to divide the form into columns -->
                        <p>
                            <label>商品名稱</label> <input
                                class="text-input small-input" type="text"
                                name="gname" />
                        </p>
                        <p>
                            <label>商品圖片</label>
                            <!--dom結構部分-->
                            <div id="uploader-demo">
                                <!-- 存放上傳圖片的預覽圖 -->
                                <div id="imgs_div" style="border: solid 1px #D0D0D0; width: 500px; height: 120px; margin-bottom: 10px; padding: 20px;">
                                   <!-- <img src="xxx" style="height: 100px; width: 100px; margin-right: 5px;"/>
                                    <img src="xxx" style="height: 100px; width: 100px; margin-right: 5px;"/>
                                    <img src="xxx" style="height: 100px; width: 100px; margin-right: 5px;"/>
                                    <img src="xxx" style="height: 100px; width: 100px; margin-right: 5px;"/>-->
                                </div>
                                <button type="button" class="mybutton" style="margin-bottom: 10px;" onclick="upload_imgs();">上傳圖片</button>
                                <div id="filePicker">選擇圖片</div>
                                <input id="image_paths" type="hidden" name="gimage" value=""/>
                            </div>
                        </p>
                        <p>
                            <label>商品價格</label> <input
                                class="text-input small-input" type="text"
                                name="gprice" />
                        </p>
                        <p>
                            <label>商品庫存</label> <input
                                class="text-input small-input" type="text"
                                name="gsave" />
                        </p>
                        <p>
                            <label>商品的描述</label>
                            <textarea class="text-input textarea wysiwyg"
                                      name="ginfo" cols="79" rows="15"></textarea>
                        </p>
                        <p>
                            <input class="mybutton" type="submit" value="提交" />
                        </p>
                    </fieldset>
                    <div class="clear"></div>
                    <!-- End .clear -->
                </form>
            </div>
            <!-- End #tab2 -->
        </div>
        <!-- End .content-box-content -->
    </div>
</div>
<!-- End #main-content -->
</body>
</html>

 

<!-- 商品列表頁面 -->

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
    <base th:href="|${#request.getContextPath()}/|"/>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>Insert title here</title>
    <!-- Reset Stylesheet -->
    <link rel="stylesheet" href="resources/css/reset.css" type="text/css"
          media="screen" />
    <!-- Main Stylesheet -->
    <link rel="stylesheet" href="resources/css/style.css" type="text/css"
          media="screen" />
    <link rel="stylesheet" href="resources/css/invalid.css" type="text/css"
          media="screen" />
    <script type="text/javascript"
            src="resources/scripts/jquery-1.3.2.min.js"></script>
    <!-- jQuery Configuration -->
    <script type="text/javascript"
            src="resources/scripts/simpla.jquery.configuration.js"></script>
</head>
<body>
<div id="main-content">
    <div class="content-box">
        <!-- End .content-box-header -->
        <div class="content-box-content">
            <div class="tab-content default-tab" id="tab1">
                <table>
                    <thead>
                    <tr>
                        <th><input class="check-all" type="checkbox" /></th>
                        <th>商品名稱</th>
                        <th>商品圖片</th>
                        <th>商品描述</th>
                        <th>商品價格</th>
                        <th>操做</th>
                    </tr>
                    </thead>

                    <tbody>
                        <tr th:each="good : ${goods}">
                            <td><input type="checkbox" /></td>
                            <td th:text="${good.gname}">Lorem ipsum dolor</td>
                            <!--默認展現商品的第一張圖片-->
                            <td><img style="width: 120px;height: 100px;" th:src="|http://192.168.59.131/${#strings.setSplit(good.gimage,'|')[0]}|"/></td>
                            <td th:text="${good.ginfo}">Consectetur adipiscing</td>
                            <td th:text="${#numbers.formatCurrency(good.gprice)}">Donec tortor diam</td>
                            <td>
                                <!-- Icons --> <a href="#" title="Edit"><img
                                    src="resources/images/icons/pencil.png" alt="Edit" /></a> <a
                                    href="#" title="Delete"><img
                                    src="resources/images/icons/cross.png" alt="Delete" /></a> <a
                                    href="#" title="Edit Meta"><img
                                    src="resources/images/icons/hammer_screwdriver.png"
                                    alt="Edit Meta" /></a>
                            </td>
                        </tr>
                    </tbody>

                    <tfoot>
                    <tr>
                        <td colspan="6">
                            <div class="bulk-actions align-left">
                                <a class="mybutton" href="/topage/goodsadd">添加商品</a>
                            </div>
                            <div class="clear"></div>
                        </td>
                    </tr>
                    </tfoot>
                </table>
            </div>
        </div>
        <!-- End .content-box-content -->
    </div>
</div>
<!-- End #main-content -->
</body>
</html>

 

//ImgController

import com.alibaba.fastjson.JSON;
import com.github.tobato.fastdfs.domain.StorePath;
import com.github.tobato.fastdfs.service.FastFileStorageClient;
import org.apache.commons.io.IOUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.multipart.MultipartFile;

import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.HashMap;
import java.util.Map;
import java.util.UUID;


@Controller
@RequestMapping("/imgs")
public class ImgController {

    @Autowired
    private FastFileStorageClient fastFileStorageClient;
    //private static final String UPLOAD_PATH = "e:\\imgs";

    @RequestMapping("/uploader")
    @ResponseBody
    public String uploadImg(MultipartFile file) {

        //得到上傳文件後輟的下標 xxx.png
        int index = file.getOriginalFilename().lastIndexOf(".");//返回指定字符在此字符串中最後一次出現處的索引
        String suffix =file.getOriginalFilename().substring(index+1);
        System.out.println("截取到的文件名後輟: "+suffix);
//文件上到FastDFS try { StorePath storePath = fastFileStorageClient.uploadImageAndCrtThumbImage(file.getInputStream(), file.getSize(), suffix, null); //獲取上傳到FastDFS中圖片的路徑 String imgUrl = storePath.getFullPath(); System.out.println("FastDFS中圖片的路徑: "+imgUrl); //將存FastDFS中圖片的路徑以JSON方式返回到前端頁面 Map<String,Object> map = new HashMap<>(); map.put("imgUrl",imgUrl); String param = JSON.toJSONString(map); return param; //return "{\"uploadPath\":\"" + imgUrl + "\"}"; } catch (IOException e) { e.printStackTrace(); } /* //文件上傳到本地磁盤 try ( InputStream inputStream = file.getInputStream(); OutputStream outputStream = new FileOutputStream(UPLOAD_PATH + UUID.randomUUID().toString()); ) { IOUtils.copy(inputStream, outputStream); } catch (IOException e) { e.printStackTrace(); }*/ return null; } }

 

//GoodsController 

import com.alibaba.dubbo.config.annotation.Reference;
import com.qf.entity.Goods;
import com.qf.service.IGoodsService;
import org.springframework.stereotype.Controller;
import org.springframework.ui.ModelMap;
import org.springframework.web.bind.annotation.RequestMapping;

import java.util.List;

@Controller
@RequestMapping("/goods")
public class GoodsController {

    @Reference
    private IGoodsService goodsService;
    /**
     * 查詢商品列表
     */
    @RequestMapping("/list")
    public String goodslist(ModelMap map){
        List<Goods> goods = goodsService.queryAll();
        map.put("goods",goods);
        return "goodslist";
    }

    /**
     * 新增商品
     */
    @RequestMapping("/insert")
    public String goodsinsert(Goods goods){
        int count = goodsService.insert(goods);
        return "redirect:/goods/list";
    }
}

 

//spring boot的入口啓動類

import com.github.tobato.fastdfs.FdfsClientConfig;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.Import;

@SpringBootApplication(scanBasePackages = "com.qf")
@Import(FdfsClientConfig.class)
public class ShopBackApplication {

    public static void main(String[] args) {
        SpringApplication.run(ShopBackApplication.class, args);
    }

}
相關文章
相關標籤/搜索