douhe4608 2018-08-04 12:25
浏览 276

生成256位ECDSA私钥

I want to make an 256 bit ECDSA private key with secp256k1 curve by php.

I used this snippet:

$pk_Generate = openssl_pkey_new(array(
    'private_key_bits' => 256,
    'private_key_type' => OPENSSL_KEYTYPE_EC,
    'curve_name' => 'secp256k1'
));

while ($msg = openssl_error_string())
    echo $msg . "<br />
";

openssl_pkey_export($pk_Generate, $pk_Generate_Private);
var_dump($pk_Generate_Private); // show me NULL

but it give me this error:

error:0E06D06C:configuration file routines:NCONF_get_string:no value
error:0E06D06C:configuration file routines:NCONF_get_string:no value
error:0E06D06C:configuration file routines:NCONF_get_string:no value
error:0E06D06C:configuration file routines:NCONF_get_string:no value

also if this code works fine, it shows me private key in PEM format but I want it in hex string format.

please guide me.

  • 写回答

1条回答 默认 最新

  • duangeli1334 2018-11-19 18:40
    关注

    Try this

    $config = [
        "config" => getenv('OPENSSL_CONF'),
        'private_key_type' => OPENSSL_KEYTYPE_EC,
        'curve_name' => 'secp256k1'
    ];
    $res = openssl_pkey_new($config);
    if (!$res) {
        echo 'ERROR: Fail to generate private key. -> ' . openssl_error_string();
        exit;
    }
    // Generate Private Key
    openssl_pkey_export($res, $priv_key, NULL, $config);
    // Get The Public Key
    $key_detail = openssl_pkey_get_details($res);
    $pub_key = $key_detail["key"];
    
    echo "priv_key:<br>".$priv_key;
    echo "<br><br>pub_key:<br>".$pub_key;
    
    评论

报告相同问题?

悬赏问题

  • ¥15 关于#hadoop#的问题
  • ¥15 (标签-Python|关键词-socket)
  • ¥15 keil里为什么main.c定义的函数在it.c调用不了
  • ¥50 切换TabTip键盘的输入法
  • ¥15 可否在不同线程中调用封装数据库操作的类
  • ¥15 微带串馈天线阵列每个阵元宽度计算
  • ¥15 keil的map文件中Image component sizes各项意思
  • ¥20 求个正点原子stm32f407开发版的贪吃蛇游戏
  • ¥15 划分vlan后,链路不通了?
  • ¥20 求各位懂行的人,注册表能不能看到usb使用得具体信息,干了什么,传输了什么数据