zoukankan      html  css  js  c++  java
  • c c++ php常用的加密解密算法

    2020年9月20日13:04:47

    为什么需要加密解密算法?

    数据加密的基本过程就是对原来为明文的文件或数据按某种算法进行处理,使其成为不可读的一段代码为“密文”,

    使其只能在输入相应的密钥之后才能显示出原容,通过这样的途径来达到保护数据不被非法人窃取、阅读的目的。

    该过程的逆过程为解密,即将该编码信息转化为其原来数据的过程。

    比如api接口,数据传输,用户密码加密等、

    php常用算法

    环境 php 7.2.9

    php的官方的加密解密扩展

    https://www.php.net/manual/zh/refs.crypto.php

      $p = 'rasmuslerdorf';
            p(md5($p));
            
    //        $hash = password_hash($p, PASSWORD_DEFAULT);
            $hash = password_hash($p, PASSWORD_BCRYPT);
            p($hash);
    //        $options = [
    //            'cost' => 12,
    //        ];
    //        echo password_hash($p, PASSWORD_BCRYPT, $options);
    
            if (password_verify($p, $hash)) {
                echo 'Password is ok!';
            } else {
                echo 'Invalid password.';
            }
    
            p(hash_algos());
    
            $bytes = random_bytes(5);
            p(bin2hex($bytes));
    
            p(random_int(100, 999));

    上面是几个比较常用的关于密码的加算法

    如果你需要更多强大的请查看

    https://www.php.net/manual/zh/function.openssl-encrypt.php

    php基本把现存所有的openssl加密算法全部移植过来了,真的很不错

    $ciphers = openssl_get_cipher_methods();
            $ciphers_and_aliases = openssl_get_cipher_methods(true);
            $cipher_aliases = array_diff($ciphers_and_aliases, $ciphers);
    
            p($ciphers);
            p($ciphers_and_aliases);
            p($cipher_aliases);

    Array
    (
        [0] => AES-128-CBC
        [1] => AES-128-CBC-HMAC-SHA1
        [2] => AES-128-CBC-HMAC-SHA256
        [3] => AES-128-CFB
        [4] => AES-128-CFB1
        [5] => AES-128-CFB8
        [6] => AES-128-CTR
        [7] => AES-128-ECB
        [8] => AES-128-OCB
        [9] => AES-128-OFB
        [10] => AES-128-XTS
        [11] => AES-192-CBC
        [12] => AES-192-CFB
        [13] => AES-192-CFB1
        [14] => AES-192-CFB8
        [15] => AES-192-CTR
        [16] => AES-192-ECB
        [17] => AES-192-OCB
        [18] => AES-192-OFB
        [19] => AES-256-CBC
        [20] => AES-256-CBC-HMAC-SHA1
        [21] => AES-256-CBC-HMAC-SHA256
        [22] => AES-256-CFB
        [23] => AES-256-CFB1
        [24] => AES-256-CFB8
        [25] => AES-256-CTR
        [26] => AES-256-ECB
        [27] => AES-256-OCB
        [28] => AES-256-OFB
        [29] => AES-256-XTS
        [30] => BF-CBC
        [31] => BF-CFB
        [32] => BF-ECB
        [33] => BF-OFB
        [34] => CAMELLIA-128-CBC
        [35] => CAMELLIA-128-CFB
        [36] => CAMELLIA-128-CFB1
        [37] => CAMELLIA-128-CFB8
        [38] => CAMELLIA-128-CTR
        [39] => CAMELLIA-128-ECB
        [40] => CAMELLIA-128-OFB
        [41] => CAMELLIA-192-CBC
        [42] => CAMELLIA-192-CFB
        [43] => CAMELLIA-192-CFB1
        [44] => CAMELLIA-192-CFB8
        [45] => CAMELLIA-192-CTR
        [46] => CAMELLIA-192-ECB
        [47] => CAMELLIA-192-OFB
        [48] => CAMELLIA-256-CBC
        [49] => CAMELLIA-256-CFB
        [50] => CAMELLIA-256-CFB1
        [51] => CAMELLIA-256-CFB8
        [52] => CAMELLIA-256-CTR
        [53] => CAMELLIA-256-ECB
        [54] => CAMELLIA-256-OFB
        [55] => CAST5-CBC
        [56] => CAST5-CFB
        [57] => CAST5-ECB
        [58] => CAST5-OFB
        [59] => ChaCha20
        [60] => ChaCha20-Poly1305
        [61] => DES-CBC
        [62] => DES-CFB
        [63] => DES-CFB1
        [64] => DES-CFB8
        [65] => DES-ECB
        [66] => DES-EDE
        [67] => DES-EDE-CBC
        [68] => DES-EDE-CFB
        [69] => DES-EDE-OFB
        [70] => DES-EDE3
        [71] => DES-EDE3-CBC
        [72] => DES-EDE3-CFB
        [73] => DES-EDE3-CFB1
        [74] => DES-EDE3-CFB8
        [75] => DES-EDE3-OFB
        [76] => DES-OFB
        [77] => DESX-CBC
        [78] => IDEA-CBC
        [79] => IDEA-CFB
        [80] => IDEA-ECB
        [81] => IDEA-OFB
        [82] => RC2-40-CBC
        [83] => RC2-64-CBC
        [84] => RC2-CBC
        [85] => RC2-CFB
        [86] => RC2-ECB
        [87] => RC2-OFB
        [88] => RC4
        [89] => RC4-40
        [90] => RC4-HMAC-MD5
        [91] => SEED-CBC
        [92] => SEED-CFB
        [93] => SEED-ECB
        [94] => SEED-OFB
        [95] => aes-128-cbc
        [96] => aes-128-cbc-hmac-sha1
        [97] => aes-128-cbc-hmac-sha256
        [98] => aes-128-ccm
        [99] => aes-128-cfb
        [100] => aes-128-cfb1
        [101] => aes-128-cfb8
        [102] => aes-128-ctr
        [103] => aes-128-ecb
        [104] => aes-128-gcm
        [105] => aes-128-ocb
        [106] => aes-128-ofb
        [107] => aes-128-xts
        [108] => aes-192-cbc
        [109] => aes-192-ccm
        [110] => aes-192-cfb
        [111] => aes-192-cfb1
        [112] => aes-192-cfb8
        [113] => aes-192-ctr
        [114] => aes-192-ecb
        [115] => aes-192-gcm
        [116] => aes-192-ocb
        [117] => aes-192-ofb
        [118] => aes-256-cbc
        [119] => aes-256-cbc-hmac-sha1
        [120] => aes-256-cbc-hmac-sha256
        [121] => aes-256-ccm
        [122] => aes-256-cfb
        [123] => aes-256-cfb1
        [124] => aes-256-cfb8
        [125] => aes-256-ctr
        [126] => aes-256-ecb
        [127] => aes-256-gcm
        [128] => aes-256-ocb
        [129] => aes-256-ofb
        [130] => aes-256-xts
        [131] => bf-cbc
        [132] => bf-cfb
        [133] => bf-ecb
        [134] => bf-ofb
        [135] => camellia-128-cbc
        [136] => camellia-128-cfb
        [137] => camellia-128-cfb1
        [138] => camellia-128-cfb8
        [139] => camellia-128-ctr
        [140] => camellia-128-ecb
        [141] => camellia-128-ofb
        [142] => camellia-192-cbc
        [143] => camellia-192-cfb
        [144] => camellia-192-cfb1
        [145] => camellia-192-cfb8
        [146] => camellia-192-ctr
        [147] => camellia-192-ecb
        [148] => camellia-192-ofb
        [149] => camellia-256-cbc
        [150] => camellia-256-cfb
        [151] => camellia-256-cfb1
        [152] => camellia-256-cfb8
        [153] => camellia-256-ctr
        [154] => camellia-256-ecb
        [155] => camellia-256-ofb
        [156] => cast5-cbc
        [157] => cast5-cfb
        [158] => cast5-ecb
        [159] => cast5-ofb
        [160] => chacha20
        [161] => chacha20-poly1305
        [162] => des-cbc
        [163] => des-cfb
        [164] => des-cfb1
        [165] => des-cfb8
        [166] => des-ecb
        [167] => des-ede
        [168] => des-ede-cbc
        [169] => des-ede-cfb
        [170] => des-ede-ofb
        [171] => des-ede3
        [172] => des-ede3-cbc
        [173] => des-ede3-cfb
        [174] => des-ede3-cfb1
        [175] => des-ede3-cfb8
        [176] => des-ede3-ofb
        [177] => des-ofb
        [178] => desx-cbc
        [179] => id-aes128-CCM
        [180] => id-aes128-GCM
        [181] => id-aes128-wrap
        [182] => id-aes128-wrap-pad
        [183] => id-aes192-CCM
        [184] => id-aes192-GCM
        [185] => id-aes192-wrap
        [186] => id-aes192-wrap-pad
        [187] => id-aes256-CCM
        [188] => id-aes256-GCM
        [189] => id-aes256-wrap
        [190] => id-aes256-wrap-pad
        [191] => id-smime-alg-CMS3DESwrap
        [192] => idea-cbc
        [193] => idea-cfb
        [194] => idea-ecb
        [195] => idea-ofb
        [196] => rc2-40-cbc
        [197] => rc2-64-cbc
        [198] => rc2-cbc
        [199] => rc2-cfb
        [200] => rc2-ecb
        [201] => rc2-ofb
        [202] => rc4
        [203] => rc4-40
        [204] => rc4-hmac-md5
        [205] => seed-cbc
        [206] => seed-cfb
        [207] => seed-ecb
        [208] => seed-ofb
    )
    
    

    c/cpp的加密解密算法库

    https://github.com/openssl/openssl/tree/master/crypto

    可以参考对照下基本全部移植过来了

    https://www.feistyduck.com/library/openssl-cookbook/online/ch-openssl.html#

    英文官方OpenSSL的说明pdf,有时间翻译下 

    还一个就是非常知名的Crypto++

    官网 https://www.cryptopp.com/

    https://github.com/weidai11/cryptopp

    使用参考博客

     https://blog.csdn.net/Lunar_Queen/column/info/25854

    如果你想学习算法编写,以上 openssl和cryptopp是非常好的学习资料,整个git库挺大的

    加速下载方法,在这里推荐一下,下面整个网站,对于网络环境比较烂的同学是非常不错的工具

    https://gitclone.com/
    git clone https://gitclone.com/github.com/weidai11/cryptopp
    
    git clone https://gitclone.com/github.com/openssl/openssl
  • 相关阅读:
    (转)WinForm中的各种表格控件
    sql2005 单用户改为多用户sql语句
    使用sp_executesql执行动态SQL语句,同时向里面传入参数。
    visual studio 不能创建biztalk 项目
    sql2005 无法连接服务器 1433端口没有监听,但是本地帐户可以登陆
    visual studio运行时提示无法启动应用程序
    将表中的数据生成插入语句
    sql 补零方法
    正则表达式,动态生成小数点位数的验证
    “本地计算机上的SQL SERVER服务启动后又停止了”解决方法
  • 原文地址:https://www.cnblogs.com/zx-admin/p/13699793.html
Copyright © 2011-2022 走看看