Microsoft MVP성태의 닷넷 이야기
VS.NET 2005 : 새롭게 소개되는 버퍼 오버런 방지 CRT 함수들 [링크 복사], [링크+제목 복사],
조회: 11734
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
부모글 보이기/감추기

VS.NET 2005에서 기존 VC++ 소스들을 컴파일하면 눈에 띄는 경고 중의 하나가 다음과 같은 것입니다.

d:\workshop\infopath\class\ProgramEnv.cpp(270) : warning C4996: 'sprintf' was declared deprecated
        e:\Program Files\Microsoft Visual Studio 8\VC\include\stdio.h(285) : see declaration of 'sprintf'

아시다시피, sprintf 함수는 가능한 쓰지 말라는 경고입니다. 실제 헤더 파일을 살펴보면,

_CRT_INSECURE_DEPRECATE _CRTIMP int __cdecl sprintf(char *, const char *, ...);
_CRTIMP int __cdecl sprintf_s(char *, size_t, const char *, ...);

위와 같이 기존 함수와 함께 "_s"가 붙은 함수가 하나 더 생긴 것을 볼 수 있습니다.

_s의 경우, 기존 함수와 다른 것이 해당 버퍼에 대해서 "size_t" 형의 버퍼 용량을 받는 인자가 추가되었다는 것인데요. 정책적으로 버퍼 오버런을 소스 차원에서 방지하겠다는 의도입니다.

요즘, MS가 "버퍼 오버런" 에 대한 상당히 민감한 대응을 펼치고 있죠.
XP SP2에서는 버퍼 오버런으로 인한 데이터 영역에 있는 코드들의 실행을 방지하는 기술(DEP, Data Execution Prevention)을 각 CPU 업체와 함께 개발을 했지요. 인텔의 경우 아직은 지원이 안된다고 들은 것 같지만... AMD64의 경우에는 NX(No eXecution)이란 기술로 선을 보이고 있습니다.

하드웨어에서의 지원이 더욱 믿음직스럽긴 하지만, 그러한 하드웨어가 아직 일반화되지 않은 시점에서는 어쩔 수 없이 소스 차원에서 막는 수밖에 없습니다.

개인적인 판단으로, VS.NET 2005 Beta 1에서의 C/C++ 지원은 거의 완벽한 정도입니다. 특별한 상황이 아니라면 기존 프로젝트를 VS.NET 2005용으로 변환해도 무방하기 때문에, 자신의 Application을 좀 더 안전하게 만들기 위해서라도 하루 빨리 위의 CRT 함수들로 컨버팅 하실 것을 권합니다.

아래에, 대충만 뽑아봤습니다. 이 외에도, 버퍼를 입력으로 받는 모든 것들이 해당합니다.


 printf_s
 _printf_p
 _cprintf_s
 _cprintf_p
 _vcprintf_s
 _vcprintf_p
 fprintf_s
 _fprintf_p
 sprintf_s
 _sprintf_p
 _snprintf_s
 vprintf_s
 _vprintf_p
 vfprintf_s
 _vfprintf_p
 vsprintf_s
 _vsprintf_p
 _vsnprintf_s
 scanf_s
 _cscanf_s
 fscanf_s
 sscanf_s
 _snscanf_s

    _strtod_l
    _strtol_l
    _strtoul_l
    _atof_l
    _atol_l
    _atoi_l
    _atoi64_l

  _itoa_s
  _ltoa_s
  _ultoa_s


  _strtoi64_l
  _strtoui64_l
_i64toa_s
_ui64toa_s

strcat_s
strcpy_s
strlen_s
  _strxfrm_l
  strerror_s
  _strerror_s

 asctime_s
 ctime_s
 _ctime32_s
 _ctime64_s
 _strdate_s
 _strtime_s

 getenv_s
 _makepath_s
 _putenv_s
 _searchenv_s
 _splitpath_s









[최초 등록일: ]
[최종 수정일: 7/10/2021]


비밀번호

댓글 작성자
 




1  2  3  4  [5]  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
1078정성태10/6/200912192IIS : 28. WebDeploy 도구 - WebDeploy Auto-Completion UI
1077정성태10/5/200911107TFS : 175. TFS 2010 - Basic 설치 모드
1076정성태10/5/200911101Debug : 42. 설치 또는 패치 시에 무한 재부팅을 요구하는 현상
1075정성태9/30/200910687Windows 7: 3. XP Mode 응용 프로그램의 다중 모니터 지원 조건
1073정성태9/25/200911472Vista : 56. 목록상자 항목 선택시에 "띵"하는 소리
1072정성태9/24/200918999.NET 3.0 : 34. WPF - 요소의 절대 좌표값 구하기
1071정성태9/17/200910451VS.NET IDE : 52. VS 2010 - WPF 디자이너 확장 코드 예제
1070정성태9/16/200910600VS.NET IDE : 51. Code Snippet 을 이용한 WPF 의존/첨부 속성 정의 코드 생성 [1]
1069정성태8/22/200910856.NET : 105. STM.NET on DevLabs
1068정성태8/20/200912065개발 환경 구성: 130. WinSxS 폴더 이해
1067정성태8/6/200910528개발 환경 구성: 129. Windows Vista/2008에서 .NET 1.1 설치
1066정성태7/31/200912191.NET 3.0 : 33. WPFPresenter.zip - PPT를 XAML 로! [1]
1065정성태7/31/200910547VS.NET IDE : 50. Debugging without executing your application
1064정성태7/28/20099993VS.NET IDE : 49. Visual Studio 2010 ...
1063정성태7/20/200911920Windows 2008 : 13. R2 - Trigger-Start Services [1]
1062정성태7/9/200910325VS.NET IDE : 48. 분리된 환경설정으로 Visual Studio 2008 실행
1061정성태7/9/200910783개발 환경 구성: 128. Web Services Contract First tool
1060정성태7/2/200911061개발 환경 구성: 127. UAC 모드에서 Virtual Server 웹 사이트 접근
1059정성태6/29/200912732x64 : 4. DLL Surrogate의 또 다른 활용 - 32bit응용 프로그램에서 64bit COM개체 호출
1058정성태6/23/200911714.NET 3.0 : 32. WCF - GetObject 로 서비스 프록시 인스턴스를 얻는 방법
1057정성태6/19/200911089.NET 3.0 : 31. WPF - ConveterParameter 로 1개 이상의 값을 전달하고 싶다면?
1056정성태6/17/200910666.NET 3.0 : 30. WPF - 다중 AppDomain에서 WPF 응용 프로그램 호스트
1055정성태6/15/200910561VS.NET IDE : 47. 디버그 중지점(Break Point) 목록 내보내기/가져오기
1054정성태6/6/200910955Vista : 55. FAQ: How do I start a program as the desktop user from an elevated app?
1053정성태6/1/200910477Debug : 41. PDB 다운로드 시도를 없애는 방법
1052정성태5/28/200911570.NET 4.0: 9. .NET Framework 4 Client Profile
1  2  3  4  [5]  6  7  8  9  10  11  12  13  14  15  ...