C语言使用openssl大数指数求余

1.源码实现

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <openssl/bn.h>

int main()
{
        BN_CTX *r[3];
        BIGNUM *a;
        BIGNUM *b;
        BIGNUM *c;
        BIGNUM *d;
        BIGNUM *e;
        BIGNUM *f;
        BIGNUM *g;
        char u[512+1] = "FE7155A4C441E38D653CC7BB82D9B9A3BFB872CF151B8A19AF4D8E6035BFE6275FFC722ACD29EA9B1FF28B8D134DFAD001738DF7A2F78909DEF606836EE6C6CB";
        char s[512+1] = "FDBAE7C63C5ECA65D27E9C8759AED3B8F6B36F24773FB6A4A03B49026B2D82491732CFDC9F3C77B61B19A945AA2386A7ABD69F23FBBFE18EDB6B7780A3C4CB13";
        char t[512+1] = "C5C671EBC128B4423C6323DF7E43A1DD35EFCFF0F17B09AD1D6B3FCFBBBB685E6C725BCBC3518B9E067B260C2FE5849F24C839C6AA799732D8B5F8EDC9F286CB";
        char *x;

        r[0] = BN_CTX_new();

        a = BN_new();
        b = BN_new();
        c = BN_new();
        d = BN_new();

        BN_hex2bn(&a, s);
        BN_hex2bn(&b, t);
        BN_hex2bn(&c, u);

        BN_mod_exp(d, a, c, b, r[0]);   //d=(a^b)%c

        x = BN_bn2hex(d);

        puts(x);

        BN_free(a);
        BN_free(b);
        BN_free(c);
        BN_free(d);

        BN_CTX_free(r[0]);

        free(x);

        return 0;
}

2.编译源码

$ gcc -I$HOME/local/include -o example example.c -L$HOME/local/lib -lssl

3.运行结果

$ ./example
3D17E54FCF88FF4CAAF8780F5FF6DEAB374C223F8EA0D7F4B00DE6F2A601F8D9E2EE49A654B9F3CB23A2F454F811834D064866967DB903766881E2C6EE2F5ABF
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容