Megosztás a következőn keresztül:


A WinHTTP-munkamenetek áttekintése

A Microsoft Windows HTTP Services (WinHTTP) C/C++ függvények készletét teszi elérhetővé, amelyek lehetővé teszik az alkalmazás számára a HTTP-erőforrások webes elérését. Ez a témakör áttekintést nyújt arról, hogyan használják ezeket a függvényeket a HTTP-kiszolgálókkal való interakcióhoz.

A WinHTTP API használata a weben való hozzáféréshez

Az alábbi ábra azt mutatja be, hogy a WinHTTP-függvények általában milyen sorrendben vannak meghívva EGY HTTP-kiszolgáló használatakor. Az árnyékolt mezők olyan függvényeket jelölnek, amelyek HINTERNET fogópontot hoznak létre, míg az egyszerű mezők azokat a függvényeket jelölik, amelyek ezeket a fogópontokat használják.

-t létrehozó függvények

A WinHTTP inicializálása

A kiszolgálóval való interakció előtt a WinHTTP-t inicializálni kell WinHttpOpenmeghívásával. WinHttpOpen létrehoz egy munkamenet-környezetet a HTTP-munkamenet részleteinek karbantartásához, és visszaad egy munkamenet-leírót. Ezzel a leíróval a WinHttpConnect függvény képes megadni egy cél HTTP- vagy SECURE Hypertext Transfer Protocol-kiszolgálót (HTTPS).

Jegyzet

A WinHttpConnecthívása nem eredményez tényleges kapcsolatot a HTTP-kiszolgálóval, amíg nem kér egy adott erőforrást.

 

Kérelem megnyitása

A WinHttpOpenRequest függvény http-kérelmet nyit meg egy adott erőforráshoz, és visszaad egy HINTERNET leírót, amelyet a többi HTTP-függvény használhat. WinHttpOpenRequest híváskor nem küldi el a kérést a kiszolgálónak. A WinHttpSendRequest függvény ténylegesen kapcsolatot létesít a hálózaton keresztül, és elküldi a kérést.

Az alábbi példa az alapértelmezett beállításokat használó WinHttpOpenRequest meghívását mutatja be.

HINTERNET hRequest = WinHttpOpenRequest( hConnect, L"GET", NULL, NULL, NULL, NULL, 0);

Kérelemfejlécek hozzáadása

A WinHttpAddRequestHeaders függvény lehetővé teszi, hogy az alkalmazás további szabad formátumú kérelemfejléceket fűzjön a HTTP-kérelem leírójához. Kifinomult alkalmazások számára készült, amelyek pontos ellenőrzést igényelnek a HTTP-kiszolgálónak küldött kérések felett.

A WinHttpAddRequestHeaders függvényhez a WinHttpOpenRequestáltal létrehozott HTTP-kéréskezelő szükséges, amely a fejléceket, a fejlécek hosszát és a módosítókat tartalmazza.

Az alábbi módosítók használhatók WinHttpAddRequestHeaders.

Módosító Leírás
WINHTTP_ADDREQ_FLAG_ADD Hozzáadja a fejlécet, ha nem létezik. Használva a WINHTTP_ADDREQ_FLAG_REPLACE-val.
WINHTTP_ADDREQ_FLAG_ADD_IF_NEW Csak akkor adja hozzá a fejlécet, ha még nem létezik; ellenkező esetben a függvény hibát ad vissza.
WINHTTP_ADDREQ_FLAG_COALESCE Az azonos nevű fejléceket egyesíti.
WINHTTP_ADDREQ_FLAG_COALESCE_WITH_COMMA Vesszővel egyesíti az azonos nevű fejléceket. Például az "Elfogadás: szöveg/*", majd az "Elfogadás: hang/*" jelölő hozzáadásával kialakul az "Elfogadás: szöveg/*, hang/*" fejléc, ami az első megtalált fejléc összevonását eredményezi. A hívó alkalmazás feladata, hogy egységes sémát biztosítson az egyesített/különálló fejlécek tekintetében.
WINHTTP_ADDREQ_FLAG_COALESCE_WITH_SEMICOLON Az azonos nevű fejléceket pontosvesszővel egyesítheti.
WINHTTP_ADDREQ_FLAG_REPLACE Lecseréli vagy eltávolítja a fejlécet. Ha a fejléc értéke üres, és a fejléc megtalálható, az el lesz távolítva. Ha a fejléc értéke nem üres, a fejléc értéke lecserélődik.

 

Kérés küldése

A WinHttpSendRequest függvény kapcsolatot létesít a kiszolgálóval, és elküldi a kérést a megadott helyre. Ehhez a függvényhez WinHttpOpenRequestáltal létrehozott HINTERNET leíró szükséges. WinHttpSendRequest további fejléceket vagy opcionális információkat is küldhet. Az opcionális információkat általában olyan műveletekhez használják, amelyek adatokat írnak a kiszolgálóra, például PUT és POST.

Miután a WinHttpSendRequest függvény elküldte a kérést, az alkalmazás használhatja a WinHttpReadData és WinHttpQueryDataAvailable függvényeket a HINTERNET leírón a kiszolgáló erőforrásainak letöltéséhez.

Adatok közzététele a kiszolgálóra

