HuoApiV2.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. <?php
  2. /**
  3. * HuoApiV2.php UTF-8
  4. * 火速API 2.0 加解密
  5. *
  6. * @date : 2018/1/15 21:04
  7. *
  8. * @license 这不是一个自由软件,未经授权不许任何使用和传播。
  9. * @author : wuyonghong <wyh@huosdk.com>
  10. * @version : HUOSDK 8.0
  11. */
  12. namespace huoCheck;
  13. class HuoApiV2 {
  14. private $key = '';
  15. /**
  16. * 构造函数
  17. *
  18. * @param string $key 秘钥
  19. */
  20. function __construct($key = '') {
  21. $this->key = $key;
  22. }
  23. /**
  24. * 设置秘钥
  25. *
  26. * @param string $key 秘钥
  27. */
  28. public function setKey($key) {
  29. $this->key = $key;
  30. }
  31. /**
  32. * 参数校验结果
  33. *
  34. * @param string $script_name 调用的API方法,
  35. * @param array $params 调用API时带的参数
  36. * @param string $method 请求方法 post / get
  37. *
  38. * @return bool 结果数组
  39. */
  40. public function check($script_name, $params, $method = 'post') {
  41. return self::verifySign($method, $script_name, $params, $this->key, get_val($params, 'sign'));
  42. }
  43. /**
  44. * 校验签名是否正确
  45. *
  46. * @param $method
  47. * @param $url_path
  48. * @param $params
  49. * @param $secret
  50. * @param $sign
  51. *
  52. * @return bool
  53. */
  54. static public function verifySign($method, $url_path, $params, $secret, $sign) {
  55. unset($params['sign']);
  56. unset($params['version']);
  57. unset($params['s']);
  58. // 再计算签名
  59. $_check_sign = self::makeSign($method, $url_path, $params, $secret);
  60. //Log::error('---------服务器签名------'.$_check_sign.'-----提交签名----'.$sign.'------');
  61. return strtoupper($_check_sign) == strtoupper($sign);
  62. }
  63. /**
  64. * 生成签名
  65. *
  66. * @param string $method 请求方法 "get" or "post"
  67. * @param string $url_path
  68. * @param array $params 表单参数
  69. * @param string $secret 密钥
  70. *
  71. * @return string
  72. */
  73. static public function makeSign($method, $url_path, $params, $secret) {
  74. $mk = self::makeSource($method, $url_path, $params);
  75. $my_sign = md5($mk.'&'.$secret);
  76. //Log::error('---------我是签名原串------'.$mk.'&'.$secret.'-----我是签名----'.$my_sign.'------');
  77. return $my_sign;
  78. }
  79. static private function makeSource($method, $url_path, $params) {
  80. $_params = $params;
  81. $_str = strtoupper($method).'&'.rawurlencode($url_path).'&';
  82. ksort($_params);
  83. reset($_params);
  84. $query_string = array();
  85. foreach ($_params as $key => $val) {
  86. if (is_array($val)) {
  87. ksort($val);
  88. reset($val);
  89. foreach ($val as $_k2 => $_v2) {
  90. array_push($query_string, $key.'-'.$_k2.'='.$_v2);
  91. }
  92. } else {
  93. array_push($query_string, $key.'='.$val);
  94. }
  95. }
  96. $query_string = join('&', $query_string);
  97. return $_str.str_replace('~', '%7E', rawurlencode($query_string));
  98. }
  99. }