JsonCast.php 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. <?php
  2. namespace App\Module\GameItems\Casts;
  3. use Illuminate\Contracts\Database\Eloquent\CastsAttributes;
  4. use Illuminate\Database\Eloquent\Model;
  5. /**
  6. * JSON类型转换器
  7. *
  8. * 通用的JSON类型转换器,用于将数据库中存储的JSON字符串转换为PHP数组,以及将PHP数组转换回JSON字符串。
  9. * 该类提供了基础的JSON序列化和反序列化功能,可用于处理各种JSON格式的数据。
  10. * 包含了对空值、无效JSON的处理,以及对中文等Unicode字符的支持。
  11. */
  12. class JsonCast implements CastsAttributes
  13. {
  14. /**
  15. * 将取出的数据转换为对应的类型
  16. *
  17. * @param Model $model
  18. * @param string $key
  19. * @param mixed $value
  20. * @param array $attributes
  21. * @return array|null
  22. */
  23. public function get($model, string $key, $value, array $attributes)
  24. {
  25. if (is_null($value)) {
  26. return [];
  27. }
  28. $decoded = json_decode($value, true);
  29. return is_array($decoded) ? $decoded : [];
  30. }
  31. /**
  32. * 将给定的值转换为存储格式
  33. *
  34. * @param Model $model
  35. * @param string $key
  36. * @param mixed $value
  37. * @param array $attributes
  38. * @return string|null
  39. */
  40. public function set($model, string $key, $value, array $attributes)
  41. {
  42. if (is_null($value)) {
  43. return null;
  44. }
  45. if (is_array($value) || is_object($value)) {
  46. return json_encode($value, JSON_UNESCAPED_UNICODE);
  47. }
  48. if (is_string($value) && $this->isJson($value)) {
  49. return $value;
  50. }
  51. return json_encode([], JSON_UNESCAPED_UNICODE);
  52. }
  53. /**
  54. * 判断字符串是否为有效的JSON
  55. *
  56. * @param string $value
  57. * @return bool
  58. */
  59. protected function isJson($value)
  60. {
  61. if (!is_string($value)) {
  62. return false;
  63. }
  64. json_decode($value);
  65. return json_last_error() === JSON_ERROR_NONE;
  66. }
  67. }