Botan c ++ хеш-функция generate_bcrypt () - PullRequest
1 голос
/ 06 марта 2012

Я пытаюсь получить хэш пароля с помощью функции 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 () - wealthy), поэтому я не хочу создавать еще один раз зависимость. Я буду очень рад и даже счастлив, если кто-нибудь даст мне советы, где скрывается моя ошибка.

упс, трудно увидеть мои скриншоты. Я выложил их:

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

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

Я могу только догадываться, что в Ботане что-то не так ... Но это невероятно

1 Ответ

2 голосов
/ 09 марта 2012

Хорошо.Я написал письмо создателю Botan - Джеку Ллойду, и он ответил !!! 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/libraries/libbotan-1.10.a

Спасибо, Джек Ллойд, за такую ​​замечательную библиотеку.

...