Heim  >  Artikel  >  Backend-Entwicklung  >  Beispiel für die gemeinsame Nutzung des RSA2-Signaturalgorithmus in PHP

Beispiel für die gemeinsame Nutzung des RSA2-Signaturalgorithmus in PHP

黄舟
黄舟Original
2017-09-08 09:39:231990Durchsuche

RSA2 basiert auf dem ursprünglichen SHA1WithRSA-Signaturalgorithmus und fügt einen neuen Signaturalgorithmus hinzu, der SHA256WithRSA unterstützt.

Dieser Algorithmus verfügt in Bezug auf den Digest-Algorithmus über stärkere Sicherheitsfunktionen als SHA1WithRSA.

Der SHA1WithRSA-Signaturalgorithmus wird weiterhin unterstützt, für die Sicherheit Ihrer Anwendung wird jedoch dringend empfohlen, den SHA256WithRSA-Signaturalgorithmus zu verwenden.

RSA-Klasse

<?php
/**
 * Created by PhpStorm.
 * User: webff
 * Date: 2017/5/12
 * Time: 20:03
 */class Rsa2
{    
private static $PRIVATE_KEY ="私钥内容";    
private static $PUBLIC_KEY  ="公钥内容";    
/**
     * 获取私钥
     * @return bool|resource
     */
    private static function getPrivateKey()
    {
        $privKey = self::$PRIVATE_KEY;        
        return openssl_pkey_get_private($privKey);
    }    
    /**
     * 获取公钥
     * @return bool|resource
     */
    private static function getPublicKey()
    {

        $publicKey = self::$PUBLIC_KEY;        
        return openssl_pkey_get_public($publicKey);
    }    /**
     * 创建签名
     * @param string $data 数据
     * @return null|string
     */
    public function createSign($data = &#39;&#39;)
    {      //  var_dump(self::getPrivateKey());die;
        if (!is_string($data)) {            
        return null;
        }        
        return openssl_sign($data, $sign, self::getPrivateKey(),OPENSSL_ALGO_SHA256 ) ? base64_encode($sign) : null;
    }    
    /**
     * 验证签名
     * @param string $data 数据
     * @param string $sign 签名
     * @return bool
     */
    public function verifySign($data = &#39;&#39;, $sign = &#39;&#39;)
    {        
    if (!is_string($sign) || !is_string($sign)) {            
    return false;
        }        
        return (bool)openssl_verify(
            $data,
            base64_decode($sign),
            self::getPublicKey(),
            OPENSSL_ALGO_SHA256
        );
    }
}

PHP-Aufruf

$rsa2 = new Rsa2();$data = &#39;mydata&#39;; //待签名字符串
$strSign = $rsa2->createSign($data);      //生成签名
$is_ok = $rsa2->verifySign($data, $strSign); //验证签名

Das obige ist der detaillierte Inhalt vonBeispiel für die gemeinsame Nutzung des RSA2-Signaturalgorithmus in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn