当前位置: 首页 > news >正文

Laravel Trait 实现 统一JSON 响应格式

什么是 Trait ?

Trait 是 PHP 5.4 引入的一个代码复用机制,它解决了 PHP 单继承的限制问题。

1.Trait 基本概念

Trait 是一种代码复用机制,即可以理解为 可重用的方法集合

trait Loggable {public function log($message) {echo "Log: $message\n";}
}

2.Trait 的特点

  • 不是类:不能实例化

  • 不是接口:可以包含具体实现

  • 解决单继承限制:一个类可以使用多个 Trait,这是重点,因为PHP只能单继承,很好弥补了这一弱势。

  • 代码复用:可以理解为帮助方法,多个类使用,不用重复多次写

3.Trait的 使用 ,Use 即可

class User {use Loggable ;
}//laravel 常见的伪删除,等等
class User extends Model {use SoftDeletes; // 软删除功能
}

4.多个 Trait 使用


class MyClass {use TraitA, TraitB;
}

5.当多个 Trait 有同名方法时

trait A {public function conflict() { echo "A"; }
}
trait B {public function conflict() { echo "B"; }
}
class MyClass {use A, B {A::conflict insteadof B;  // 使用 A 的 conflict 方法B::conflict as conflictB; // 将 B 的 conflict 方法重命名}
}

6.Trait 与继承的优先级

方法解析优先级(从高到低):

  1. 当前类中的方法权重最高

  2. 其次是Trait 中的方法

  3. 最后继承的父类中的方法

Trait 还有一些其他的特性 等等,大家去看看语法。重点来了

统一JSON 响应类开放。

直接上源码:

<?php
namespace App\Http\Trait;use Illuminate\Http\JsonResponse;
use Illuminate\Support\Facades\Response;trait ResponseJson
{/*** 默认成功状态码*/protected int $successCode = 200;/*** 默认错误状态码*/protected int $errorCode = 101;/*** 返回成功 JSON 响应** @param string $message 成功消息* @param mixed $data 返回数据* @param array $headers 附加头信息* @param int $httpStatus HTTP 状态码* @return JsonResponse*/public function success(string $message,mixed  $data = [],array  $headers = [],int    $httpStatus = 200): JsonResponse{return Response::json(['code' => $this->successCode,'message' => $message,'data' => $data,], $httpStatus, $headers);}/*** 返回错误 JSON 响应** @param string $message 错误消息* @param int|null $code 业务错误码* @param mixed $data 附加数据* @param array $headers 附加头信息* @param int $httpStatus HTTP 状态码* @return JsonResponse*/public function error(string $message,int    $code = NULL,mixed  $data = [],array  $headers = [],int    $httpStatus = 400): JsonResponse{return Response::json(['code' => $code ?? $this->errorCode,'message' => $message,'data' => $data,], $httpStatus, $headers);}/*** 根据数据自动返回成功或错误响应** @param array $responseData 必须包含 code, message, data* @param array $headers 附加头信息* @return JsonResponse*/public function autoResponse(array $responseData, array $headers = []): JsonResponse{if(!isset($responseData['code'], $responseData['message'])){return $this->error('Invalid response format', 500, [], $headers, 500);}return $responseData['code'] === $this->successCode? $this->success($responseData['message'], $responseData['data'] ?? [], $headers): $this->error($responseData['message'], $responseData['code'], $responseData['data'] ?? [], $headers);}
}

1. Api接口直接使用

class TestController extends Controller
{use ResponseJson;public function index(){//return $this->success('success', [1, 2, 3]);return $this->error('error', 11, [1, 2, 3]);}
}

2.代码分析

  1. 封装了成功和错误和自定义的响应方法,success ,error,autoResponse
  2. 支持自定义 HTTP 状态码和 headers
  3. success ,error 保持一致的参数顺序 (消息 -> 数据/代码 -> headers -> HTTP状态码),使用的时候尽量减少干扰
  4. 区分业务编码 code 和 HTTP 状态码 httpStatus,一个是业务上的区分,一个是接口通信上的状态。
  5. 增强的 autoResponse 方法,处理自定义的相关情况
  6. 严格的参数类型声明和验证
  7. 灵活性、可维护性和类型安全性

http://www.mrgr.cn/news/96667.html

相关文章:

  • Spring-事务属性
  • Axure项目实战:智慧运输平台后台管理端-承运商管理(中继器筛选)
  • 博客学术汇测试报告
  • Android:Dialog的使用详解
  • ffmpeg滤镜使用
  • 音频进阶学习二十四——IIR滤波器设计方法
  • VUE3+Mapbox-GL 实现鼠标绘制矩形功能的详细代码和讲解
  • NVR接入录像回放平台EasyCVR视频融合平台城市/乡镇污水处理厂解决方案
  • 蓝桥杯专项复习——二分查找、二分答案
  • Laravel APP_KEY 生成方法
  • 力扣每日一题:2712——使所有字符相等的最小成本
  • 苍穹外卖项目结构
  • 网络架构搭建中的 QinQ 与端口安全策略
  • DAY 32 leetcode 242--哈希表.有效的字母异位词
  • Oracle数据库数据编程SQL<3.5 PL/SQL 存储过程(Procedure)>
  • 魔改chromium——基础环境搭建
  • Open GL ES ->GLSurfaceView在正交投影下的图片旋转、缩放、位移
  • OpenCV图像输入输出模块imgcodecs
  • 什么是 CSSD?
  • OCCT(2)Windows平台编译OCCT