LinkedIn oAuth RequestToken "401 Несанкционированный" - PullRequest
1 голос
/ 13 сентября 2011

Я пытаюсь получить RequestToken для API LinkedIn через oAuth. Я перепробовал множество вещей и прочитал всю документацию, связанную с этой темой, и последовательно попробовал все возможные решения.

Код, который я использую, выглядит следующим образом:

    public Dictionary<string, string> GetAccessToken()
    {

        Dictionary<string, string> tokens = new Dictionary<string, string>();
        string url = string.Format("https://api.linkedin.com/uas/oauth/requestToken");
        HttpWebRequest request = WebRequest.Create(url) as HttpWebRequest;

        string header = string.Format(@"OAuth oauth_nonce=""{0}"", oauth_signature_method=""{1}"", oauth_timestamp=""{2}"", oauth_consumer_key=""{3}"", oauth_signature=""{4}"", oauth_version=""{5}""",
        HttpUtility.UrlEncode(GenerateNonce()), HttpUtility.UrlEncode(getSignatureMethod()), HttpUtility.UrlEncode(GenerateTimeStamp()), HttpUtility.UrlEncode(getClientID()), HttpUtility.UrlEncode(getClientSecret()), HttpUtility.UrlEncode(getVersion()));

        request.Headers.Add("Authorization", header);
        request.Method = "POST";

        HRArtis_Security.MyProxy HRProxy = new HRArtis_Security.MyProxy();
        request.Proxy = HRProxy;
        using (HttpWebResponse response = request.GetResponse() as HttpWebResponse)
        {
            StreamReader reader = new StreamReader(response.GetResponseStream());
            string retVal = reader.ReadToEnd();

            foreach (string token in retVal.Split('&'))
            {
                tokens.Add(token.Substring(0, token.IndexOf("=")),
                    token.Substring(token.IndexOf("=") + 1, token.Length - token.IndexOf("=") - 1));
            }
        }
        return tokens;
    }

Затем я выполняю POST для этого URL. Ошибка возникает при попытке получить ответ со строкой HttpWebResponse response = request.GetResponse() as HttpWebResponse

Другой вариант, который я пробовал, - добавлять эти параметры в заголовок без результата.

Я что-то упускаю или идиот?

1 Ответ

0 голосов
/ 13 сентября 2011

Мне кажется, вы неправильно настроили заголовок oAuth. Я советую вам использовать библиотеку Hammock или RestSharp для авторизации с LinkedIn. Вот несколько примеров, как это сделать: Гамак и RestSharp (оба LinkedIn и Twitter используют oAuth v1.0).

...