FastDFS 图片上传功能实现

1.功能分析  
     我们使用KindEditor的多图片上传插件,具体使用参考:http://kindeditor.net/doc.php

2.业务逻辑分析:
(1) 接收页面传递的图片信息uploadFile
(2) 把图片上传到图片服务器。使用封装的工具类实现。需要取文件的内容和扩展名。
(3) 图片服务器返回图片的url
(4) 将图片的url补充完整,返回一个完整的url。
(5) 把返回结果封装到一个Map对象中返回。

3.后台具体使用
(1) 把commons-io、fileupload 的jar包添加到工程中。
(2) 配置多媒体解析器。
<!-- 定义文件上传解析器 -->
      <bean id="multipartResolver"
           class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
           <!-- 设定默认编码 -->
           <property name="defaultEncoding" value="UTF-8"></property>
           <!-- 设定文件上传的最大值5MB,5*1024*1024 -->
           <property name="maxUploadSize" value="5242880"></property>
      </bean>
(3) Controller
@Controller
public class PictureController {

      @Value("${IMAGE_SERVER_URL}")
      private String IMAGE_SERVER_URL;

      @RequestMapping("/pic/upload")
      @ResponseBody
      public Map fileUpload(MultipartFile uploadFile) {
           try {
                 //1、取文件的扩展名
                 String originalFilename = uploadFile.getOriginalFilename();
                 String extName = originalFilename.substring(originalFilename.lastIndexOf(".") + 1);
                 //2、创建一个FastDFS的客户端
                 FastDFSClient fastDFSClient = new FastDFSClient("classpath:resource/client.conf");
                 //3、执行上传处理
                 String path = fastDFSClient.uploadFile(uploadFile.getBytes(), extName);
                 //4、拼接返回的url和ip地址,拼装成完整的url
                 String url = IMAGE_SERVER_URL + path;
                 //5、返回map
                 Map result = new HashMap<>();
                 result.put("error", 0);
                 result.put("url", url);
                 return result;
           } catch (Exception e) {
                 e.printStackTrace();
                 //5、返回map
                 Map result = new HashMap<>();
                 result.put("error", 1);
                 result.put("message", "图片上传失败");
                 return result;
           }
      }
}
4.解决浏览器兼容性的问题
     KindEditor的图片上传插件,对浏览器兼容性不好,使用@ResponseBody注解返回java对象:Content-Type:application/json;charset=UTF-8。
(1) 返回字符串时:Json格式


(2) 指定响应结果的Content-Type:text/plain;charset=UTF-8

(3) KindEditor的多图片上传插件最后响应的content-type是text/plan格式的json字符串。兼容性是最好的。

(4) Json与其他数据的相互转换,在以后用到使用该工具类即可。
import java.util.List;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.JavaType;
import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.ObjectMapper;

/**
 * 自定义响应结构
 */
public class JsonUtils {

    // 定义jackson对象
    private static final ObjectMapper MAPPER = new ObjectMapper();

    /**
     * 将对象转换成json字符串。
     * <p>Title: pojoToJson</p>
     * <p>Description: </p>
     * @param data
     * @return
     */
    public static String objectToJson(Object data) {
        try {
            String string = MAPPER.writeValueAsString(data);
            return string;
        } catch (JsonProcessingException e) {
            e.printStackTrace();
        }
        return null;
    }

    /**
     * 将json结果集转化为对象
     *
     * @param jsonData json数据
     * @param clazz 对象中的object类型
     * @return
     */
    public static <T> T jsonToPojo(String jsonData, Class<T> beanType) {
        try {
            T t = MAPPER.readValue(jsonData, beanType);
            return t;
        } catch (Exception e) {
            e.printStackTrace();
        }
        return null;
    }

    /**
     * 将json数据转换成pojo对象list
     * <p>Title: jsonToList</p>
     * <p>Description: </p>
     * @param jsonData
     * @param beanType
     * @return
     */
    public static <T>List<T> jsonToList(String jsonData, Class<T> beanType) {
        JavaType javaType = MAPPER.getTypeFactory().constructParametricType(List.class, beanType);
        try {
            List<T> list = MAPPER.readValue(jsonData, javaType);
            return list;
        } catch (Exception e) {
            e.printStackTrace();
        }

        return null;
    }
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员学习圈

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值