0

我正在按照本教程远程验证 Sharepoint Online,但我是在 C# 中进行的。

http://allthatjs.com/2012/03/28/remote-authentication-in-sharepoint-online/

我可以毫无问题地从 STS 获取 SAML,但我似乎无法将此令牌发送到 Sharepoint 以接收 Cookie 以便登录。下面是我的代码,请原谅任何明显的错误,我是新手!

 //Send cookie to SPO. The token is from STS.
        byte[] spbyteArray = Encoding.UTF8.GetBytes(theToken);
        WebRequest sprequest = WebRequest.Create("https://login.microsoftonline.com/login.srf?wa=wsignin1.0&rpsnv=2&ct=1335885737&rver=6.1.6206.0&wp=MBI&wreply=https%3A%2F%2Fcamida.sharepoint.com%2F_forms%2Fdefault.aspx&lc=1033&id=500046&cbcxt=mai&wlidp=1&guest=1");
        sprequest.Method = "POST";
        sprequest.ContentLength = spbyteArray.Length;
        sprequest.ContentType = "application/x-www-form-urlencoded";
        sprequest.Headers.GetType().InvokeMember("ChangeInternal", BindingFlags.NonPublic | BindingFlags.Instance | BindingFlags.InvokeMethod, null, sprequest.Headers, new object[] { "Host", "mydomain.sharepoint.com" });
        Stream spdataStream = sprequest.GetRequestStream();
        spdataStream.Write(spbyteArray, 0, spbyteArray.Length);
        spdataStream.Close();

        //Get response from SPO
        WebResponse spresponse = sprequest.GetResponse();
        spdataStream = spresponse.GetResponseStream();
        StreamReader spreader = new StreamReader(spdataStream);

        // Read the content.
        string spresponseFromServer = spreader.ReadToEnd();

如果我使用教程中的 URL,我会收到 403 禁止。我使用的 URL 是当我到达http://mydomain.sharepoint.com时它重定向到的 URL

非常感谢任何帮助和建议。

4

2 回答 2

3

从 SharePoint 请求时,您必须设置用户代理,否则它会返回 403 此行;

 sprequest.UserAgent = "Mozilla/5.0 (Windows NT 6.0; rv:12.0) Gecko/20100101 Firefox/12.0";

是不是都花了。

于 2012-05-02T16:23:15.513 回答
1

您似乎没有添加任何 cookie,这可能是必需的。如果将WebRequest转换为HttpWebRequest,则可以使用cookie。请参阅使用 WebBrowser cookie 的 c# WebRequest

此外,我会熟悉Fiddler 之类的工具,以检查您从浏览器发送的请求和响应。这使您可以准确地看到来回发送的内容,以便您可以尝试在 C# 中复制/模拟请求。

于 2012-05-01T16:51:16.097 回答