我正在将代码从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();我被拒绝访问。
谢谢
发布于 2016-05-25 11:54:58
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-08-12 17:10:54
您是否尝试过使用projContext.Credentials = System.Net.CredentialCache.DefaultNetworkCredentials;设置凭据
发布于 2016-05-25 11:49:46
您需要先登录到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;
}https://stackoverflow.com/questions/14961912
复制相似问题