V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
tanszhe
V2EX  ›  PHP

sm3(国密签名算法)的 PHP 实现

  •  
  •   tanszhe · 2021-02-01 15:20:51 +08:00 · 3038 次点击
    这是一个创建于 1384 天前的主题,其中的信息可能已经有所发展或是发生改变。

    源码地址

    https://github.com/lizhichao/sm

    安装

    composer require lizhichao/one-sm
    

    使用

    <?php
    require __DIR__ . '/vendor/autoload.php';
    
    // 字符串签名
    echo \OneSm\Sm3::sign('abc') . PHP_EOL;
    echo \OneSm\Sm3::sign(str_repeat("adfas 哈哈哈", 100)) . PHP_EOL;
    
    
    // 文件签名
    echo \OneSm\Sm3::signFile(__FILE__) . PHP_EOL;
    

    性能测试

    openssl , SM3-PHP 性能测试

    php bench.php
    

    结果

    openssl:4901d7181a1024b8c0f59b8d3c5c6d96b4b707ad10e8ebc8ece5dc49364a3067
    one-sm3:4901d7181a1024b8c0f59b8d3c5c6d96b4b707ad10e8ebc8ece5dc49364a3067
    SM3-PHP:4901d7181a1024b8c0f59b8d3c5c6d96b4b707ad10e8ebc8ece5dc49364a3067
    openssl time:6.3741207122803ms
    one-sm3 time:8.1770420074463ms
    SM3-PHP time:1738.5928630829ms
    

    测试代码 bench.php

    3 条回复    2021-02-01 21:11:36 +08:00
    shawndev
        1
    shawndev  
       2021-02-01 17:14:40 +08:00
    SM3 什么时候成签名算法了???你确定不是杂凑算法???
    GTim
        2
    GTim  
       2021-02-01 17:25:58 +08:00
    国米算法延迟这么高
    BIAOXYZ
        3
    BIAOXYZ  
       2021-02-01 21:11:36 +08:00
    @GTim #2 应该用第二个时间和第一个比吧。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2741 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 12:46 · PVG 20:46 · LAX 04:46 · JFK 07:46
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.