详解Nginx搭建图片服务器过程

2019-10-17 18:08:57王冬梅

 

说明:

① @Value 注解是Spring4 中提供的,@Value("${XXX}")

② 返回值是一个Map,并且key有error,url,message。这是根据KindEditer的语法要求来的。

Controller 层

负责页面跳转的 PageController.java

package com.itdragon.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
public class PageController {

  /**
   * 打开首页
   */
  @RequestMapping("/")
  public String showIndex() {
    return "index";
  }
  
  @RequestMapping("/{page}")
  public String showpage(@PathVariable String page) {
    System.out.println("page : " + page);
    return page;
  }
}

负责图片上传的 PictureController.java

package com.itdragon.controller;

import java.util.Map;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;

import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.itdragon.service.PictureService;

@RestController
public class PictureController {

  @Autowired
  private PictureService pictureService;
  
  @RequestMapping("pic/upload")
  public String pictureUpload(@RequestParam(value = "fileUpload") MultipartFile uploadFile) {
    String json = "";
    try {
      Map result = pictureService.uploadPicture(uploadFile);
      // 浏览器擅长处理json格式的字符串,为了减少因为浏览器内核不同导致的bug,建议用json
      json = new ObjectMapper().writeValueAsString(result);
    } catch (JsonProcessingException e) {
      e.printStackTrace();
    }
    return json;
  }
}

说明:

① @RestController 也是Spring4 提供的,是 @Controller + @ResponseBody 的组合注解。

② Controller层的返回值是一个json格式的字符串。是考虑到浏览器对json解析兼容性比较好。

Views视图层

负责上传图片的jsp页面 pic-upload.jsp

<%@ page language="java" contentType="text/html; UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>ITDragon 图片上传</title>
</head>
  <link href="/js/kindeditor-4.1.10/themes/default/default.css" rel="external nofollow" type="text/css" rel="stylesheet">
  <script type="text/javascript" src="js/jquery.min.js"></script> 
  <script type="text/javascript" charset="utf-8" src="/js/kindeditor-4.1.10/kindeditor-all-min.js"></script>
  <script type="text/javascript" charset="utf-8" src="/js/kindeditor-4.1.10/lang/zh_CN.js"></script>
</head> 
<body> 
  <h3>测试上传图片功能接口的form表单</h3>
  <form action="pic/upload" method="post" enctype="multipart/form-data">
    <input type="file" name="fileUpload" />
    <input type="submit" value="上传文件" />
  </form>
  <hr />
  <h3>借用KindEditor富文本编辑器实现批量上传图片</h3>
  <textarea id="kindEditorDesc" style="width:800px;height:300px;visibility:hidden;"></textarea>
  <script type="text/javascript">
    $(function(){
      //初始化富文本编辑器
      KindEditor.create("#kindEditorDesc", {
        // name值,必须和Controller 的参数对应,不然会提示 400 的错误
        filePostName : "fileUpload",
        // action值,
        uploadJson : '/pic/upload',
        // 设置上传类型,分别为image、flash、media、file
        dir : "image"
      });
    });
  </script>  
</body>
</html>