Botan c++哈希函数generate_bcrypt()

Botan c++ hash function generate_bcrypt()

本文关键字:bcrypt generate c++ 哈希 函数 Botan      更新时间:2023-10-16

我正在尝试使用Botan的函数generate_bcrypt()获取密码哈希。
我阅读了手册http://botan.randombit.net/passhash.html在这里后来我又读了一遍。源代码:

#include <botan/botan.h>
#include <botan-1.10/botan/bcrypt.h>
#include <stdio.h>
#include <iostream>
 using namespace Botan;
 int main(int argc, char *argv[])
 {
   LibraryInitializer init;
   std::string passw="12dnblkndlnbfndlknblf";
   AutoSeeded_RNG rng;

    std::string str= generate_bcrypt(passw,rng,12);
   } 


我成功地编译了它,但当我运行它时,我得到了:

     Starting /home/sh/qt/test-build-desktop/test...
      *** stack smashing detected ***: /home/sh/qt/test-build-desktop/test terminated
      ======= Backtrace: =========
  /lib/i386-linux-gnu/libc.so.6(__fortify_fail+0x45)[0x7618d5]
/lib/i386-linux-gnu/libc.so.6(+0xe7887)[0x761887]
/usr/local/lib/libbotan-1.10.so.0(+0x2517a1)[0xd957a1]
/usr/local/lib/libbotan-1.10.so.0(_ZN5Botan8Blowfish16eks_key_scheduleEPKhjS2_j+0x17d)[0xbcb52d]
[0xbfb64f4c]
======= Memory map: ========
00110000-00127000 r-xp 00000000 08:07 17853      /lib/i386-linux-gnu/libpthread-2.13.so
00127000-00128000 r--p 00016000 08:07 17853      /lib/i386-linux-gnu/libpthread-2.13.so
00128000-00129000 rw-p 00017000 08:07 17853      /lib/i386-linux-gnu/libpthread-2.13.so
00129000-0012b000 rw-p 00000000 00:00 0 
0012b000-00147000 r-xp 00000000 08:07 17835      /lib/i386-linux-gnu/libgcc_s.so.1
00147000-00148000 r--p 0001b000 08:07 17835      /lib/i386-linux-gnu/libgcc_s.so.1
00148000-00149000 rw-p 0001c000 08:07 17835      /lib/i386-linux-gnu/libgcc_s.so.1
00149000-00158000 r-xp 00000000 08:07 21570      /lib/libbz2.so.1.0.4
00158000-00159000 r--p 0000e000 08:07 21570      /lib/libbz2.so.1.0.4
00159000-0015a000 rw-p 0000f000 08:07 21570      /lib/libbz2.so.1.0.4
0015a000-001c8000 r-xp 00000000 08:07 212988     /usr/lib/libgmp.so.10.0.1
001c8000-001c9000 r--p 0006d000 08:07 212988     /usr/lib/libgmp.so.10.0.1
001c9000-001d0000 rw-p 0006e000 08:07 212988     /usr/lib/libgmp.so.10.0.1
001d0000-001d7000 r-xp 00000000 08:07 17855      /lib/i386-linux-gnu/librt-2.13.so
001d7000-001d8000 r--p 00006000 08:07 17855      /lib/i386-linux-gnu/librt-2.13.so
001d8000-001d9000 rw-p 00007000 08:07 17855      /lib/i386-linux-gnu/librt-2.13.so
001d9000-001ec000 r-xp 00000000 08:07 17267      /lib/i386-linux-gnu/libz.so.1.2.3.4
001ec000-001ed000 r--p 00012000 08:07 17267      /lib/i386-linux-gnu/libz.so.1.2.3.4
001ed000-001ee000 rw-p 00013000 08:07 17267      /lib/i386-linux-gnu/libz.so.1.2.3.4
001ee000-001f1000 r-xp 00000000 08:07 17842      /lib/i386-linux-gnu/libdl-2.13.so
001f1000-001f2000 r--p 00002000 08:07 17842      /lib/i386-linux-gnu/libdl-2.13.so
001f2000-001f3000 rw-p 00003000 08:07 17842      /lib/i386-linux-gnu/libdl-2.13.so
00214000-00232000 r-xp 00000000 08:07 17836      /lib/i386-linux-gnu/ld-2.13.so
00232000-00233000 r--p 0001d000 08:07 17836      /lib/i386-linux-gnu/ld-2.13.so
00233000-00234000 rw-p 0001e000 08:07 17836      /lib/i386-linux-gnu/ld-2.13.so
00234000-00312000 r-xp 00000000 08:07 666277     /usr/lib/i386-linux-gnu/libstdc++.so.6.0.16
00312000-00313000 ---p 000de000 08:07 666277     /usr/lib/i386-linux-gnu/libstdc++.so.6.0.16
00313000-00317000 r--p 000de000 08:07 666277     /usr/lib/i386-linux-gnu/libstdc++.so.6.0.16
00317000-00318000 rw-p 000e2000 08:07 666277     /usr/lib/i386-linux-gnu/libstdc++.so.6.0.16
00318000-0031f000 rw-p 00000000 00:00 0 
0031f000-004ac000 r-xp 00000000 08:07 16477      /lib/i386-linux-gnu/libcrypto.so.1.0.0
004ac000-004ba000 r--p 0018c000 08:07 16477      /lib/i386-linux-gnu/libcrypto.so.1.0.0
004ba000-004c0000 rw-p 0019a000 08:07 16477      /lib/i386-linux-gnu/libcrypto.so.1.0.0
004c0000-004c3000 rw-p 00000000 00:00 0 
004c3000-004eb000 r-xp 00000000 08:07 17843      /lib/i386-linux-gnu/libm-2.13.so
004eb000-004ec000 r--p 00028000 08:07 17843      /lib/i386-linux-gnu/libm-2.13.so
004ec000-004ed000 rw-p 00029000 08:07 17843      /lib/i386-linux-gnu/libm-2.13.so
0067a000-007f0000 r-xp 00000000 08:07 17839      /lib/i386-linux-gnu/libc-2.13.so
007f0000-007f2000 r--p 00176000 08:07 17839      /lib/i386-linux-gnu/libc-2.13.so
007f2000-007f3000 rw-p 00178000 08:07 17839      /lib/i386-linux-gnu/libc-2.13.so
007f3000-007f6000 rw-p 00000000 00:00 0 
0088c000-00b2a000 r-xp 00000000 08:07 214999     /usr/lib/libbotan-1.8.13.so
00b2a000-00b36000 r--p 0029d000 08:07 214999     /usr/lib/libbotan-1.8.13.so
00b36000-00b37000 rw-p 002a9000 08:07 214999     /usr/lib/libbotan-1.8.13.so
00b44000-00e0e000 r-xp 00000000 08:07 287007     /usr/local/lib/libbotan-1.10.so.0.1
00e0e000-00e18000 r--p 002ca000 08:07 287007     /usr/local/lib/libbotan-1.10.so.0.1
00e18000-00e1a000 rw-p 002d4000 08:07 287007     /usr/local/lib/libbotan-1.10.so.0.1
00e3f000-00e40000 r-xp 00000000 00:00 0          [vdso]
08048000-0804a000 r-xp 00000000 08:06 155662     /home/sh/qt/test-build-desktop/test
0804a000-0804b000 r--p 00001000 08:06 155662     /home/sh/qt/test-build-desktop/test
0804b000-0804c000 rw-p 00002000 08:06 155662     /home/sh/qt/test-build-desktop/test
09529000-0954a000 rw-p 00000000 00:00 0          [heap]
b77ee000-b77f4000 rw-p 00000000 00:00 0 
b7812000-b7814000 rw-p 00000000 00:00 0 
bfb45000-bfb66000 rw-p 00000000 00:00 0          [stack]
The program has unexpectedly finished.

