Object_ext.php 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. <?php
  2. namespace loyalsoft;
  3. /**
  4. * 扩展对象的一些通用方法
  5. * 使用方法: $var = new XX($obj); ... 用完后注意进行回存.(相当于克隆一个原始对象,若需覆盖原始对象记得回存操作)
  6. * @version
  7. * 1.0.3 增加了Json()和MD5()方法,用于计算对象的摘要,方便与客户端或者存储端进行校验. --gwang 2022.5.31
  8. * 1.0.2 增加了LoadFrom()方法. --gwang 2020.4.24
  9. * 1.0.1 改名, PHP 7以后的语法中已经将Object作为关键字 --gwang 2017年8月2日
  10. * 1.0.0 Created at 2017-3-28. by --gwang
  11. * @author gwang (mail@wanggangzero.cn)
  12. * @copyright ? 2017-3-28, SJZ LoyalSoft Corporation & gwang. All rights reserved.
  13. */
  14. class Object_ext {
  15. /**
  16. * 默认构造函数,能够智能提取关联数组或者是object中的字段进行初始化.
  17. * Ps. 不会进行递归类型检查, php的serilize函数也没有附带字段的类型信息
  18. */
  19. function __construct($arg = null) {
  20. if (func_num_args() != 1 || is_null($arg)) { # 若参数为null,无特殊操作
  21. return;
  22. }
  23. $para = is_array($arg) ? $arg : (array) $arg; # 关联数组
  24. $vars = get_class_vars(get_class($this)); # 后期绑定,获得实例的实际类名称=>属性数组
  25. foreach ($vars as $name => $value) {
  26. $this->$name = isset($para[$name]) ? $para[$name] : $value; # 取参数中的或者默认值
  27. }
  28. }
  29. /**
  30. * 从对象加载数据(赋值给自己的字段)
  31. * @param array/Object $obj
  32. */
  33. public function LoadFrom($obj) {
  34. if (func_num_args() != 1 || is_null($obj)) { # 防御: 参数数量不对
  35. die("too many args or arg obj was null!");
  36. }
  37. $para = is_array($obj) ? $obj : (array) $obj; # 转关联数组
  38. $vars = get_class_vars(get_class($this)); # 后期绑定,获得实例的实际类名称=>属性数组
  39. foreach ($vars as $name => $value) {
  40. if (isset($para[$name])) {
  41. $this->$name = $para[$name]; # 取参数中的或者默认值
  42. }
  43. }
  44. return $this;
  45. }
  46. public function __toString() { # 用json_encode覆盖下toString()方法
  47. return $this->toString();
  48. }
  49. /**
  50. * @return 将自身数据序列化为json串.
  51. */
  52. public function Json() {
  53. return JsonUtil::encode($this);
  54. }
  55. public function toString() { # 还没想好要不要留一个显式的toString()方法
  56. $str = $this->Json();
  57. return $str;
  58. }
  59. /**
  60. * @param bool $lower 是否返回小写字符串,默认值false, 返回大写字符串
  61. * @return string 计算自身数据序列化为json串后的MD5值(大写16进制)
  62. */
  63. public function MD5($lower = false) {
  64. $str = $this->Json();
  65. return $lower ? md5($str) : strtoupper(md5($str));
  66. }
  67. }