CredentialCache.GetCredential Metodo

Definizione

Restituisce un'istanza NetworkCredential associata a un URI o a un URI (Uniform Resource Identifier) specificato e al tipo di autenticazione.

Overload

Nome Descrizione
GetCredential(Uri, String)

Restituisce l'istanza NetworkCredential associata al tipo di autenticazione e all'URI (Uniform Resource Identifier) specificati.

GetCredential(String, Int32, String)

Restituisce l'istanza NetworkCredential associata all'host, alla porta e al protocollo di autenticazione specificati.

GetCredential(Uri, String)

Restituisce l'istanza NetworkCredential associata al tipo di autenticazione e all'URI (Uniform Resource Identifier) specificati.

public:
 virtual System::Net::NetworkCredential ^ GetCredential(Uri ^ uriPrefix, System::String ^ authType);
public System.Net.NetworkCredential GetCredential(Uri uriPrefix, string authType);
abstract member GetCredential : Uri * string -> System.Net.NetworkCredential
override this.GetCredential : Uri * string -> System.Net.NetworkCredential
Public Function GetCredential (uriPrefix As Uri, authType As String) As NetworkCredential

Parametri

uriPrefix
Uri

Oggetto Uri che specifica il prefisso URI delle risorse a cui le credenziali concedono l'accesso.

authType
String

Schema di autenticazione usato dalla risorsa denominata in uriPrefix.

Valori restituiti

Oppure NetworkCredential , se nella cache non sono presenti credenziali corrispondenti, null.

Implementazioni

Eccezioni

uriPrefix o authType è null.

Esempio

Nell'esempio di codice seguente viene usato il GetCredential(Uri, String) metodo per restituire l'istanza NetworkCredential associata all'URI e al tipo di autenticazione specificati.

  public static void GetPage(string url,string userName,string password,string domainName)
  {
      try
      {
          CredentialCache myCredentialCache = new CredentialCache();
          // Dummy names used as credentials.
          myCredentialCache.Add(new Uri("http://microsoft.com/"),"Basic", new NetworkCredential("user1","passwd1","domain1"));
          myCredentialCache.Add(new Uri("http://msdn.com/"),"Basic", new NetworkCredential("user2","passwd2","domain2"));
          myCredentialCache.Add(new Uri(url),"Basic", new NetworkCredential(userName,password,domainName));
          // Create a webrequest with the specified url.
       WebRequest myWebRequest = WebRequest.Create(url);
          // Call 'GetCredential' to obtain the credentials specific to our Uri.
          NetworkCredential myCredential = myCredentialCache.GetCredential(new Uri(url),"Basic");
          Display(myCredential);
       // Associating only our credentials.
          myWebRequest.Credentials = myCredential;
          // Sends the request and waits for response.
       WebResponse myWebResponse = myWebRequest.GetResponse();

          // Process response here.

       Console.WriteLine("\nResponse Received.");
          myWebResponse.Close();
      }
      catch(WebException e)
      {
          if (e.Response != null)
              Console.WriteLine("\r\nFailed to obtain a response. The following error occurred : {0}",((HttpWebResponse)(e.Response)).StatusDescription);
          else
              Console.WriteLine("\r\nFailed to obtain a response. The following error occurred : {0}",e.Status);
      }
      catch(Exception e)
      {
          Console.WriteLine("\nThe following exception was raised : {0}",e.Message);
      }
}
public static void Display(NetworkCredential credential)
{
  Console.WriteLine("\nThe credentials are:");
  Console.WriteLine("\nUsername : {0} ,Password : {1} ,Domain : {2}",credential.UserName,credential.Password,credential.Domain);
}
Public Shared Sub GetPage(url As String, userName As String, password As String, domainName As String)
    Try
        Dim myCredentialCache As New CredentialCache()
        ' Dummy names used as credentials    
        myCredentialCache.Add(New Uri("http://microsoft.com/"), "Basic", New NetworkCredential("user1", "passwd1", "domain1"))
        myCredentialCache.Add(New Uri("http://msdn.com/"), "Basic", New NetworkCredential("user2", "passwd2", "domain2"))
        myCredentialCache.Add(New Uri(url), "Basic", New NetworkCredential(userName, password, domainName))
        ' Creates a webrequest with the specified url. 
        Dim myWebRequest As WebRequest = WebRequest.Create(url)
        ' Call 'GetCredential' to obtain the credentials specific to our Uri.
        Dim myCredential As NetworkCredential = myCredentialCache.GetCredential(New Uri(url), "Basic")
        Display(myCredential)
        myWebRequest.Credentials = myCredential 'Associating only our credentials            
        ' Sends the request and waits for response.
        Dim myWebResponse As WebResponse = myWebRequest.GetResponse()
        ' Process response here.
        Console.WriteLine(ControlChars.Cr + "Response Received.")
        myWebResponse.Close()

    Catch e As WebException
        If Not (e.Response Is Nothing) Then
            Console.WriteLine(ControlChars.Lf + ControlChars.Cr + "Failed to obtain a response. The following error occurred : {0}", CType(e.Response, HttpWebResponse).StatusDescription)
        Else
            Console.WriteLine(ControlChars.Lf + ControlChars.Cr + "Failed to obtain a response. The following error occurred : {0}", e.Status)
        End If
    Catch e As Exception
        Console.WriteLine(ControlChars.Cr + "The following exception was raised : {0}", e.Message)
    End Try
