来自Sharepoint 2013的Project Server 2013 PSI调用

时间:2013-02-19 16:05:26

标签: sharepoint-2013 psi ms-project-server-2013

我正在从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();

我被拒绝访问。

由于

3 个答案:

答案 0 :(得分: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;
    }

答案 1 :(得分:0)

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

答案 2 :(得分:-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;
}