我不知道我为什么得到它(当然,我知道堆栈有问题)。但我甚至不敢因此谴责博坦。所以我认为我做错了什么。当然,我可以离开这个图书馆,尝试一些不同的东西。但我已经将自己绑定到这个库(我使用了decrypt()和ecnrypt()-rich),所以我不想创建一次依赖关系。如果有人告诉我错误隐藏的地方,我会非常高兴,甚至高兴。

哎呀,很难看到我的截图。我重新加载了它们:

http://s14.radikal.ru/i187/1203/d1/b1b1a52d051d.png

http://s51.radikal.ru/i131/1203/5f/893fe9f6bbc5.png

我只能猜测植物学出了问题。。。。但这是令人难以置信的

好吧。我给植物学家杰克·劳埃德写了一封信,他回信了!!!uraaa。他的个人网页是http://www.randombit.net/
他认为,错误的来源可能是使用了和库的不同版本相关的头。即,我有几个版本的头,但只有一个库。我把它们混合在一起。工作代码:

#include <botan-1.10/botan/botan.h>
#include <botan-1.10/botan/bcrypt.h>
#include <iostream>
using namespace std;
using namespace Botan;
 int main(int argc, char* argv[])
  {
    LibraryInitializer init;
    AutoSeeded_RNG rng;
    int a=1;
    string strr="4sdfgnglkjnfkdfdfndfglgndlkgdnlkjj";
    cout<<generate_bcrypt(strr, rng,a);
    return 0;
   }

我还明确链接了库:
LIBS+=-lbotan\
/home/sh/qt/usb_encrypt/librarys/libbotan-1.10.

谢谢你,Jack Lloyd,有这么棒的图书馆。