다음을 통해 공유


ValidateBitmapInfoHeader 함수

[이 페이지와 연결된 기능인 DirectShow는 레거시 기능입니다. MediaPlayer, IMFMediaEngineMedia Foundation의 오디오/비디오 캡처로 대체되었습니다. 이러한 기능은 Windows 10 및 Windows 11 최적화되었습니다. 가능한 경우 새 코드에서 DirectShow 대신 MediaPlayer, IMFMediaEngine오디오/비디오 캡처를 사용하는 것이 좋습니다. 가능한 경우 레거시 API를 사용하는 기존 코드를 다시 작성하여 새 API를 사용하도록 제안합니다.]

함수는 ValidateBitmapInfoHeader 버퍼 오버런 또는 정수 오버플로를 일으킬 수 있는 특정 일반적인 오류에 대해 BITMAPINFOHEADER 구조를 확인합니다.

참고

이 함수는 BITMAPINFOHEADER 구조가 유효하거나 구조를 사용하는 코드가 안전하다는 것을 보장하지 않습니다.

 

구문

BOOL ValidateBitmapInfoHeader(
   const BITMAPINFOHEADER *pbmi,
         DWORD            cbSize
);

매개 변수

pbmi

유효성을 검사할 BITMAPINFOHEADER 구조체에 대한 포인터입니다.

cbSize

구조를 보유하는 메모리 블록의 크기(바이트)입니다.

반환 값

부울 값을 반환합니다. 값이 FALSE이면 BITMAPINFOHEADER 구조가 잘못되었습니다.

설명

이 함수는 다음 오류를 방지합니다.

  • 구조체 크기 또는 잘못된 구조 크기의 산술 오버플로입니다.
  • biClrUsed 멤버의 값이 잘못되었습니다.
  • 이미지 크기의 산술 오버플로(biSizeImage).
  • RGB 형식의 이미지 크기(biSizeImage)에 대한 값이 잘못되었습니다.

함수는 구조체가 유효한 비디오 형식을 설명하는지 여부를 검사 않습니다.

요구 사항

요구 사항
헤더
Checkbmi.h

추가 정보

비디오 및 이미지 함수