Hex로 된 데이터를 HexString으로, HexString을 Hex로 변환하는 경우가 종종 있었다.
그럴때 마다 Hex convert to Hexstring ~~ 등등 구글링을 했었는데....
이번에 만든 걸로 쓸 곳에 쓰고 정리를 해보았다.
Hex 를 HexString으로 변환은 말그대로 Hex형태로 된 데이터를 HexString으로 변환하는 것이다.
쉽게 말하면 아래와 같다.
Hex로 된 데이터가 있다.
uint8_t hex[16]={0xA1,0xA2,0xA3,0xA4,0xB5,0xB6,0xB7,0xB8,0xC9,0xC0,0xCA,0xCB,0xDC,0xDD,0xDE,0xDF};
현재는 한 바이트당 hex로 표시된 것을 말 그대로 스트링형태로 바꾸는 것이다.
예를 들어 0xA1의 경우 1바이트 Hex로 표시되어 있다.
이 때, A와 1을 문자형태로 만들어 0xA1이란 1바이트 Hex를 A1이란 2바이트의 문자열(0x41,0x31)로 만드는 것이다.
반대로 HexString 은 A1이란 스트링을 보이는 그대로 0xA1이란 Hex로 만드는 것이다.
설명이 애매한가....? 난 이해가 되니깐.. ㅎ
먼저 Hex를 HexString으로 바꾸는 건 아래와 같다.
int hex_convert_hexstring(uint8_t* data, uint8_t len, uint8_t* result){
int i=0;
int idx=0;
for(i=0;i<len;i++){
result[idx++]=(*(data+i))>>4 & 0x0f;
result[idx++]=(*(data+i))& 0x0f;
}
for(i=0;i<idx;i++){
if(result[i]>=10){
result[i]=result[i]-10+'A';
}else{
result[i]=result[i]+'0';
}
}
return idx;
}
data에는 변환할 Hex 데이터, len에는 data의 길이, result는 결과를 저장할 배열을 넣는다.
변환된 후, result의 데이터 길이가 retrun된다.
간단히 설명하자면.....
Hex 값을 4비트씩 나누어서 result에 넣고, 문자열로 표현하기에 result에 넣은 값을 문자열 형태로 변환해주면 된다.
이 때, 10이 hex로 표현되면 A로 표현되므로 문자열로 변환하기 위해서 10이상의 값은 10을 빼주고 문자 'A'만큼 더해준다.
이렇게 되면 10일 경우는 문자 'A', 11인경우 11-10+'A' 가 되므로 'A'+1 인 'B'가 된다.
10보다 작을 때는 문자 '0'을 더해주어 0~9를 문자 형태로 변환한다.
아스키 코드 표를 보면서 하면 더 쉽게 이해가 될 것이다.
다음으로는 HexString에서 Hex로 변환하는 법이다.
int hexstring_convert_hex(uint8_t* data,uint8_t len,uint8_t* result){
int idx=0;
int i=0;
for (i=0;i<len;i++){
if(*(data+i)>='A'){
*(data+i)=*(data+i)-'A'+10;
}else{
*(data+i)=*(data+i)-'0';
}
}
i=0;
for(idx=0;idx<len/2;idx++){
result[idx]=*(data+i++)<<4 | *(data+i++) & 0x0f;
}
return idx;
}
data에 hexstring을 넣고, len에 hexstirng의 길이를 넣고, result에 hex결과를 저장할 배열을 넣는다.
변환된 후, hex데이터의 길이가 return 된다.
아까와는 반대로 hexString의 문자를 hex로 만들고, 2바이트씩 합쳐준다.
실행 예시는 다음과 같다.
int main(){
int i=0;
int string_len=0;
int hex_len=0;
uint8_t hex[16]={0xA1,0xA2,0xA3,0xA4,0xB5,0xB6,0xB7,0xB8,0xC9,0xC0,0xCA,0xCB,0xDC,0xDD,0xDE,0xDF};
uint8_t hex_string[64];
uint8_t hex_result[64];
string_len=hex_convert_hexstring(hex,sizeof(hex),hex_string);
for(i=0;i<string_len;i++){
printf("%C ",hex_string[i]);
}
printf("\r\n");
printf("%s\r\n",hex_string); //A1A2A3A4B5B6B7B8C9C0CACBDCDDDEDF
hex_len=hexstring_convert_hex(hex_string,string_len,hex_result);
for(i=0;i<hex_len;i++){
printf("%02X ",hex_result[i]); //A1 A2 A3 A4 B5 B6 B7 B8 C9 C0 CA CB DC DD DE DF
}
printf("\r\n");
return 0;
}
주석처리가 실제 프린트된 내용인데 잘 변환된 것 같다.
끝 !
'지식저장소 > C' 카테고리의 다른 글
[C] Ring Buffer / 링버퍼 구현 (0) | 2022.03.29 |
---|---|
[C/BOJ] 9012 괄호 - Stack이용 (0) | 2022.02.16 |
[C]구조체를 이용한 Stack 구현 (0) | 2022.02.16 |
[C/STM32] Uart로 printf 대신하기 (0) | 2022.01.14 |
[C] ARIA 128 암호화 (2) | 2021.09.03 |