通用结果类

今天给大家介绍一个我们Java前后端开发项目时常常使用的一个通用结果类

实现代码如下:

/**
 * 通用返回结果,服务端响应的数据最终都会封装成此对象
 * @param <T>
 */
@Data
public class R<T> {
    private Integer code;       //编码:1成功,0和其它数字为失败
    private String msg;         //错误信息
    private T data;             //数据
    private Map map = new HashMap();   //动态数据

    public static <T> R<T> success(T object) {
        R<T> r = new R<T>();
        r.data = object;
        r.code = 1;
        return r;
    }
    public static <T> R<T> error(String msg) {
        R r = new R();
        r.msg = msg;
        r.code = 0;
        return r;
    }
    public R<T> add(String key, Object value) {
        this.map.put(key, value);
        return this;
    }
}

1.解析此类

code: 实际上就是和前端约定好的状态码。

常常200表示成功 400表示执行失败。这里使用1成功,0和其它数字为失败。

例如在success() 中设置code = 1,error()则code = 0

msg:错误信息

在使用error函数中常常设置错误信息返回给前端

data:访问成功时,返回的数据信息。使用了泛型可以根据不同情况,返回不同类型的数据。

在访问成功又不需要返回数据的情况可以将T设置为String类型,然后用作返回访问成功提示信息。

map:动态向结果集中填充一些额外的数据

例如:R.success().add(key,value)函数向其中填充额外数据。

static <T> R<T> success(T object): 静态方法,用于创建R类的实体类对象

R.success(返回的数据对象) 即可返回携带返回数据 设置好状态码的R对象。通过springMVC中的@ResponseBody注解将返回的R对象转化为json类型数据

同理:

static <T> R<T> error(String msg): 静态方法,用于创建R类的实体类对象

R.error(返回的错误信息) 即可返回携带提示信息 设置好状态码的R对象。

add():用于向结果集中添加额外的动态信息。

2.使用实例:

下面是我写登录退出时的使用情景:

@Slf4j
@RestController
@RequestMapping("/employee")
public class EmployeeController {

    @Autowired
    private EmployeeService employeeService;

    @PostMapping("/login")
    public R<Employee> login(HttpServletRequest request, @RequestBody Employee employee){

        // 1.将页面提交的密码password进行md5加密处理
        String password = employee.getPassword();
        password = DigestUtils.md5DigestAsHex(password.getBytes());

        // 2.根据页面提交的username查找数据库
        LambdaQueryWrapper<Employee> queryWrapper = new LambdaQueryWrapper<>();
        queryWrapper.eq(Employee::getUsername,employee.getUsername());
        Employee emp = employeeService.getOne(queryWrapper);
        // 3.如果没有查询到则返回登录失败结果
        if (emp == null){
            return R.error("该用户不存在!");
        }
        // 4.密码对比 不一致则登陆失败
        if (!emp.getPassword().equals(password)){
            return R.error("密码输入有误!");
        }
        // 5.查看员工状态 若已禁用 则返回用户已被禁用
        if (emp.getStatus() == 0){
            return R.error("您的账户已被冻结!");
        }
        // 6.登陆成功,将员工id存入Session并返回登陆成功结果
        request.getSession().setAttribute("employee",emp.getId());
        return R.success(emp);
    }
    @PostMapping("/logout")
    public R<String> logout(HttpServletRequest request){
        request.getSession().removeAttribute("employee");
        return R.success("退出成功!");
    }
}

其中:

// 返回访问错误信息
return R.error("密码输入有误!");
// 返回访问成功 并将登陆成功的成员信息返回到结果集中
return R.success(emp);  
//添加额外动态信息的结果集 
return R.success(emp).add("info","登陆成功!");  

  • 9
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
Oracle PHP统一连接类是一种用于在PHP中连接和操作Oracle数据库的通用工具类。通过这个连接类,我们可以方便地创建连接,执行SQL语句和获取结果集。 首先,我们可以使用该连接类来创建一个数据库连接。在创建连接时,我们需要提供数据库的主机名、端口号、用户名、密码以及要连接的数据库名称。连接类可以根据提供的信息创建一个有效的连接,并返回一个连接对象供我们后续使用。 一旦连接建立,我们就可以使用连接类执行各种SQL语句。连接类封装了各种常见的数据库操作方法,如执行查询语句、插入、更新和删除数据等。我们只需要调用相应的方法,并传递相应的SQL语句和参数,就可以执行相应的操作了。 当执行查询操作时,连接类还可以帮助我们获取查询结果集。我们可以使用连接类提供的方法来遍历结果集中的每条记录,并获取其中的字段值。 除了执行SQL语句之外,连接类还提供了其他功能,如事务处理和错误处理。我们可以使用连接类提供的方法来开始、提交或回滚一个事务。同时,连接类还可以捕获并处理数据库操作中可能出现的错误,以保证代码的健壮性。 总之,Oracle PHP统一连接类是一种方便易用的工具,可以帮助我们在PHP中连接和操作Oracle数据库。它提供了各种方法来执行SQL语句、获取结果集,并支持事务处理和错误处理等功能。使用该连接类,我们可以更加高效地开发PHP与Oracle数据库相关的应用程序。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值