PHP技术SHA256WithRSA生成签名API代码

PHP技术SHA256WithRSA生成签名API代码。将筛选的参数按照第一个字符的键值 ASCII 码递增排序(字母升序排序),如果遇到相同字符则按照第二个字符的键值 ASCII 码递增排序,以此类推。

代码演示

//取出从api开始后面的方法
$path = parse_url('https://baidu.com:9443/api/pmss/doSendTransferMsg/v1',PHP_URL_PATH);

$params['app_id'] = 'appid12344567';
$params['msg_id'] = uniqid();
$params['fmt_type'] = 'json';
$params['charset'] = 'UTF-8';
$params['timestamp'] = date('Y-m-d H:i:s');
$strToSign = $this->buildOrderedSignStr($path, $params);
$signedStr = $this->sign($strToSign, 'SHA256WithRSA', $PRIVATE_KEY, 'UTF-8');
$params['sign'] = $signedStr;

//将筛选的参数按照第一个字符的键值 ASCII 码递增排序(字母升序排序),如果遇到相同字符则按照第二个字符的键值 ASCII 码递增排序,以此类推
//将排序后的参数与其对应值,组合成“参数=参数值”的格式,并且把这些参数用&字符连接起来,此时生成的字符串为待签名字符串
public function buildOrderedSignStr($path,$params){
        $isSorted = ksort ( $params );
        $comSignStr = $path . '?';

        $hasParam = false;
        foreach ( $params as $key => $value ) {
            if (null == $key || "" == $key || null == $value || "" == $value) {
            } else {
                if ($hasParam) {
                    $comSignStr = $comSignStr . '&';

                } else {
                    $hasParam = true;
                }

                $comSignStr = $comSignStr . $key . '=' . $value;
                // 	print_r($comSignStr);
                // print_r('<hr>');

            }
        }

        return $comSignStr;
    }

//选择签名方式
public function sign($strToSign, $signType, $privateKey){
	return $this->rsa($strToSign,$privateKey,$signType);
}

//开始签名
public function rsa($content,$privateKey,$algorithm){
        $signature = "";

        if( $algorithm == 'SHA1WithRSA'){
            openssl_sign($content,$signature,"-----BEGIN PRIVATE KEY-----\n".wordwrap($privateKey,64,"\n",true)."\n-----END PRIVATE KEY-----", OPENSSL_ALGO_SHA1);
        }elseif ($algorithm == 'SHA256WithRSA') {
            //  print_r(111);
            openssl_sign($content,$signature,"-----BEGIN PRIVATE KEY-----\n".wordwrap($privateKey,64,"\n",true)."\n-----END PRIVATE KEY-----",OPENSSL_ALGO_SHA256);
        }else{
            throw new Exception("Only support OPENSSL_ALGO_SHA1 or OPENSSL_ALGO_SHA256 algorithm signature!");
        }
        return base64_encode($signature);
    }
温馨提示:
1.本站大部分内容均收集于网络!若内容若侵犯到您的权益,请发送邮件至:duhaomu@163.com,我们将第一时间处理!
2.资源所需价格并非资源售卖价格,是收集、整理、编辑详情以及本站运营的适当补贴,并且本站不提供任何免费技术支持。
3.所有资源仅限于参考和学习,版权归原作者所有,更多请阅读网站声明

给TA赞赏
共{{data.count}}人
人已赞赏
编程技巧

PHP技术break和continue后面都是可以加层级的

2016-3-2 9:00:00

编程技巧

PHP技术PHP<5.3.2中没有提供ReflectionMethod::setAccessible怎么获取私有属性呢?

2016-3-4 9:00:00

0 条回复 A文章作者 M管理员
----《》
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索