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

生成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 用matlab 设计一个不动点迭代法求解非线性方程组的代码
  • ¥15 牛顿斯科特系数表表示
  • ¥15 arduino 步进电机
  • ¥20 程序进入HardFault_Handler
  • ¥15 oracle集群安装出bug
  • ¥15 关于#python#的问题:自动化测试
  • ¥20 问题请教!vue项目关于Nginx配置nonce安全策略的问题
  • ¥15 教务系统账号被盗号如何追溯设备
  • ¥20 delta降尺度方法,未来数据怎么降尺度
  • ¥15 c# 使用NPOI快速将datatable数据导入excel中指定sheet,要求快速高效