const unsigned char * преобразование в / из строки или const char * - PullRequest
0 голосов
/ 16 марта 2012

Я потерян в подземном мире указателей!Вот моя проблема,

Это очень странно, и я могу управлять только одной из функций, поэтому, пожалуйста, не говорите, что мне нужно изменить дизайн.Это компилируется в Linux Ubuntu 11.04 с использованием android-ndkr7.Это чисто нативное приложение (или служба), которое будет работать на телефоне Android.Я использую тест Google для проверки моего класса / функций.Первая функция (мой тестовый класс) должна объявить беззнаковый символ char *, она передает его второй функции, которая будет использоваться в качестве вывода (crypt :: encryptBuffer), encrypt принимает объявленную переменную, выделяет для нее память и передает еетретья функция, где значение помещается в него в качестве вывода.

Crypt.h

class Crypt
{
public:

   Crypt();
   ~Crypt();

   bool encryptBuffer(const unsigned char* inDecryptBuffer, const int inputSize, unsigned char** outEncryptBuffer, int*  pOutSize);

};

#endif

Crypt.cpp

#include "Crypt.h"
#include "pan/crypt.h"

static unsigned char HydraEncryptionKey[] = {0x17, 0x43, 0x9B, 0x55, 0x07, 0xAE, 0x73, 0xB1, 0x32, 0x10, 0xE0, 0x22, 0xD9, 0xC7, 0xF2, 0x3B};

bool AccCrypt::encryptBuffer(const unsigned char* inDecryptBuffer, const int inputSize, unsigned char** outEncryptBuffer, int*  pOutSize)
{
    int encryptedSize;
    pan::aes128_cbc enc(HydraEncryptionKey);

    // see how long the encrypted data will be and allocate space for the data
    encryptedSize = enc.output_len( inputSize );

    *outEncryptBuffer = (unsigned char*)malloc(encryptedSize + 4);

    enc.encrypt(inDecryptBuffer, *outEncryptBuffer, inputSize );
    return true;
}

CryptTest.cpp

#incude "Crypt.h"
#include <gtest/gtest.h>

#define CHECK_COND(X, a, b, c) { \
if(X) \
{ \
    printf("FAIL: %s\n", c); \
    printf("Press any key to continue");\
    getc(stdin);\
}\
else \
{ \
    printf("PASS: %s\n", c); \
}\
}

#define EXPECT_EQ(a,b,c)  CHECK_COND((a != b), a, b, c)

const char* decBuff = "something";
const int inputSize = 10;
unsigned char* encBuffTest = NULL;
int pOutsize = 0;

class cryptTester : public testing::Test
{
    protected:
    virtual void SetUp()
    {
        cryptTest = new Crypt();
        cryptTest->encryptBuffer((const unsigned char*)decBuff, inputSize, &encBuffTest, &pOutsize);
    }

    virtual void TearDown()
    {
    }

    Crypt* cryptTest;

};
TEST_F(AccCryptTest, decryptBuffer)
{
    int poutSize = 0;
    EXPECT_EQ(true, accCryptTest->decryptBuffer((const unsigned char*)encBuffTest, pOutsize, &outDecryptBuffTest, &poutSize), "decryptBuffer(valid, valid)");

}

Это скомпилируется нормально, однако, когда язапустить его на телефоне я получаю ошибку сегментации.Я не могу понять, где это происходит, так как я не смог правильно настроить отладку из оболочки adb.

Буду признателен за любую помощь!

1 Ответ

0 голосов
/ 04 августа 2012

Ваш код выглядит нормально, возможно ошибка в методе encrypt:

enc.encrypt(inDecryptBuffer, *outEncryptBuffer, inputSize );
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...