[英]How to convert a string to byte array?
我有以下字符*:
char*Problem = "\x8B\x15\x00\x00\x00\x00\x8B\x7C\x24\x14\x85\xC9\x74\x16\x8B\x03\x89\x01\x8B\x2D\x00\x00\x00\x00\x8B\x15\x00\x00\x00\x00\x8B\x0D\x00\x00\x00\x00\x83\xC1\x04"
我試圖得到這個:
unsigned char buf[] = {0x8B, 0x15, 0x00, 0x00, 0x00, 0x00, 0x8B, 0x7C, 0x24, 0x14, 0x85, 0xC9, 0x74, 0x16, 0x8B, 0x03, 0x89, 0x01, 0x8B, 0x2D, 0x00, 0x00, 0x00, 0x00, 0x8B, 0x15, 0x00, 0x00, 0x00, 0x00, 0x8B, 0x0D, 0x00, 0x00, 0x00, 0x00, 0x83, 0xC1, 0x04};
但是通過運行時。 我正在從文本框中讀取char *。
我嘗試了以下方法:
UnicodeString Maskstr = Edit2->Text; //My char*Problem above
const char *chr = AnsiString(Maskstr).c_str();
char* MaskConverted = const_cast<char*>( chr );
unsigned char NewArray[40];
strcpy( (char*) NewArray, MaskConverted );
我以為,我的未簽名字符現在應該是NewArray,但事實並非如此。 那么如何獲得正確的結果呢?
我現在有點卡住了。 有任何想法嗎?
謝謝! :)
您的示例在第二個字節之后不正確地初始化了Problem
變量(正在截斷數據)。
但是,為了便於討論,我們假設您的TEdit
實際上包含您感興趣的完整文本TEdit
是否包含已按原樣擴展為16位Unicode字符的實際原始字節 ,還是包含十六進制的-原始字節的編碼表示形式 ? 這使您在處理文本方面大不同。
如果文本包含原始字節 ,則您的處理代碼錯誤地存儲了char*
指針,該指針指向的數據屬於臨時AnsiString
,在使用該指針之前會被破壞,從而表現出未定義的行為 。 復制完AnsiString
之前,請勿破壞它:
AnsiString Maskstr = Edit2->Text;
unsigned char NewArray[40];
strncpy(reinterpret_cast<char*>(NewArray), const_cast<char*>(s.c_str()), 40);
另外,根本不轉換為AnsiString
,您可以截斷Unicode字符:
UnicodeString Maskstr = Edit2->Text;
unsigned char NewArray[40] = {};
int maxlen = Maskstr.Length();
if (maxlen > 40) maxlen = 40;
for(int i = 0; i < maxlen; ++i) {
NewArray = static_cast<unsigned char>(Maskstr[i+1]);
}
但是,如果文本實際包含原始字節的十六進制編碼表示形式 ,則需要解析文本以將十六進制序列解碼為實際字節,例如:
#include <stdio.h>
UnicodeString Maskstr = Edit2->Text;
const WideChar *ptr = Maskstr.c_str();
unsigned char NewArray[40] = {};
int maxlen = Maskstr.Length();
if (maxlen > 40) maxlen = 40;
for(int i = 0; i < maxlen; ++i)
{
unsigned int b, numChars;
if (swscanf(ptr, L"\\x%2x%n", &b, &numChars) != 1) break;
NewArray[i] = static_cast<unsigned char>(b);
ptr += numChars;
}
編譯器將編譯制表符的十六進制值,但是我找不到轉換它的函數-盡管Remy使用的是scanf。 我將選項卡更改為0x格式並使用strtol。
// convert hex string to char/byte values
size_t TForm1::TranslateTabbedHex(const AnsiString str, std::vector<unsigned char> & result)
{
AnsiString char_str(str);
char * pEnd;
size_t pos = char_str.AnsiPos("\\");
for( ; pos; pos = char_str.AnsiPos("\\") )
{
if( pos != 1)
char_str.Delete(1, pos-1);
char_str[1] = '0';
result.push_back( strtol(char_str.c_str(), &pEnd, 0) );
char_str.Delete(1,1);
}
return result.size();
}
//---------------------------------------------------------------------------
void TForm1::TestTranslateTabbedHex(std::vector<unsigned char> & result)
{
unsigned char test_value[] = "\x8B\x15\x00\x00\x00\x00\x8B\x7C\x24\x14"
"\x85\xC9\x74\x16\x8B\x03\x89\x01\x8B\x2D"
"\x00\x00\x00\x00\x8B\x15\x00\x00\x00\x00"
"\x8B\x0D\x00\x00\x00\x00\x83\xC1\x04";
//"\x8B\x15\x00\x00\x00\x00\x8B\x7C\x24\x14\x85\xC9\x74\x16\x8B\x03\x89\x01\x8B\x2D\x00\x00\x00\x00\x8B\x15\x00\x00\x00\x00\x8B\x0D\x00\x00\x00\x00\x83\xC1\x04"
Memo1->Clear();
size_t test_size = sizeof test_value - 1;
AnsiString length( test_size );
Memo1->Lines->Add( AnsiString("size test_value=") + length );
Memo1->Lines->Add( AnsiString("size result=") + result.size() );
AnsiString text(Edit1->Text);
if(Edit1->Text.Length() > 0)
Memo1->Lines->Add( AnsiString("first char value in EditBox = ") + text[1]);
else
Memo1->Lines->Add("No text in EditBox");
Memo1->Lines->Add(" ");
if(result.size() == 0)
{ Memo1->Lines->Add("result = 0 length");
}
else
{ size_t test_size = std::min( result.size(), test_size ); // #include <algorithm>
Memo1->Lines->Add("test - result - same");
for(size_t i=0; i<test_size; i++)
{ AnsiString line(test_value[i]);
line += AnsiString(" - ") + result[i];
line += AnsiString(" - ") + AnsiString((result[i] == test_value[i]) ? "Yes" : "No");
Memo1->Lines->Add( line );
}
}
}
//---------------------------------------------------------------------------
void __fastcall TForm1::Button1Click(TObject *Sender)
{
std::vector<unsigned char> result;
TranslateTabbedHex(Edit1->Text, result);
TestTranslateTabbedHex( result );
}
//---------------------------------------------------------------------------
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.