使用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); } }