好的,我已经编写了我的第一个功能性 PHP 扩展。它有效,但它只是一个概念验证。现在我正在写另一个真正做到老板想要的东西。
我想从你们所有的 PHP 专家那里知道,这段代码是否有意义。我是否已经很好地掌握了诸如此类的东西emalloc
,或者那里有什么东西会在以后转身并试图咬掉我的手?
以下是其中一项功能的代码。它返回同样经过 Blowfish 加密的字符串的 base64。调用该函数时,会提供两个字符串,即要加密和编码的文本,以及用于加密阶段的密钥。它没有使用 PHP 自己的 base64 函数,因为此时我不知道如何链接到它们。出于同样的原因,它没有使用 PHP 自己的 mcrypt 函数。相反,它链接到 SSLeayBF_ecb_encrypt
函数。
PHP_FUNCTION(Blowfish_Base64_encode)
{
char *psData = NULL;
char *psKey = NULL;
int argc = ZEND_NUM_ARGS();
int psData_len;
int psKey_len;
char *Buffer = NULL;
char *pBuffer = NULL;
char *Encoded = NULL;
BF_KEY Context;
int i = 0;
unsigned char Block[ 8 ];
unsigned char * pBlock = Block;
char *plaintext;
int plaintext_len;
int cipher_len = 0;
if (zend_parse_parameters(argc TSRMLS_CC, "ss", &psData, &psData_len, &psKey, &psKey_len) == FAILURE)
return;
Buffer = (char *) emalloc( psData_len * 2 );
pBuffer = Buffer;
Encoded = (char *) emalloc( psData_len * 4 );
BF_set_key( &Context, psKey_len, psKey );
plaintext = psData;
plaintext_len = psData_len;
for (;;)
{
if (plaintext_len--)
{
Block[ i++ ] = *plaintext++;
if (i == 8 )
{
BF_ecb_encrypt( Block, pBuffer, &Context, BF_ENCRYPT );
pBuffer += 8;
cipher_len += 8;
memset( Block, 0, 8 );
i = 0;
}
} else {
BF_ecb_encrypt( Block, pBuffer, &Context, BF_ENCRYPT );
cipher_len += 8;
break;
}
}
b64_encode( Encoded, Buffer, cipher_len );
RETURN_STRINGL( Encoded, strlen( Encoded ), 0 );
}
你会注意到我有两个emalloc
电话, forEncoded
和 for Buffer
。OnlyEncoded
被传回给调用者,所以我担心 Buffer 不会被释放。是这样吗?我应该使用 malloc/freeBuffer
吗?
如果有任何其他明显的错误,我真的很感激知道。