繁体   English   中英

使用 MS Graph 站点 API 和 C# 时出现内部服务器错误

[英]Internal Server Error while using MS Graph Site API with C#

我正在尝试使用图形 API 在 SharePoint 上搜索文件。 Microsoft graph-explorer上获得正确的结果,但是当我尝试使用 C# 时出现错误Status Code: 500 Reason Phrase:Internal Server Error

回复详情如下:

{
"error": {
 "code": "System.NullReferenceException",
 "message": "Object reference not set to an instance of an object.",
 "innerError": {
  "date": "2021-03-19T16:16:28",
  "request-id": "f3092cda-b813-4507-928e-7e2de84fc88f",
  "client-request-id": "f3092cda-b813-4507-928e-7e2de84fc88f"
  }
 }
}

C# 我正在使用的代码

var searchTerm = "164377_07323_03122021_112659_TaxApp";
var headerStr = @"{{""requests"": [{{""entityTypes"": [""listItem""],""query"": {{""queryString"": ""{0}""}}}}]}}";
headerStr = string.Format(headerStr, searchTerm);
var headerJson = JsonConvert.SerializeObject(headerStr);
httpClient.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Bearer", authResponse.AccessToken);
var content = new StringContent(headerJson, Encoding.UTF8, "application/json");
HttpResponseMessage response = httpClient.PostAsync("https://graph.microsoft.com/v1.0/search/query", content).Result;
var postResult = response.Content.ReadAsStringAsync().Result;

任何指示我哪里出错了?

尝试使用下面的代码。 看起来您的代码被序列化了两次。 所以我只是删除了序列化步骤并且它起作用了。

var searchTerm = "164377_07323_03122021_112659_TaxApp";
var headerStr = @"{{""requests"": [{{""entityTypes"": [""listItem""],""query"": {{""queryString"": ""{0}""}}}}]}}";
headerStr = string.Format(headerStr, searchTerm);
httpClient.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Bearer", authResponse.AccessToken);
var content = new StringContent(headerStr, Encoding.UTF8, "application/json");
HttpResponseMessage response = httpClient.PostAsync("https://graph.microsoft.com/v1.0/search/query", content).Result;
var postResult = response.Content.ReadAsStringAsync().Result;

您始终可以使用fiddler测试 API 请求。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM