1

我正在将代码从 2010 年迁移到 2013 年。

我在 Sharepoint 中部署了一个调用 PSI 的用户控件。2010 年,它运作良好。现在在 2013 年和声明身份验证中,我总是得到:“HTTP 请求未经客户端身份验证方案'Ntlm' 的授权。从服务器收到的身份验证标头是'NTLM,Negotiate'。” 当我与任何用户(甚至项目管理员)调用任何 PSI(甚至 GetCurrentUserUid)时。

看起来凭据没有传递给 PSI,它称它们为匿名。任何人都可以帮忙吗?

我从 Sharepoint 执行的另一个代码示例:

ProjectContext projContext = new ProjectContext(PROJECT_SERVER_URL);
projContext.Load(projContext.EnterpriseResources);
projContext.ExecuteQuery();

我被拒绝访问。

谢谢

4

3 回答 3

0
    public static ProjectContext GetContext()
    {
        ProjectContext projContext;
        using (projContext = new ProjectContext("pwaUrl"))
        {
            SecureString passWord = new SecureString();

            foreach (char c in "YourEmailPassword".ToCharArray()) passWord.AppendChar(c);

            projContext.Credentials = new SharePointOnlineCredentials("YourEmail", passWord);
        }
        return projContext;
    }
于 2016-05-25T03:54:57.833 回答
0

您是否尝试过使用设置凭据 projContext.Credentials = System.Net.CredentialCache.DefaultNetworkCredentials;

于 2016-08-12T09:10:53.943 回答
-1

您需要先登录到 SharePoint。下面的内容将为您提供有效的上下文。

public static ProjectContext GetContext()
{
    ProjectContext projContext;
    using (projContext = new ProjectContext("pwaUrl"]))
    {
        SecureString passWord = new SecureString();

        foreach (char c in "yourPassword".ToCharArray()) passWord.AppendChar(c);

        projContext.Credentials = new SharePointOnlineCredentials("youremailaddress", passWord);
    }
    return projContext;
}
于 2016-05-25T03:49:46.477 回答