c# - JQuery Ajax 函数未在 DNN 中调用后端方法
问题描述
我无法让 DotNetNuke 从我的 JQuery Ajax 函数执行后端代码。我的 View.ascx 文件中有以下 JQuery 代码
我确实尝试将 URL 更改为 View.ascx/DeleteReviewData 但没有运气。
function deleteReview(ReviewID){
var ReviewIDToDelete = ReviewID;
$.ajax({
type: "POST",
contentType: "application/json",
url: "https://dnndev.me/Product-View/DeleteReviewData",
data: "{'deleteReviewID': '"+ ReviewIDToDelete +"'}",
datatype: "json",
success: function (data) {
alert("Delete successfull");
},
error: function (error) {
alert(error);
}
});
}
这是我没有在 View.ascx.cs 文件上执行的后端代码:
[System.Web.Services.WebMethod]
public static void DeleteReviewData(int deleteReviewID)
{
try
{
//Deletes a review from the database
using (SqlConnection connection = new SqlConnection(ConfigurationManager.ConnectionStrings["SiteSqlServer"].ToString()))
{
connection.Open();
using (SqlCommand command = new SqlCommand($"delete from ProductReviews where ReviewID = {deleteReviewID}"))
{
command.Connection = connection;
command.ExecuteNonQuery();
}
connection.Close();
}
}
catch(Exception ex)
{
throw;
}
}
如果我应该使用 MapHttpRoute。请问有人有例子吗?
我查看了以下帖子,但我不确定是否使用 RouteConfig.cs 和额外的标头等:https ://www.dnnsoftware.com/answers/execute-an-action-by-calling-an-ajax-post
我目前没有控制台错误。它进入成功部分。当我在调试时将鼠标悬停在 Type、ContentType 或其中任何一个上时,它说未定义。请参见下面的示例。该网站正在使用 JQuery 01.09.01
更新
我已经更改了现在给我一个 404 错误的 URL:url: $.fn.GetBaseURL() + 'DesktopModules/ProductDetailedView/DeleteReviewData'
我还通过添加 API 尝试了此 URL 路径API/DeleteReviewData
,但我收到 [object Object] 错误,因为它在控制台中显示 404 错误。
解决方案
这是一个例子:
$.ajax({
data: { "Id": IdToDelete },
type: "POST",
dataType: "json",
url: "/DesktopModules/{API-ProjectName}/API/Main/DeleteExpenseByID"
}).complete(function () {
//...
});
接口方法:
[HttpPost]
[DnnAuthorize]
public void DeleteExpenseByID(int Id)
{
//...
}
您需要发送一个数字,这样您就不需要 ReviewIDToDelete var 周围的“'”。
还要检查 [POST] 属性的 DeleteReviewData,它似乎是 [GET] 调用。
推荐阅读
- angular - 带有innerHTML的Angular 7反应式表单
- java - 如何将程序的输出写入excel表格
- sap-business-bydesign - SAP ByD in code Customer Invoice Request to Customer Invoice
- firebase - 当只有经过身份验证的用户可以阅读文档时,如何检查文档是否作为未经身份验证的用户存在于集合中
- java - GUAVA CACHE - 动态计算权重
- java - 无法从请求正文中读取
- javascript - 如何将我的 JSON 数据显示到 html 表中的另一个 html 页面?
- node.js - 从节点 API 中提取数据并保存输出
- mysql - 如果在另一个 tbale 中创建新行,如何创建新行?
- r - 用于比较具有相同 ID 的特定列的行之间的函数