2

我正在尝试将字符串“255”中的数字转换为类型 gcry_mpi_t。gcry_mpi_dump 显示 323535 而不是 gcry_mpi_add 和 gcry_mpi_print(GCRYMPI_FMT_USG... ) 无法正常工作。

#include <gcrypt.h>
#include <assert.h>
#include <stdio.h>
#include <string.h>


const char *byte_to_binary(int x)   
{
    static char b[9];
    b[0] = '\0';

    int z;
    for (z = 128; z > 0; z >>= 1) {
        strcat(b, ((x & z) == z) ? "1" : "0");
    }

    return b;
}





int main() {

gcry_mpi_t max_ul = gcry_mpi_new(64);         
gcry_mpi_t mul = gcry_mpi_new(128);                    
gcry_mpi_t cript_prime;

char mybignum[5] = {0}; 

cript_prime = gcry_mpi_new(5);

mybignum[0] ='2';
mybignum[1] ='5';
mybignum[2]='5';


printf("First %s\n", mybignum);


char buffer[60] = {0}; 

size_t scanned = 0; 

strcpy(mybignum, "255"); 
gcry_mpi_scan(&max_ul, GCRYMPI_FMT_USG, &mybignum, 5, NULL);

printf("read : %ld \n", scanned);


printf(" max_ul is  ");

gcry_mpi_dump(max_ul); printf("\n");

gcry_mpi_add(mul,max_ul,max_ul );

printf(" mul is ");
// выводим на экран
gcry_mpi_dump(mul); printf("\n");



gcry_mpi_print(GCRYMPI_FMT_USG, buffer, 30 ,  &scanned, mul);

printf("\nwrite : %ld \n", scanned);

printf("\n output the line %s \n", buffer);

for (int i=0; i<10  ; i++)
{
    printf("%s\n",byte_to_binary(buffer[i]) );
}


printf(" \n mul is: ");



gcry_mpi_dump(mul); printf("\n");





gcry_mpi_release(mul);
gcry_mpi_release(max_ul);
printf("____________________________________\n");


 return 0 ; 
}

你可以看到输出:

输出

lib 取自https://gnupg.org/download/index.html

gcc 版本 9.3.0 (Ubuntu 9.3.0-17ubuntu1~20.04)

用命令编译。gcc test.c -lgcrypt

如果你有这种类型的例子,我想看看。

4

2 回答 2

1

的文档gcry_mpi_scan()说:

转换存储在缓冲区中的整数的外部表示形式……<br /> 格式描述了存储在 缓冲区中的 MPI 格式:……<br /> GCRYMPI_FMT_USG 简单的无符号整数。

这确实有点不清楚,因此您将外部表示误解为 ASCII 十进制表示;实际上,它表示存储在内存中的整数表示。因此,要存储数字 255char mybignum[5]并对其进行转换,您可以编写:

*mybignum = 255;
gcry_error_t error = gcry_mpi_scan(&max_ul, GCRYMPI_FMT_USG, mybignum, 1, &scanned);

因此,gcry_mpi_print(GCRYMPI_FMT_USG, buffer, 30 , &scanned, mul)将 MPI a 转换为不适合用 打印的表示printf("\n output the line %s \n", buffer)

于 2020-10-28T10:47:02.367 回答
0

str 到 gcry_mpi_t。

我使用的最好方法是:

    gcry_mpi_t p = gcry_mpi_new(0);
    gcry_mpi_scan(&p, GCRYMPI_FMT_HEX, "FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF", 0, 0);

然后一切正常。

于 2020-11-09T21:30:16.500 回答