Ha adatokat szeretne közzétenni egy kiszolgálóra, a WinHttpOpenRequest hívásában szereplő HTTP- parancsnak POST vagy PUT értékűnek kell lennie. Ha WinHttpSendRequest van meghívva, a dwTotalLength paramétert bájtban kell beállítani az adatok méretére. Ezután WinHttpWriteData használatával tegye közzé az adatokat a kiszolgálón.

Másik lehetőségként állítsa a WinHttpSendRequestlpOptional paraméterét egy olyan puffer címére, amely adatokat tartalmaz a kiszolgálóra való közzétételhez. A technika használatakor meg kell adnia mind a dwOptionalLength, mind a dwTotalLength paramétert a WinHttpSendRequest esetében, hogy megegyezzenek a közzéteendő adatok méretével. Az WinHttpSendRequest ilyen módon történő meghívása szükségtelenné teszi WinHttpWriteDatameghívását.

Információ megszerzése egy kérésről

A WinHttpQueryHeaders függvény lehetővé teszi, hogy az alkalmazás adatokat kérjen le egy HTTP-kérésről. A függvényhez szükség van egy HINTERNET leíróra, amelyet WinHttpOpenRequesthozott létre, egy információszint-értéket és egy pufferhosszt. WinHttpQueryHeaders is elfogad egy puffert, amely tárolja az információkat és egy nulla alapú fejlécindexet, amely több azonos nevű fejlécet sorol fel.

A Lekérdezési információs jelzők lapon található információszint-értékek bármelyikét használhatja egy módosítóval annak a formátumnak a szabályozásához, amelyben az adatok a WinHttpQueryHeaderslpvBuffer paraméterében találhatók.

Erőforrások letöltése a webről

Miután megnyitott egy kérelmet a WinHttpOpenRequest függvénnyel, WinHttpSendRequest, és előkészíti a kéréskezelőt, hogy választ kapjon WinHttpReceiveResponse, az alkalmazás használhatja a WinHttpReadData és WinHttpQueryDataAvailable függvényeket az erőforrás HTTP-kiszolgálóról való letöltéséhez.

Az alábbi mintakód bemutatja, hogyan tölthet le egy erőforrást biztonságos tranzakció szemantikával. A mintakód inicializálja a WinHTTP alkalmazásprogramozási felületét (API), kiválaszt egy cél HTTPS-kiszolgálót, majd megnyitja és elküldi a biztonságos erőforrásra vonatkozó kérést. WinHttpQueryDataAvailable a kérelemleíróval határozza meg, hogy mennyi adat érhető el a letöltéshez, majd WinHttpReadData használja az adatok olvasására. Ez a folyamat addig ismétlődik, amíg a teljes dokumentum le nem olvasható és meg nem jelenik.

  DWORD dwSize = 0;
  DWORD dwDownloaded = 0;
  LPSTR pszOutBuffer;
  BOOL  bResults = FALSE;
  HINTERNET  hSession = NULL, 
             hConnect = NULL,
             hRequest = NULL;

  // Use WinHttpOpen to obtain a session handle.
  hSession = WinHttpOpen( L"WinHTTP Example/1.0",  
                          WINHTTP_ACCESS_TYPE_DEFAULT_PROXY,
                          WINHTTP_NO_PROXY_NAME, 
                          WINHTTP_NO_PROXY_BYPASS, 0 );

  // Specify an HTTP server.
  if( hSession )
    hConnect = WinHttpConnect( hSession, L"www.microsoft.com",
                               INTERNET_DEFAULT_HTTPS_PORT, 0 );

  // Create an HTTP request handle.
  if( hConnect )
    hRequest = WinHttpOpenRequest( hConnect, L"GET", NULL,
                                   NULL, WINHTTP_NO_REFERER, 
                                   WINHTTP_DEFAULT_ACCEPT_TYPES, 
                                   WINHTTP_FLAG_SECURE );

  // Send a request.
  if( hRequest )
    bResults = WinHttpSendRequest( hRequest,
                                   WINHTTP_NO_ADDITIONAL_HEADERS, 0,
                                   WINHTTP_NO_REQUEST_DATA, 0, 
                                   0, 0 );


  // End the request.
  if( bResults )
    bResults = WinHttpReceiveResponse( hRequest, NULL );

  // Keep checking for data until there is nothing left.
  if( bResults )
  {
    do 
    {
      // Check for available data.
      dwSize = 0;
      if( !WinHttpQueryDataAvailable( hRequest, &dwSize ) )
        printf( "Error %u in WinHttpQueryDataAvailable.\n",
                GetLastError( ) );

      // Allocate space for the buffer.
      pszOutBuffer = new char[dwSize+1];
      if( !pszOutBuffer )
      {
        printf( "Out of memory\n" );
        dwSize=0;
      }
      else
      {
        // Read the data.
        ZeroMemory( pszOutBuffer, dwSize+1 );

        if( !WinHttpReadData( hRequest, (LPVOID)pszOutBuffer, 
                              dwSize, &dwDownloaded ) )
          printf( "Error %u in WinHttpReadData.\n", GetLastError( ) );
        else
          printf( "%s", pszOutBuffer );

        // Free the memory allocated to the buffer.
        delete [] pszOutBuffer;
      }
    } while( dwSize > 0 );
  }


  // Report any errors.
  if( !bResults )
    printf( "Error %d has occurred.\n", GetLastError( ) );

  // Close any open handles.
  if( hRequest ) WinHttpCloseHandle( hRequest );
  if( hConnect ) WinHttpCloseHandle( hConnect );
  if( hSession ) WinHttpCloseHandle( hSession );