我的项目设置为使用天蓝色广告作为登录名(来自dotnet核心模板)。我已成功登录。
但是,我想使用相同的登录用户从 sharepoint rest api 中检索数据。
我有以下方法:
public async Task<FileResults> Test()
{
var siteUrl = "https://xxxxx.sharepoint.com";
var username = "xx@xx.no";
var password = "xxxxxx";
var securePassword = new SecureString();
password.ToCharArray().ToList().ForEach(c => securePassword.AppendChar(c));
var credentials = new SharePointOnlineCredentials(username, securePassword);
var handler = new HttpClientHandler();
handler.Credentials = credentials;
var uri = new Uri(siteUrl);
handler.CookieContainer.SetCookies(uri, credentials.GetAuthenticationCookie(uri));
var json = string.Empty;
using (var client = new HttpClient(handler))
{
client.DefaultRequestHeaders.Clear();
client.DefaultRequestHeaders.Add("Accept", "application/json;odata=verbose");
var response = await client.GetAsync(siteUrl + "/_api/Web/GetFolderByServerRelativeUrl('/Delte%20dokumenter/Test')/Files");
json = await response.Content.ReadAsStringAsync();
var result = Newtonsoft.Json.JsonConvert.DeserializeObject<Rootobject>(json);
var files = result.FileResults;
return files;
}
}
这工作正常,正在从sharepoint获取文档。 但是,这是在使用硬编码凭据时。如何通过Azure AD使用已登录用户的凭据?我是否要获取访问令牌?
答案 0 :(得分:0)
要使用Azure AD身份验证,您需要拥有Authentication flows之一。
注意:用户名/密码流为not recommended。
之后,将根据指定的范围获取令牌,并且需要单击Microsoft Graph Api,在内部,需要根据需要单击SharePoint API终结点。
您可以从sample
开始探索