colly_wyx
2018-05-18 50a53f7db63c5729b0ddbc93367117cf35ccf03c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
<?php
/**
 * PhalApi_Filter_SimpleMD5 简单的MD5拦截器
 *
 * - 签名的方案如下:
 *
 * + 1、排除签名参数(默认是sign)
 * + 2、将剩下的全部参数,按参数名字进行字典排序
 * + 3、将排序好的参数,全部用字符串拼接起来
 * + 4、进行md5运算
 *
 * 注意:无任何参数时,不作验签
 *
 * @package     PhalApi\Filter
 * @license     http://www.phalapi.net/license GPL 协议
 * @link        http://www.phalapi.net/
 * @author      dogstar <chanzonghuang@gmail.com> 2015-10-23
 */
 
class PhalApi_Filter_SimpleMD5 implements PhalApi_Filter {
 
    protected $signName;
 
    public function __construct($signName = 'sign') {
        $this->signName = $signName;
    }
 
    public function check() {
        $allParams = DI()->request->getAll();
        if (empty($allParams)) {
            return;
        }
 
        $sign = isset($allParams[$this->signName]) ? $allParams[$this->signName] : '';
        unset($allParams[$this->signName]);
 
        $expectSign = $this->encryptAppKey($allParams);
 
        if ($expectSign != $sign) {
            DI()->logger->debug('Wrong Sign', array('needSign' => $expectSign));
            throw new PhalApi_Exception_BadRequest(T('wrong sign'), 6);
        }
    }
 
    protected function encryptAppKey($params) {
        ksort($params);
 
        $paramsStrExceptSign = '';
        foreach ($params as $val) {
            $paramsStrExceptSign .= $val;
        }
 
        return md5($paramsStrExceptSign);
    }
}