2010-09-02 10 views
5

Estoy escribiendo una aplicación web para publicar automáticamente en Google Buzz.gdata header de autorización desconocida

Escribí una biblioteca C# para gestionar con "Oauth dance" y funciona bien, puedo obtener oauth_token y oauth_token_secret.

He utilizado www.googlecodesamples.com/oauth_playground/ para validar mi oauth_token y oauth_token_secret y funciona bien. Lo probé con GET y https://www.googleapis.com/buzz/v1/activities/@me/@self para obtener la transmisión del usuario, funciona.

pero ahora

que estoy tratando de hacer lo mismo usando mi biblioteca de C#, pero siempre me sale este error :

<?xml version="1.0" encoding="UTF-8"?> 
<errors xmlns="http://schemas.google.com/g/2005"> 
    <error> 
     <domain>GData</domain> 
     <code>invalid</code> 
     <location type="header">Authorization</location> 
     <internalReason>Unknown authorization header</internalReason> 
    </error> 
</errors> 

Mi encabezado de la solicitud es la misma de la de parque infantil.

Accept: */* 
Content-Type: application/atom+xml 
Authorization: OAuth oauth_version="1.0", oauth_nonce="9216320", 
oauth_timestamp="1283430867", oauth_consumer_key="www.mysite.com", 
oauth_token="1%2FZodlNmPP96GT11vYaWA0y6QoqKLqNqZ8bNmxknZZZc", 
oauth_signature_method="HMAC-SHA1", 
oauth_signature="Tuu82feKNWa4CxoDUyvtIEVODRA%3D" 
GData-Version: 2.0 

Aquí está el código C#:

string headAuth = "Authorization: OAuth oauth_version=\"1.0\", oauth_nonce=\"9216320\", oauth_timestamp=\"1283430867\", 
oauth_consumer_key=\"www.mysite.com\", oauth_token= 
\"1%2FZodlNmPP96GT11vYaWA0y6QoqKLqNqZ8bNmxknZZZc\", 
oauth_signature_method=\"HMAC-SHA1\", oauth_signature= 
\"Tuu82feKNWa4CxoDUyvtIEVODRA%3D\""; 

HttpWebRequest req1 =(HttpWebRequest)HttpWebRequest.Create("https://www.googleapis.com/buzz/v1/activities/@me/@self"); 
req1.Method = "GET"; 
req1.Accept = "*/*"; 
req1.ContentType = "application/atom+xml"; 
req1.Headers.Add("Authorization", headAuth); 
req1.Headers.Add("GData-Version", "2.0"); 

try 
{ 
    HttpWebResponse response1 =(HttpWebResponse)req1.GetResponse(); 
    using (var sr = new StreamReader(response1.GetResponseStream())) 
    { 
     string test_1 = sr.ReadToEnd(); 
    } 
} 
catch (WebException e) 
{ 
    Stream objStream = e.Response.GetResponseStream(); 
    StreamReader objStreamReader = new StreamReader(objStream); 
    string err = objStreamReader.ReadToEnd(); 
} 

Por qué con los mismos datos que funciona bien en el patio y no funciona en código C#? ¿Alguna idea de cómo solucionarlo?

Gracias, Stefano

+1

¿Lo resolvió usted? Porque estoy enfrentando el mismo problema con la API de aprovisionamiento. – JochenJung

Respuesta

0

Parece que va a agregar la autorización OAuth en su cabecera dos veces.

En la cadena de encabezado tiene string headAuth = "Authorization: OAuth y cuando agrega el encabezado a req1.Headers.Add("Authorization", headAuth); lo está agregando de nuevo.