我正在从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();
我被拒绝访问。
由于
答案 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;
}