谈谈php对接芝麻信用踩的坑


Posted in PHP onDecember 01, 2016

由于项目需要,接入芝麻信用对用户进行认证,打开芝麻信用官方网站( https://b.zmxy.com.cn/index.htm)查看官方demo,在文档中看到如图

谈谈php对接芝麻信用踩的坑

瞬间觉得这个官方demo的垃圾了。

在其中有需要注意如下:

1.本地生成密钥,可以按照提示进行生成

2.在“商家管理”中创建应用,通过第一步生成的密钥得到芝麻信用给的公钥,这就得到了加密用的密钥

注意:芝麻信用给的公钥只能复制,但是复制出来的格式是不对的,需要咱们手工处理每行64,和咱们生成的密钥格式一致,不然加密和解密将不能进行;

3.需要传递的参数根据文档可以得出,上图只是生成了一个参数,需要处理生成对应文档的数据返回;

直接上代码:

<?php 
  include('/ZmopClientphp'); 
  include('/ZhimaAuthInfoAuthorizeRequestphp'); 
  class TestAuthFreeze { 
    //芝麻信用网关地址 
    public $gatewayUrl = "https://zmopenapizmxycomcn/openapido"; 
    //商户公钥文件 
    //芝麻公钥文件 
    public $privateKeyFile = "path/rsa_private_keypem"; 
    public $zmPublicKeyFile = "path/zima_public_keypem"; 
 
    //数据编码格式 
    public $charset = "UTF-8"; 
    //芝麻分配给商户的appId 
    public $appId = "1000003"; 
 
 
  //生成移动端SDK 集成需要的sign 参数 ,并进行urlEncode 
  public function generateSign($certNo,$name,$certType='IDENTITY_CARD'){ 
    $client = new ZmopClient($this->gatewayUrl, $this->appId, $this->charset, $this->privateKeyFile,$this->zmPublicKeyFile); 
    $request = new ZhimaAuthInfoAuthorizeRequest(); 
    $request->setScene("test"); 
    // 授权来源渠道设置为appsdk 
    $request->setChannel("appsdk"); 
    // 授权类型设置为2标识为证件号授权见“章节4中的业务入参说明identity_type” 
    $request->setIdentityType("2"); 
    // 构造授权业务入参证件号,姓名,证件类型;“章节4中的业务入参说明identity_param” 
    $request->setIdentityParam("{\"certNo\":\"$certNo\",\"certType\":\"IDENTITY_CARD\", \"name\":\"$name\"}"); 
    // 构造业务入参扩展参数“章节4中的业务入参说明biz_params” 
    $request->setBizParams("{\"auth_code\":\"M_APPSDK\"}"); 
     
    $params = $client->generateEncryptedParamWithUrlEncode($request); 
    $sign = $client->generateSignWithUrlEncode($request); 
 
    $data['gatewayUrl'] = $this->gatewayUrl; 
    $data['appId'] = $this->appId; 
    $data['charset'] = $this->charset; 
    $data['params']=$params; 
    $data['sign'] = $sign; 
    return $data; 
  } 

  // 解密 
  public function zhimacallback($params){ 
    $this->privateKeyFile= "path/rsa_private_keypem"; 
    $client = new ZmopClient($this->gatewayUrl, $this->appId, $this->charset, $this->privateKeyFile,$this->zmPublicKeyFile); 
    $result=$client->generateSignCallBack($params,$this->privateKeyFile); 
    return $result; 
  } 
}  
?>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
php5.2.0内存管理改进
Jan 22 PHP
PHP4和PHP5性能测试和对比 测试代码与环境
Aug 17 PHP
php&amp;mysql 日期操作小记
Feb 27 PHP
php版小黄鸡simsimi聊天机器人接口分享
Jan 26 PHP
php中convert_uuencode()与convert_uuencode函数用法实例
Nov 22 PHP
PHP中SimpleXML函数用法分析
Nov 26 PHP
smarty内置函数foreach用法实例
Jan 22 PHP
浅析THINKPHP的addAll支持的最大数据量
Feb 03 PHP
php生成二维码
Aug 10 PHP
PHP+MySQL实现的简单投票系统实例
Feb 24 PHP
php实现用户登陆简单实例
Apr 04 PHP
PHP魔术方法之__call与__callStatic使用方法
Jul 23 PHP
PHP自定义函数获取汉字首字母的方法
Dec 01 #PHP
phpmailer绑定邮箱的实现方法
Dec 01 #PHP
thinkPHP实现多字段模糊匹配查询的方法
Dec 01 #PHP
thinkPHP商城公告功能开发问题分析
Dec 01 #PHP
thinkPHP订单数字提醒功能的实现方法
Dec 01 #PHP
PHP 芝麻信用接入的注意事项
Dec 01 #PHP
PHP中静态变量的使用方法实例分析
Dec 01 #PHP
You might like
通过对php一些服务器端特性的配置加强php的安全
2006/10/09 PHP
第二章 PHP入门基础之php代码写法
2011/12/30 PHP
php初始化对象和析构函数的简单实例
2014/03/11 PHP
PHP中的gzcompress、gzdeflate、gzencode函数详解
2014/07/29 PHP
php获得文件夹下所有文件的递归算法的简单实例
2016/11/01 PHP
ThinkPHP3.2框架自定义配置和加载用法示例
2018/06/14 PHP
JavaScript 闭包在封装函数时的简单分析
2009/11/28 Javascript
javascript 模拟点击广告
2010/01/02 Javascript
javascript 程序库的比较(一)之DOM功能
2010/04/07 Javascript
js将控件隐藏的方法及display属性介绍
2013/07/04 Javascript
javascript操作表格排序实例分析
2015/05/06 Javascript
详解vue-cli中配置sass
2017/06/21 Javascript
jQuery选择器之表单元素选择器详解
2017/09/19 jQuery
在vue项目中,使用axios跨域处理
2018/03/07 Javascript
react项目如何使用iconfont的方法步骤
2019/03/13 Javascript
详解在React项目中安装并使用Less(用法总结)
2019/03/18 Javascript
VUE+elementui组件在table-cell单元格中绘制微型echarts图
2020/04/20 Javascript
Element-ui el-tree新增和删除节点后如何刷新tree的实例
2020/08/31 Javascript
vuex中遇到的坑,vuex数据改变,组件中页面不渲染操作
2020/11/16 Javascript
vue 在单页面应用里使用二级套嵌路由
2020/12/19 Vue.js
Django中实现一个高性能计数器(Counter)实例
2014/07/09 Python
Python多进程并发(multiprocessing)用法实例详解
2015/06/02 Python
python利用Tesseract识别验证码的方法示例
2019/01/21 Python
Python八皇后问题解答过程详解
2019/07/29 Python
python3.9和pycharm的安装教程并创建简单项目的步骤
2021/02/03 Python
使用CSS3实现SVG路径描边动画效果入门教程
2019/10/21 HTML / CSS
html5使用window.postMessage进行跨域实现数据交互的一次实战
2021/02/24 HTML / CSS
医药大学生求职简历的自我评价
2013/10/17 职场文书
研究生自我鉴定范文
2013/10/30 职场文书
网络信息管理员岗位职责
2014/01/05 职场文书
2015国庆节宣传语
2015/07/14 职场文书
幼儿园教师教学反思
2016/03/02 职场文书
Vue通过懒加载提升页面响应速度
2021/05/10 Vue.js
浅谈Laravel中使用Slack进行异常通知
2021/05/29 PHP
Python爬虫基础之初次使用scrapy爬虫实例
2021/06/26 Python
Python使用psutil库对系统数据进行采集监控的方法
2021/08/23 Python