2015-12-21 7 views
15

Ich habe viele für die Azure-Verwaltungs-APIs, die mit dem folgenden Code funktionieren, mit Ausnahme der GetRole für virtuelle Maschinen. Hier ist die doc für diese API-Aufruf: https://msdn.microsoft.com/en-us/library/azure/jj157193.aspxRole abrufen - Azure-API gibt (400) zurück Bad Request

Hier ist der Code, den ich auszuführen versuche:

static void Main(string[] args) 
     { 
      Program p = new Program(); 
      p.MakeRequest(); 
     } 

     public void MakeRequest() 
     { 
      string strThumbprint = "{thumbprint}"; 
      X509Certificate2 certificate = GetStoreCertificate(strThumbprint); 
      string strRequestURI = "https://management.core.windows.net/{subscription}/services/hostedservices/{cloud-service}/deployments/{deployment}/roles/{rolename}"; 
      HttpWebRequest request = (HttpWebRequest)HttpWebRequest.Create(strRequestURI); 
      request.ClientCertificates.Add(certificate); 
      request.ContentType = "application/xml"; 
      request.Headers.Add("x-ms-version", "2015-04-01"); 
      try 
      { 
      HttpWebResponse response = (HttpWebResponse)request.GetResponse(); 
      Console.WriteLine("Status Code: " + response.StatusCode.ToString()); 
      Stream receiveStream = response.GetResponseStream(); 
      Encoding encode = Encoding.GetEncoding("utf-8"); 
      StreamReader readStream = new StreamReader(receiveStream, encode); 
      Console.WriteLine(readStream.ReadToEnd()); 
      response.Close(); 
      } 
      catch(Exception ex) 
      { 
       Console.WriteLine("Error: " + ex.Message); 
      } 

     } 

     private static X509Certificate2 GetStoreCertificate(string thumbprint) 
     { 
      List<StoreLocation> locations = new List<StoreLocation> 
      { 
       StoreLocation.CurrentUser, 
       StoreLocation.LocalMachine 
      }; 

      foreach (var location in locations) 
      { 
       X509Store store = new X509Store("My", location); 
       try 
       { 
        store.Open(OpenFlags.ReadOnly | OpenFlags.OpenExistingOnly); 
        X509Certificate2Collection certificates = store.Certificates.Find(
         X509FindType.FindByThumbprint, thumbprint, false); 
        if (certificates.Count == 1) 
        { 
         return certificates[0]; 
        } 
       } 
       finally 
       { 
        store.Close(); 
       } 
      } 
      throw new ArgumentException(string.Format(
       "A Certificate with Thumbprint '{0}' could not be located.", 
       thumbprint)); 
     } 

EDIT: Ich habe jetzt die URL fest, aber ich erhalte 400 - Bad Request.

+0

Können Sie hier neben dem Statuscode auch die Fehlermeldung posten? – juvchan

+0

Die Nachricht, die ich erhalte, lautet: "Der Remote-Server hat einen Fehler zurückgegeben: (404) Not Found." – Jeremy

+0

400 - Ungültige Anforderung, Die von Ihnen gesendete HTTP-Nachricht ist fehlerhaft. Es könnte verschiedene Gründe dafür geben. Verfolgen Sie mit dem Webkonsolen-Debugger? – Ian

Antwort

0

Nach dem Code, den ich zuvor gepostet habe, konnte ich dies mithilfe des Cloud-Dienstnamens als Bereitstellung ausführen. Es scheint, dass Microsoft Probleme mit ihrer Terminologie für die MSDN-Dokumentation und was auf dem Azure-Portal ist.