【在Spring MVC框架和Spring Boot项目中,控制器的响应结果】

目录

1. 控制器的响应结果

2. 相关配置

3. 使用枚举优化代码


1. 控制器的响应结果

当控制器处理了请求之后,向客户端响应的结果中,应该至少包含:

  • 业务状态码:通常是数值类型的,客户端可以根据此数值来判断操作成功与否,或者,失败时是哪一种失败,具体值应该是由服务器端和客户端协商的
  • 消息:是字符串类型的,客户端可以将此消息直接显示在软件的界面中(例如显示在网页中、显示在手机APP中……),有了这个数据,客户端就不必自行组织语言来描述操作结果

 由于响应结果只有1个,但是需要同时包含业务状态和消息,应该使用JSON格式来组织这样的结果,例如:

{
    "state": 1,
    "message": "添加相册成功!"
}

或者:

{
    "state": 2,
    "message": "添加相册失败,尝试添加的相册名称已经被使用!"
}

2. 相关配置

在Spring MVC框架中,当需要响应JSON格式的字符串时,需要:

  • 使用自定义的数据类型作为处理请求的方法的返回值类型,并返回自定义数据类型的对象
  • 需要在项目中添加jackson-databind依赖项
    • spring-boot-starter-web中已经包含jackson-databind
  • 需要开启注解驱动
    • 在基于XML配置的Spring MVC项目中,需要在XML配置中添加<annotation-driven/>标签
    • 在基于注解配置的Spring MVC项目中,需要在配置类上添加@EnableWebMvc注解
    • 在Spring Boot项目中,不需要额外配置

则在项目的根包下创建web.JsonResult类,在类中声明JSON结果中对应的属性:

package cn.tedu.csmall.product.web;

import lombok.Data;

@Data
public class JsonResult {

    private Integer state;
    private String message;

    public static JsonResult ok() {
        JsonResult jsonResult = new JsonResult();
        jsonResult.state = ServiceCode.OK;
        return jsonResult;
    }

}

然后,调整控制器中处理请求的方法的返回结果:

@ApiOperation("添加相册")
@PostMapping("/add-new")
public JsonResult addNew(AlbumAddNewDTO albumAddNewDTO) {
    albumService.addNew(albumAddNewDTO);
    return JsonResult.ok();
}
if (response.data.state == 1) {
    // 成功
} else if (response.data.state == 2) {
    // 失败:名称被占用
    alert(response.data.message);
}
    login(){
        axios.post("/login",v.user).then(function (response) {
            if (response.data==1){
                location.href="/admin.html"; //跳转到后台管理页面
            }else if(response.data==2){
                v.\$message.error("用户名不存在!");
            }else{
                v.\$message.error("密码错误!");
            }
        })
    }

3. 使用枚举优化代码

JsonResult中设计了Integer state属性,用于表示“业务状态码”,由于此值是可以由客户端和服务器端协商的值,所以,值的大小不一定是固定的,例如“成功”,可以使用1表示,也可以使用200表示,只要协商一致即可,所以,在应用时,不应该直接将数值常量赋值到state属性上,否则,代码的可读性较差!

**反例:**jsonResult.state = 200;

应该将数值声明为常量来使用,以增加代码的可读性!

**正例:**jsonResult.state = ServiceCode.OK;

在设计方法时,如果使用Integer state作为参数,方法的调用者仍可能不使用声明的常量,而是直接传入某个未协商的直接常量值,例如,当设计了fail()方法时:

public static JsonResult fail(Integer state, String message) { 
    // ... 
}

则可能调用时传入错误的值:

JsonResult.fail(99999, e.getMessage());

由于state对应的值是相对有限的,是可以穷举的,则可以使用枚举来解决问题!

package cn.tedu.csmall.product.web;

public enum ServiceCode {

    OK(200),
    ERR_NOT_FOUND(404),
    ERR_CONFLICT(409);

    private Integer value;

    ServiceCode(Integer value) {
        this.value = value;
    }

    public Integer getValue() {
        return value;
    }
}

如果将方法的参数设计为以上枚举类型,则方法的调用者只能传入以上列举的3个值中的某1个!例如将方法调整为:

public static JsonResult fail(ServiceCode serviceCode, String message) { 
    // ... 
}

调用时则是:

JsonResult.fail(ServiceCode.ERR_CONFLICT, e.getMessage());

个人主页:居然天上楼

感谢你这么可爱帅气还这么热爱学习~~

人生海海,山山而川

你的点赞👍 收藏⭐ 留言📝 加关注✅

是对我最大的支持与鞭策

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

居然天上楼

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

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

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

打赏作者

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

抵扣说明:

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

余额充值