End Sub

Public Shared Sub Display(ByVal credential As NetworkCredential)
    Console.WriteLine("The credentials are: ")
    Console.WriteLine(ControlChars.Cr + "Username : {0} ,Password : {1} ,Domain : {2}", credential.UserName, credential.Password, credential.Domain)
End Sub

Commenti

Il GetCredential(Uri, String) metodo cerca nell'oggetto CredentialCache e restituisce l'istanza per l'URI NetworkCredential e il tipo di autorizzazione specificati. Se l'oggetto non contiene un'istanza CredentialCache corrispondente NetworkCredential , null viene restituito .

GetCredential usa il prefisso URI corrispondente più lungo nella cache per determinare quale set di credenziali restituire per un tipo di autorizzazione. Nella tabella seguente sono illustrati alcuni esempi.

Prefisso URI Matches
http://www.contoso.com/portal/news.htm Richieste per la pagina news.htmWeb specifica.
http://www.contoso.com/portal/ Richiede tutto il portal contenuto nel percorso, ad eccezione della pagina news.htm.
http://www.contoso.com/ Richieste per tutte le risorse in www.contoso.com, ad eccezione di quelle nel portal percorso.

Si applica a

GetCredential(String, Int32, String)

Restituisce l'istanza NetworkCredential associata all'host, alla porta e al protocollo di autenticazione specificati.

public:
 virtual System::Net::NetworkCredential ^ GetCredential(System::String ^ host, int port, System::String ^ authenticationType);
public System.Net.NetworkCredential GetCredential(string host, int port, string authenticationType);
abstract member GetCredential : string * int * string -> System.Net.NetworkCredential
override this.GetCredential : string * int * string -> System.Net.NetworkCredential
Public Function GetCredential (host As String, port As Integer, authenticationType As String) As NetworkCredential

Parametri

host
String

Oggetto String che identifica il computer host.

port
Int32

Oggetto Int32 che specifica la porta a cui connettersi in host.

authenticationType
String

Oggetto String che identifica lo schema di autenticazione utilizzato per la connessione a host.

Valori restituiti

Oppure NetworkCredential , se nella cache non sono presenti credenziali corrispondenti, null.

Implementazioni

Eccezioni

host è null.

oppure

authenticationType è null.

authenticationType non è un valore accettato.

oppure

host è uguale alla stringa vuota ("").

port è minore di zero.

Commenti

Questo metodo cerca nell'oggetto CredentialCache e restituisce l'istanza per l'host, la NetworkCredential porta e il tipo di autorizzazione specificati. I hostvalori , porte passati a questo metodo non fanno distinzione tra maiuscole e authenticationType minuscole rispetto ai valori specificati quando la credenziale è stata aggiunta a CredentialCache utilizzando i Add metodi .

I valori supportati per authenticationType sono "NTLM", "Digest", "Kerberos" e "Negotiate".

Si applica a