微信三方授权登录,解密用户手机号。php解密方法

官方的方法有c++ php node  python https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/signature.html

php解密文件 3个文件

demo.php 

decryptData($encryptedData, $iv, $data );if ($errCode == 0) {print($data . "\n");
} else {print($errCode . "\n");
}

errorCode.php 

*    
  • -41001: encodingAesKey 非法
  • *
  • -41003: aes 解密失败
  • *
  • -41004: 解密后得到的buffer非法
  • *
  • -41005: base64加密失败
  • *
  • -41016: base64解密失败
  • * */ class ErrorCode {public static $OK = 0;public static $IllegalAesKey = -41001;public static $IllegalIv = -41002;public static $IllegalBuffer = -41003;public static $DecodeBase64Error = -41004; }?>

    wxBizDataCrypt.php

    sessionKey = $sessionKey;$this->appid = $appid;}/*** 检验数据的真实性,并且获取解密后的明文.* @param $encryptedData string 加密的用户数据* @param $iv string 与用户数据一同返回的初始向量* @param $data string 解密后的原文** @return int 成功0,失败返回对应的错误码*/public function decryptData( $encryptedData, $iv, &$data ){if (strlen($this->sessionKey) != 24) {return ErrorCode::$IllegalAesKey;}$aesKey=base64_decode($this->sessionKey);if (strlen($iv) != 24) {return ErrorCode::$IllegalIv;}$aesIV=base64_decode($iv);$aesCipher=base64_decode($encryptedData);$result=openssl_decrypt( $aesCipher, "AES-128-CBC", $aesKey, 1, $aesIV);$dataObj=json_decode( $result );if( $dataObj  == NULL ){return ErrorCode::$IllegalBuffer;}if( $dataObj->watermark->appid != $this->appid ){return ErrorCode::$IllegalBuffer;}$data = $result;return ErrorCode::$OK;}}

    说简单点替换4个参数 就可以

    1.appid 这个好找(小程序公众平台--开发设置)

    2.sessionKey 这个参数 的获取

     通过这个接口换取 https://api.weixin.qq.com/sns/jscode2session?appid=wx1e4785fa849e936c&secret=87d8d4e95b6c9237fd4d363ddfb82f4d&js_code=033JpREd0tlV3t1PiOCd0SxyEd0JpRE1&grant_type=authorization_code

    结果:{

    "session_key": "OaGZH0YKQlLI5bxs5H64tw==", 

    "openid": "oeXqH5DNXD5mEVZMc-U1r8LmaXDw"

    }

            参数 

           appid (小程序公众平台 --开发设置)    secret (小程序公众平台--开发设置)  grant_type(authorization_code)

          js_code通过调用login方法获得:

    wx.login({

    success: function(res) {

    console.log(res.code)//这个就是js_code(每次登陆不一样 5分钟失效)

    },

    3第三,四个参数encryptedData  iv 可以通过getPhoneNumber方法获得 

    官方:https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/getPhoneNumber.html

    
    
    Page({getPhoneNumber(e) {console.log(e.detail.errMsg)console.log(e.detail.iv)console.log(e.detail.encryptedData)}
    })

    遇到的问题:

    1,运行php报错 Call to undefined function openssl_decrypt()

    解决方案 :首先说我用的php环境是 phpstudy PHP7.1版本(最好是这个版本 我也不知道为什么)

    找到php.ini(对应你正在使用php版本)

    前面的引号去掉,安装ssl扩展

    解密成功


    本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

    相关文章

    立即
    投稿

    微信公众账号

    微信扫一扫加关注

    返回
    顶部