바이너리 코드의 숨겨진 문자열 마스크 해제
소프트웨어 개발 시 암호화 키와 같은 민감한 데이터를 숨겨야 하는 경우가 발생할 수 있습니다. 컴파일된 바이너리 내에서. 이 방법만으로는 데이터를 단호한 공격자로부터 안전하게 보호할 수는 없지만 추가 보안 계층 역할을 합니다.
문자열을 숨기는 기본적인 접근 방식 중 하나는 문자열을 개별 문자로 나누어 별도로 저장하는 것입니다. 코드 제공:
char encryptionKey[30]; int n = 0; encryptionKey[n++] = 'M'; // Continuing with the rest of the characters...
그러나 이 방법은 우아함이 부족하고 복잡합니다. logic.
향상된 솔루션
더 바람직한 접근 방식은 Boost C 전처리기 매크로 메커니즘을 활용하여 문자열을 암호화하고 숨기는 것입니다. 이 방법은 두 가지 프로세스를 사용합니다.
아래 코드는 구현을 보여줍니다.
#include <boost/preprocessor/cat.hpp> #include <boost/preprocessor/seq/for_each_i.hpp> #include <boost/preprocessor/seq/enum.hpp> #define CRYPT_MACRO(r, d, i, elem) ( elem ^ ( d - i ) ) #define DEFINE_HIDDEN_STRING(NAME, SEED, SEQ)\ static const char* BOOST_PP_CAT(Get, NAME)()\ {\ static char data[] = {\ BOOST_PP_SEQ_ENUM(BOOST_PP_SEQ_FOR_EACH_I(CRYPT_MACRO, SEED, SEQ)),\ '<pre class="brush:php;toolbar:false">DEFINE_HIDDEN_STRING(EncryptionKey, 0x7f, ('M')('y')(' ')('s')('t')('r')('o')('n')('g')(' ')('e')('n')('c')('r')('y')('p')('t')('i')('o')('n')(' ')('k')('e')('y'))'\ };\ \ static bool isEncrypted = true;\ if ( isEncrypted )\ {\ for (unsigned i = 0; i < ( sizeof(data) / sizeof(data[0]) ) - 1; ++i)\ {\ data[i] = CRYPT_MACRO(_, SEED, i, data[i]);\ }\ \ isEncrypted = false;\ }\ \ return data;\ }
이 매크로를 활용하면 숨겨진 문자열을 정의할 수 있습니다. 다음과 같습니다:
이 접근 방식은 바이너리 코드에서 문자열을 숨기는 데 더 안전하고 미학적으로 만족스러운 솔루션을 제공합니다. 이전 버전과의 호환성을 유지하면서 비대칭 암호화가 필요하지 않습니다.
위 내용은 C 전처리를 사용하여 바이너리 코드에서 문자열을 어떻게 안전하게 숨길 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!