SpringMVC文件上传、Json处理

文章目录


本文主要介绍SpringMVC中然后实现文件上传已经Json处理。

文件上传

在SpringMVC的pom.xml基础上,加上文件上传的pom.xml:

<dependency>
      <groupId>commons-fileupload</groupId>
      <artifactId>commons-fileupload</artifactId>
      <version>1.3.3</version>
</dependency>

然后在你的springMVC的配置文件中加入一个Bean:

<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
        <!-- 必须和用户JSP 的pageEncoding属性一致,以便正确解析表单的内容 -->
        <property name="defaultEncoding" value="UTF-8"></property>
        <!-- 文件最大大小(字节) 1024*1024*50=50M-->
        <property name="maxUploadSize" value="52428800"></property>
        <!--resolveLazily属性启用是为了推迟文件解析,以便捕获文件大小异常-->
        <property name="resolveLazily" value="true"/>
</bean>

接下来就可以测试了:
JSP:
注意的是form要是多功能表单(enctype=“multipart/form-data”),这样才能实现文件上传

<body>

    <form action="${pageContext.request.contextPath}/upload" method="post" enctype="multipart/form-data">
        上传的文件:<input type="file" name="img" id="">
        <button type="submit">提交</button>
    </form>

</body>

方法:
注意的是第二个参数要是文件,也就是你上传之后的文件的名字

    @RequestMapping("/upload")
    public String upload(MultipartFile img){
        try {
            FileUtils.copyInputStreamToFile(img.getInputStream(),new File("D:\\"+img.getOriginalFilename()));
        } catch (IOException e) {
            e.printStackTrace();
        }
        return "forward:hello3";
    }

以上,即可成功使用了。

Json处理

编写一个工具类JSONResult :

package com.zlk.util;

public class JSONResult {

    // 响应业务状态
    private Integer status;

    // 响应消息
    private String msg;

    // 响应中的数据
    private Object data;

    private String ok;	// 不使用

    public static JSONResult build(Integer status, String msg, Object data) {
        return new JSONResult(status, msg, data);
    }

    public static JSONResult ok(Object data) {
        return new JSONResult(data);
    }

    public static JSONResult ok() {
        return new JSONResult(null);
    }

    public static JSONResult errorMsg(String msg) {
        return new JSONResult(500, msg, null);
    }

    public static JSONResult errorMap(Object data) {
        return new JSONResult(501, "error", data);
    }

    public static JSONResult errorTokenMsg(String msg) {
        return new JSONResult(502, msg, null);
    }

    public static JSONResult errorException(String msg) {
        return new JSONResult(555, msg, null);
    }

    public JSONResult() {

    }

    public JSONResult(Integer status, String msg, Object data) {
        this.status = status;
        this.msg = msg;
        this.data = data;
    }

    public JSONResult(Object data) {
        this.status = 200;
        this.msg = "OK";
        this.data = data;
    }

    public Boolean isOK() {
        return this.status == 200;
    }

    public Integer getStatus() {
        return status;
    }

    public void setStatus(Integer status) {
        this.status = status;
    }

    public String getMsg() {
        return msg;
    }

    public void setMsg(String msg) {
        this.msg = msg;
    }

    public Object getData() {
        return data;
    }

    public void setData(Object data) {
        this.data = data;
    }

    public String getOk() {
        return ok;
    }

    public void setOk(String ok) {
        this.ok = ok;
    }

}


方法:

    @ResponseBody
    @RequestMapping("/jsonData3")
    public JSONResult jsonData3(){
        return JSONResult.ok("成功:此参数可以存放字符串、对象、集合都可以,这样可以节省拼接map集合的过程");
    }

    @ResponseBody
    @RequestMapping("/jsonData4")
    public JSONResult jsonData4(){
        return JSONResult.errorMsg("失败,此参数可以存放字符串、对象、集合都可以,这样可以节省拼接map集合的过程");
    }

效果:
在这里插入图片描述

在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值