• php理解非对称SSL加密解密、验证及签名


        加密方式分为对称加密和非对称加密,对称加密只使用一个秘钥,加密和解密都使用该秘钥;非对称加密则使用一对秘钥,使用公钥加密,私钥解密。
        需要通过原生的openssl_public_encrypt加密,openssl_private_decrypt解密
        公钥和私钥都可以用来加密数据,相反用另一个解开.
    
        (1)公钥加密数据,然后私钥解密的情况被称为加密解密.
        例如:
        Tskey表示Tom的私钥,Tpkey表示Tom的公钥
        Bskey表示Bob的私钥,Bpkey表示Bob的公钥    
      Tom给Bob发消息:(用对方的公钥加密,用自己的私钥解密)这中行为加密和解密
    . 加密结果 = RsaEncrypt(消息内容,Bpkey); Bob收到了Tom发送的加密后的数据,进行解密 消息内容 = RsaDecrypt(加密结果,Bskey); (2)私钥加密数据,公钥解密一般被称为签名和验证签名. 例如: Tskey表示Tom的私钥,Tpkey表示Tom的公钥 Bskey表示Bob的私钥,Bpkey表示Bob的公钥 Tom给Bob发信: (用自己的私钥进行签名,用对方的公钥进行验证)这种行为签名和验证签名. 数字签名 = RsaSign(信件内容,Tskey); Bob收到Tom的来信,使用Tom的公钥,验证数字签名 验证结果 = RsaVerify(信件内容,数字签名,Tpkey); 在PHP还有两种常用的数字签名分别是sha1和md5. sha1通常是对一段内容或者一个文件进行签名,以判断信息在传输的过程中没有被修改过. md5则常用在登录验证,将签名的结果保存到数据库中,每次登录进行签名的验证. 总结:在公钥密码体制中,公钥对别人有用,私钥对自己有用

      /**
      * RSA验证签名
      * @param string $data 待签名数据
      * @param string $sign 需要验签的签名
      * @param string $publicKey App公钥, PEM格式
      * 验签公钥,摘要算法为MD5
      * @return bool 验签是否通过 bool值
      */
      public function verifySign($data, $sign,$publickey)
      {
        //获取公钥

       $publicKey = file_get_contents($publickey);
      //转换为openssl格式密钥
       $res = openssl_get_publickey($publicKey);
      //调用openssl内置方法验签,返回bool值
       $result = (bool)openssl_verify($data, base64_decode($sign), $res, OPENSSL_ALGO_MD5);
      //释放资源
       openssl_free_key($res);
      //返回资源是否成功
       return $result;
      }
     
  • 相关阅读:
    老陌与博客
    有关模式窗体和无(非)模式窗体的区别
    10月9日至10月22日备忘录
    9月4日至9月10日备忘录
    VS2015 远程调试:Remote Debugger
    8月28日至9月3日备忘录
    8月21日至8月27日技术积累
    用函数方法实现迭代器
    python中eval, exec, execfile,和compile(转载)
    dev 中的GridControl中的行实现选择的功能实现
  • 原文地址:https://www.cnblogs.com/cxx8181602/p/8466395.html
Copyright © 2020-2023  润新知