使用 DotNetNuke DnnApiController 我无法使用 $http.post 命令检索 post 数据,但是 .ajax 有效
Using DotNetNuke DnnApiController I can't retrieve post data with an $http.post command but .ajax works
使用 angular,我正在尝试使用 $http.post:
将一些 post 数据发送到 DnnApiController
findit: function(onSuccess, onFailure,searchTerms) {
alert(JSON.stringify(searchTerms));
const rvtoken = $("input[name='__RequestVerificationToken']").val();
$http({
cache: false,
dataType: 'json',
url: "/DesktopModules/AdvancedProductSearchAPI/API/AdvancedProductSearchApi/DoAdvancedSearch",
method: "Post",
headers: {
"ModuleId": moduleId,
"TabId": tabId,
"RequestVerificationToken": rvtoken
},
data: { "": JSON.stringify(searchTerms) }
}).success(onSuccess).error(onFailure);
-----.ajax方法----
findit: function(onSuccess, onFailure,searchTerms) {
alert(JSON.stringify(searchTerms));
const rvtoken = $("input[name='__RequestVerificationToken']").val();
$.ajax({
cache: false,
dataType: 'json',
url: "/DesktopModules/AdvancedProductSearchAPI/API/AdvancedProductSearchApi/DoAdvancedSearch",
method: "Post",
headers: {
"ModuleId": moduleId,
"TabId": tabId,
"RequestVerificationToken": rvtoken
},
data: { "": JSON.stringify(searchTerms) }
}).success(onSuccess).error(onFailure);
更新2018/09/02
我试过这个:
$http.post("/DesktopModules/AdvancedProductSearchAPI/API/AdvancedProductSearchApi/DoAdvancedSearch3",
searchTerms,
{
headers: {
"ModuleId": moduleId,
"TabId": tabId,
"RequestVerificationToken": rvtoken
}
}).success(onSuccess).error(onFailure);
这是我正在调用的 DnnApiController 方法:
[AllowAnonymous]
[DotNetNuke.Web.Api.ValidateAntiForgeryToken]
public string DoAdvancedSearch([FromBody] string advancedSearchItems)
{
IList<SearchTerm> SearchTerms = JsonConvert.DeserializeObject<List<SearchTerm>>(advancedSearchItems);
return JsonConvert.SerializeObject(SearchTerms);
}
或
public string DoAdvancedSearch2([FromBody] IList<SearchTerm> SearchTerms)
{
//IList<SearchTerm> SearchTerms = JsonConvert.DeserializeObject<List<SearchTerm>>(advancedSearchItems);
return JsonConvert.SerializeObject(SearchTerms);
}
或
[HttpPost]
[AllowAnonymous]
[DotNetNuke.Web.Api.ValidateAntiForgeryToken]
[Route("doadvancedsearch3")]
public string DoAdvancedSearch3(IList<SearchTerm> SearchTerms)
{
//IList<SearchTerm> SearchTerms = JsonConvert.DeserializeObject<List<SearchTerm>>(advancedSearchItems);
return JsonConvert.SerializeObject(SearchTerms);
}
所有 api 都从 $http.post 命令触发,具体取决于我调用的 api。但是 $http.post 方法会导致 api 的参数 (advancedSearchItems) 为空,而 .ajax 方法在所有情况下都可以正常工作
我在 $http 方法中缺少什么?
我不确定这是否可以作为答案,但它确实有效:
$http(
{
url: "/DesktopModules/AdvancedProductSearchAPI/API/AdvancedProductSearchApi/DoAdvancedSearchANG",
data: JSON.stringify(searchTerms),
method: "post",
headers: {
"ModuleId": moduleId,
"TabId": tabId,
"RequestVerificationToken": rvtoken,
'Content-Type': 'application/json'
}
}).success(onSuccess).error(onFailure);
或
$http.post("/DesktopModules/AdvancedProductSearchAPI/API/AdvancedProductSearchApi/DoAdvancedSearchANG",
JSON.stringify(searchTerms),
{
headers: {
"ModuleId": moduleId,
"TabId": tabId,
"RequestVerificationToken": rvtoken,
"Content-Type': 'application/json"
}
}).success(onSuccess).error(onFailure);
API:
//this method works with AJAX
[HttpPost]
[AllowAnonymous]
[DotNetNuke.Web.Api.ValidateAntiForgeryToken]
public string DoAdvancedSearchAJAX([FromBody] string advancedSearchItems)
{
IList<SearchTerm> SearchTerms = JsonConvert.DeserializeObject<List<SearchTerm>>(advancedSearchItems);
return JsonConvert.SerializeObject(SearchTerms);
}
//This method works with AngularJS $http.post method
[HttpPost]
[AllowAnonymous]
[ValidateAntiForgeryToken]
public string DoAdvancedSearchANG(IList<SearchTerm> SearchTerms)
{
//IList<SearchTerm> SearchTerms = JsonConvert.DeserializeObject<List<SearchTerm>>(advancedSearchItems);
return JsonConvert.SerializeObject(SearchTerms);
}
我认为我尝试的所有事情(例如,)都是针对 Angular 的旧版本,我使它变得比需要的更复杂。
使用 angular,我正在尝试使用 $http.post:
将一些 post 数据发送到 DnnApiControllerfindit: function(onSuccess, onFailure,searchTerms) {
alert(JSON.stringify(searchTerms));
const rvtoken = $("input[name='__RequestVerificationToken']").val();
$http({
cache: false,
dataType: 'json',
url: "/DesktopModules/AdvancedProductSearchAPI/API/AdvancedProductSearchApi/DoAdvancedSearch",
method: "Post",
headers: {
"ModuleId": moduleId,
"TabId": tabId,
"RequestVerificationToken": rvtoken
},
data: { "": JSON.stringify(searchTerms) }
}).success(onSuccess).error(onFailure);
-----.ajax方法----
findit: function(onSuccess, onFailure,searchTerms) {
alert(JSON.stringify(searchTerms));
const rvtoken = $("input[name='__RequestVerificationToken']").val();
$.ajax({
cache: false,
dataType: 'json',
url: "/DesktopModules/AdvancedProductSearchAPI/API/AdvancedProductSearchApi/DoAdvancedSearch",
method: "Post",
headers: {
"ModuleId": moduleId,
"TabId": tabId,
"RequestVerificationToken": rvtoken
},
data: { "": JSON.stringify(searchTerms) }
}).success(onSuccess).error(onFailure);
更新2018/09/02 我试过这个:
$http.post("/DesktopModules/AdvancedProductSearchAPI/API/AdvancedProductSearchApi/DoAdvancedSearch3",
searchTerms,
{
headers: {
"ModuleId": moduleId,
"TabId": tabId,
"RequestVerificationToken": rvtoken
}
}).success(onSuccess).error(onFailure);
这是我正在调用的 DnnApiController 方法:
[AllowAnonymous]
[DotNetNuke.Web.Api.ValidateAntiForgeryToken]
public string DoAdvancedSearch([FromBody] string advancedSearchItems)
{
IList<SearchTerm> SearchTerms = JsonConvert.DeserializeObject<List<SearchTerm>>(advancedSearchItems);
return JsonConvert.SerializeObject(SearchTerms);
}
或
public string DoAdvancedSearch2([FromBody] IList<SearchTerm> SearchTerms)
{
//IList<SearchTerm> SearchTerms = JsonConvert.DeserializeObject<List<SearchTerm>>(advancedSearchItems);
return JsonConvert.SerializeObject(SearchTerms);
}
或
[HttpPost]
[AllowAnonymous]
[DotNetNuke.Web.Api.ValidateAntiForgeryToken]
[Route("doadvancedsearch3")]
public string DoAdvancedSearch3(IList<SearchTerm> SearchTerms)
{
//IList<SearchTerm> SearchTerms = JsonConvert.DeserializeObject<List<SearchTerm>>(advancedSearchItems);
return JsonConvert.SerializeObject(SearchTerms);
}
所有 api 都从 $http.post 命令触发,具体取决于我调用的 api。但是 $http.post 方法会导致 api 的参数 (advancedSearchItems) 为空,而 .ajax 方法在所有情况下都可以正常工作 我在 $http 方法中缺少什么?
我不确定这是否可以作为答案,但它确实有效:
$http(
{
url: "/DesktopModules/AdvancedProductSearchAPI/API/AdvancedProductSearchApi/DoAdvancedSearchANG",
data: JSON.stringify(searchTerms),
method: "post",
headers: {
"ModuleId": moduleId,
"TabId": tabId,
"RequestVerificationToken": rvtoken,
'Content-Type': 'application/json'
}
}).success(onSuccess).error(onFailure);
或
$http.post("/DesktopModules/AdvancedProductSearchAPI/API/AdvancedProductSearchApi/DoAdvancedSearchANG",
JSON.stringify(searchTerms),
{
headers: {
"ModuleId": moduleId,
"TabId": tabId,
"RequestVerificationToken": rvtoken,
"Content-Type': 'application/json"
}
}).success(onSuccess).error(onFailure);
API:
//this method works with AJAX
[HttpPost]
[AllowAnonymous]
[DotNetNuke.Web.Api.ValidateAntiForgeryToken]
public string DoAdvancedSearchAJAX([FromBody] string advancedSearchItems)
{
IList<SearchTerm> SearchTerms = JsonConvert.DeserializeObject<List<SearchTerm>>(advancedSearchItems);
return JsonConvert.SerializeObject(SearchTerms);
}
//This method works with AngularJS $http.post method
[HttpPost]
[AllowAnonymous]
[ValidateAntiForgeryToken]
public string DoAdvancedSearchANG(IList<SearchTerm> SearchTerms)
{
//IList<SearchTerm> SearchTerms = JsonConvert.DeserializeObject<List<SearchTerm>>(advancedSearchItems);
return JsonConvert.SerializeObject(SearchTerms);
}
我认为我尝试的所有事情(例如,)都是针对 Angular 的旧版本,我使它变得比需要的更复杂。