php 身份认证(二要素)API 校验

本文介绍了阿里云身份认证服务接口的调用过程。包括服务地址、购买方式,详细说明了请求接口所需参数,如主账号Id、identifyNum、userName、verifyKey、appcode等的获取方法。还讲述了调用接口时需请求两个接口并授权,遇到问题找客服解决,最终完成调试。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

服务地址:

https://market.aliyun.com/products/57000002/cmapi029454.html?spm%3D5176.10695662.1194487.1.fa096c19PeVIb4#sku=yuncode2345400002

购买

        

        

请求示例:没有别的sdk

        

开始弄参数

        

首先就是主账号Id

登录上阿里云后 访问下面的地址 红框内就是

https://account.console.aliyun.com/?spm=5176.730006-56764045-56830014-56844019-cmapi030971/A.1146454.305.4ee9acfeVE1WBr#/secure

        

customerID 可以随便写 不是必须参数 略过

identifyNum 和  userName 是请求接口的时候必须的,来源于用户所填的内容

verifyKey 这个是填写你要调用的网站 才能生成的 也就是说你必须要有网站域名,

如果你有域名备案通过,并且在有效期,那很简单

访问下面地址

https://yundun.console.aliyun.com/?spm=5176.2020520001.aliyun_sidebar.59.68874bd3ZkcrH4&p=saf#/config

        

然后新增verifyKey

       

完成后,会跳转

        

还有appcode

如果你已经购买了 这个服务接口 打开下面地址

        

这样接口所需参数都已经完成了!

那然后是不是直接可以请求了,

然鹅,看产品说明,感觉事情并没有那么简单

        

我自己试了试

发现请求完第一个接口以后,返回了一个URL地址 ,

还需要请求第二个接口授权后才会返回结果

        

返回结果

        

再去请求其中返回的地址 结果

        

点击同意授权后,页面空白,没有任何输出

不行,还得找客服 注意找身份认证一的客服

        

        

        

再去请求接口

发现这次直接返回验证结果了 这也就是自己授权

        

填正确的 返回结果

{"code":200,"value":{"verifyUrl":"","bizCode":0,"message":"success"},"message":"success"}

200 表示验证通过

填错误的返回结果

{"code":404,"message":"check.param.error:参数非法"}

这次没问题了

也就是 verifyKey需要客服确认,如果更换了,还需要客服确认!就这一点比较麻烦!

调试告一段落,我把请求示例自己改了一下 ,需要的拿走,不用谢!

<?php


/**
 * 阿里 云盾身份认证(二要素)
 * Class AliIdentityAuth
 * @package App\Extend
 */
class AliIdentityAuth
{
    protected $userId = 'xxxxxx';//购买服务的主账号ID

    protected $customerID = 12;//客户自己的userid,只做透传

    protected $verifyKey = 'xxxxxx';//新增使用域名生成的verifyKey(重新生成后需与客服确认)

    protected $appCode = 'xxxxxxxx';//购买接口生成的code

    protected $host = "https://safrvcert.market.alicloudapi.com";//请求阿里云接口域名

    protected $path = "/safrv_2meta_id_name/";//请求接口路径


    /**
     * 执行实名验证
     * @param $name:真实姓名
     * @param $id_card:身份证号
     * @return bool
     */
    public function conductAuth($name, $id_card)
    {
        if (empty($name) || empty($id_card)) return false;

        $host = $this->host;
        $appCode = $this->appCode;

        $querys = "__userId=" . $this->userId . "&customerID=" . $this->customerID . "&identifyNum=" . $id_card . "&userName=" . $name . "&verifyKey=" . $this->verifyKey;
        $url = $host . $this->path . "?" . $querys;

        $json = $this->curlRequest($host, $url, $appCode, "GET");
        $return = json_decode($json, true);
        if($return['code'] != 200) {
            return false;
        }
        return true;
    }


    /**
     * curl请求接口
     * @param $host
     * @param $url
     * @param $appCode
     * @param $method
     * @return bool|string
     */
    public function curlRequest($host, $url, $appCode, $method)
    {
        $headers = array();
        array_push($headers, "Authorization:APPCODE " . $appCode);

        $curl = curl_init();
        curl_setopt($curl, CURLOPT_CUSTOMREQUEST, $method);
        curl_setopt($curl, CURLOPT_URL, $url);
        curl_setopt($curl, CURLOPT_HTTPHEADER, $headers);
        curl_setopt($curl, CURLOPT_FAILONERROR, false);
        curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
        curl_setopt($curl, CURLOPT_HEADER, false);
        if (1 == strpos("$" . $host, "https://")) {
            curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
            curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
        }
        return curl_exec($curl);
    }

}

### 关于PHP实现富友支付扫码API #### PHP集成富友支付扫码API的关键要素 在开发基于PHP的富友支付扫码API时,需关注以下几个核心部分: 1. **基础配置** 开发者需要先完成基本的环境搭建以及参数设置。这通常包括商户号、密钥以及其他必要的认证信息[^2]。 2. **签名算法** 富友支付接口要求开发者按照特定规则生成签名字符串,用于验证请求的真实性。常见的做法是通过MD5或RSA加密方式来构建签名[^3]。 3. **HTTP通信协议** 使用标准POST方法向富友服务器发送数据包,并接收返回的结果。此过程可能涉及JSON解析与XML处理技术[^4]。 4. **错误处理机制** 设计合理的异常捕获逻辑以应对可能出现的各种网络状况及业务场景下的失败情况[^5]。 下面提供一段简单的示例代码展示如何利用PHP发起一次典型的维码付款请求: ```php <?php // 定义变量存储必要信息 $merchantNo = 'your_merchant_no'; // 商户编号 $key = 'your_security_key'; // 安全秘钥 $data = array( 'service' => 'create_direct_pay_by_user', 'partner' => $merchantNo, ... ); // 对数组中的键值对按字典序排列并拼接成urlquery形式 ksort($data); $stringToBeSigned = ''; foreach ($data as $k=>$v){ if('sign' != $k && '' !== trim($v)){ $stringToBeSigned .= "$k=$v&"; } } $stringToBeSigned = rtrim($stringToBeSigned, '&'); // 添加安全校验码计算后的最终提交串 $signStr = strtoupper(md5($stringToBeSigned . "&key=" .$key)); $data['sign'] = $signStr; // 发起http post 请求至网关地址 $url = 'https://example.fuiou.com/gateway.do'; $response = httpPostCurl($url,$data); function httpPostCurl($url,$fields=array()){ $ch = curl_init(); curl_setopt($ch,CURLOPT_URL,$url); curl_setopt($ch,CURLOPT_POST,true); curl_setopt($ch,CURLOPT_POSTFIELDS,$fields); curl_setopt($ch,CURLOPT_RETURNTRANSFER,true); $result=curl_exec($ch); curl_close($ch); return $result; } echo $response; // 输出响应结果供调试分析使用 ?> ``` 以上脚本仅为示意性质,在实际项目应用前还需参照具体版本的官方手册做适当调整优化[^6]。 #### 注意事项 - 确保所有传输的数据都经过严格的安全防护措施保护。 - 测试阶段建议采用沙箱模式运行程序以便发现问题及时修正。 - 生产环境中务必启用HTTPS连接保障客户隐私不受侵犯。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

JSON_L

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值