Udostępnij przez


Przykładowy kod SecBuffer i SecBufferDesc

W tym przykładzie pokazano, jak zainicjować tablicę zabezpieczeń. Przedstawia on wejściowe zabezpieczeń zainicjowane przez serwer po stronie połączenia w celu przygotowania wywołania do AcceptSecurityContext (ogólne). Należy pamiętać, że ostatni bufor zawiera nieprzezroczysty token zabezpieczający odebrany przez klienta i że flaga SECBUFFER_READONLY jest ustawiona na SecBuffer.

SecBuffer  Buffers[3];
SecBufferDesc BufferDesc;
BYTE *pHeader;
BYTE *pMessage;
BYTE *pTrailer;

//--------------------------------------------------------------------
// pHeader, pMessage, and pTrailer are BYTE strings.
// In a working program, they would be assigned string values.

BufferDesc.ulVersion = SECBUFFER_VERSION;
BufferDesc.cBuffers = 3;
BufferDesc.pBuffers = Buffers;

Buffers[0].cbBuffer = sizeof(pHeader);
Buffers[0].BufferType = SECBUFFER_READONLY | SECBUFFER_DATA;
Buffers[0].pvBuffer = pHeader;

Buffers[1].cbBuffer = sizeof(pMessage);
Buffers[1].BufferType = SECBUFFER_DATA;
Buffers[1].pvBuffer = pMessage;

Buffers[2].cbBuffer = sizeof(pTrailer);
Buffers[2].BufferType = SECBUFFER_READONLY | SECBUFFER_TOKEN;
Buffers[2].pvBuffer = pTrailer;