微信使用的签名算法应用到接口认证

1、签名算法

(签名校验工具)

签名生成的通用步骤如下:

第一步,设所有发送或者接收到的数据为集合M,将集合M内非空参数值的参数按照参数名ASCII码从小到大排序(字典序),使用URL键值对的格式(即key1=value1&key2=value2…)拼接成字符串stringA。

特别注意以下重要规则:

  1. ◆ 参数名ASCII码从小到大排序(字典序);
  2. ◆ 如果参数的值为空不参与签名;
  3. ◆ 参数名区分大小写;
  4. ◆ 验证调用返回或微信主动通知签名时,传送的sign参数不参与签名,将生成的签名与该sign值作校验。
  5. ◆ 微信接口可能增加字段,验证签名时必须支持增加的扩展字段

第二步,在stringA最后拼接上key得到stringSignTemp字符串,并对stringSignTemp进行MD5运算,再将得到的字符串所有字符转换为大写,得到sign值signValue。

◆ key设置路径:微信商户平台(pay.weixin.qq.com)-->账户设置-->API安全-->密钥设置

举例:

假设传送的参数如下:

appid: wxd930ea5d5a258f4f

mch_id: 10000100

device_info: 1000

body: test

nonce_str: ibuaiVcKdpRxkhJA

第一步:对参数按照key=value的格式,并按照参数名ASCII字典序排序如下:

stringA="appid=wxd930ea5d5a258f4f&body=test&device_info=1000&mch_id=10000100&nonce_str=ibuaiVcKdpRxkhJA";

第二步:拼接API密钥:

stringSignTemp=stringA+"&key=192006250b4c09247ec02edce69f6a2d" //注:key为商户平台设置的密钥key

sign=MD5(stringSignTemp).toUpperCase()="9A0A8659F005D6984697E2CA0A9CF3B7" //注:MD5签名方式

sign=hash_hmac("sha256",stringSignTemp,key).toUpperCase()="6A9AE1657590FD6257D693A078E1C3E4BB6BA4DC30B23E0EE2496E54170DACD6" //注:HMAC-SHA256签名方式











php代码如下:

/**
 * 校验签名
 *
 */
protected function checkSign($param)
{
    //判断token是否为空
    if (isset($param['sign']) && empty($param['sign'])) {
        return false;
    }
    //赋值
    $sign = $param['sign'];
    unset($param['sign']);

    //验证签名结果
    $sign1 = $this->getSign($param);
    $this->writeLogs(json_encode($param).'-----'.$sign.'----'.$sign1);
    return $sign === $sign1;
}

/**
 * 生成签名
 */
protected function getSign($param)
{
    $sign_string = $this->getParamToString($param);
    return strtoupper(md5($sign_string . '&key='.$this->getAppSecret($param['app_key'])));
}

/**
 * 获取字符串
 */
private function getParamToString($params)
{
    $param_to_string = '';
    if (null === $params || '' === $params) {
        return $param_to_string;
    }
    if (is_array($params)) {
        //过滤空数组
        $params = array_filter($params);
        ksort($params);
        foreach ($params as $param_k => $param_v) {
            $param_to_string .= '&'. (string)$param_k .'='. $this->getParamToString($param_v);
        }
        $param_to_string = trim($param_to_string, '&');
    } else {
        $param_to_string .= (string)$params;
    }
    return $param_to_string;
}

/**
 * 获取app_secret
 */
private function getAppSecret($app_key) {

    if(!$app_key){
        return;
    }
    //查询数据库取出 appsecret
 
    return $appinfo['appsecret'];
}








  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值