我正在将代码从2010年迁移到2013年。
我在Sharepoint中部署了一个调用PSI的用户控件。2010年,它运行良好。现在在2013年和Claims身份验证中,当我与任何用户(甚至是项目管理员)一起调用任何PSI(甚至是GetCurrentUserUid)时,我总是会得到:"HTTP请求未经授权,客户端身份验证方案为'Ntlm'。从服务器收到的身份验证标头为'Ntlm,Negotiate'。"。
看起来这些证书没有传递给PSI,它称它们为匿名的。有人能帮忙吗?
我从Sharepoint执行的另一个代码示例:
ProjectContext projContext = new ProjectContext(PROJECT_SERVER_URL);
projContext.Load(projContext.EnterpriseResources);
projContext.ExecuteQuery();
我被拒绝访问。
感谢
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;
}
您是否尝试使用projContext.Credentials = System.Net.CredentialCache.DefaultNetworkCredentials;
您需要首先登录到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;
}