JQuery AJAX Вызов для отправки данных на страницу ASP.Net(не Get POST)
У меня есть следующий вызов jQuery AJAX на страницу ASP.Net.
$.ajax({
async: true,
type: "POST",
url: "DocSummaryDataAsync.aspx", //"DocSummary.aspx/GetSummaryByProgramCount",
contentType: "application/json; charset=utf-8",
data: kendo.stringify({ vendorId: supplierId, businessUnit: busUnit, productSegmentId: prodSegmentId, programId: progId, productManagerId: prodManagerId, companyIds: compIds, expired: exp.toString(), requestType: 'TotalCount' }),
success: function (msg) {
// alert('in success of getcount');
},
error: function (XMLHttpRequest, textStatus, errorThrown) {
// alert('in failure of getcount');
}
});
Когда я пытаюсь извлечь из объекта Request, опубликованные данные, он не отображается.
Мой код страницы aspx приведен ниже. Я отправляю каждую опубликованную информацию в формате Json на страницу, но она не отображается на странице кода. Есть ли дополнительные настройки в jQuery ajax-вызове, который мне не хватает?
protected void Page_Load(object sender, EventArgs e)
{
Response.ContentType = "application/json";
string requestType = Request.Params["requestType"];
//populate variables from posted data
string vendorId = Request.Params["vendorId"];
string businessUnit = Request.Params["businessUnit"];
string productSegmentId = Request.Params["productSegmentId"];
string commitmentProgramId = Request.Params["programId"];
string productManagerId = Request.Params["productManagerId"];
string companyIds = Request.Params["companyIds"];
string expired = Request.Params["expired"];
}
ОБНОВЛЕНИЕ 1: Ответ Стивена - лучший подход к этому, особенно подход, который делает ProcessRequest. Тем не менее, я нашел небольшой трюк, который позволит публиковать данные в ASP.Net обычным образом, например, Request [ "vendorId" ] и т.д. Чтобы включить такую отправку данных из любого jQuery ajax-запроса, вам просто нужно убедитесь, что к вашему jQuery ajax-вызову применяются следующие 2 точки:
- Тип содержимого должен быть исключен из вашего jQuery ajax-вызова. Если вы хотите включить его, он должен не устанавливать "application/json; charset = utf-8", но "application/x-www-form-urlencoded; charset = UTF-8". Content-type, согласно моему пониманию, сообщает странице ASP.Net тип данных, которые отправляются, а не тип данных, которые ожидаются на странице.
- Часть данных jQuery ajax не должна содержать имена данных, заключенные в кавычки. Поэтому данные: { "venorId": "AD231", "businessUnit": "123" } должны быть заменены данными: {vendorId: "AD231", businessUnit: "123" }. В этом примере имена данных являются vendorId и businessUnit, к которым можно получить доступ в коде ASP.Net с использованием обычного синтаксиса ASP.Net, такого как Request [ "vendorId" ] и Request [ "businessUnit" ].
Ответы
Ответ 1
Вариант 1. Сохраняйте код на стороне сервера тем же самым
Сначала удалите файл kendo.stringify. Затем либо удалите contentType, либо измените его на...
"application/x-www-form-urlencoded; charset=utf-8"
... или измените ваш вызов $.ajax на следующее:
$.post('DocSummaryDataAsync.aspx', { vendorId: supplierId, businessUnit: busUnit, productSegmentId: prodSegmentId, programId: progId, productManagerId: prodManagerId, companyIds: compIds, expired: exp.toString(), requestType: 'TotalCount' }, function (data) { });
Вариант 2. Измените POST на GET
Подобно этому
$.ajax({
async: true,
type: "GET",
etc.
Это передаст ваши данные через QueryString. Если вы удалите вызов kendo.stringify, вы получите доступ ко всем таким значениям:
string vendorId = Request.QueryString[0];
string businessUnit = Request.QueryString[1];
etc.
Вариант 3. Используйте свой оригинальный вызов $.ajax
Если вы используете исходный $.ajax, то применяется следующее:
Request.Params получает "объединенную коллекцию элементов QueryString, Form, Cookies и ServerVariables". - эта ссылка
Вы не работаете ни с одним из них. Вместо этого вам нужно получить доступ к Request.InputStream.
Вот как вы можете это сделать:
Создайте класс на стороне сервера, который сопоставляется с запрошенным объектом JSON, например
public class MyClass
{
// The type (int or string) should probably correspond to the JSON
public int vendorId { get; set; }
public string businessUnit { get; set; }
public string productSegmentId { get; set; }
public string programId { get; set; }
public string productManagerId { get; set; }
public string companyIds { get; set; }
public string expired { get; set; }
public string requestType { get; set; }
}
Преобразуйте Request.InputStream в этот тип, а затем вы можете его использовать.
public void ProcessRequest()
{
System.IO.Stream body = Request.InputStream;
System.Text.Encoding encoding = Request.ContentEncoding;
System.IO.StreamReader reader = new System.IO.StreamReader(body, encoding);
string json = reader.ReadToEnd();
JavaScriptSerializer serializer = new JavaScriptSerializer();
MyClass myclass = (MyClass)serializer.Deserialize(json, typeof(MyClass));
int vendorId = myclass.vendorId;
string requestType = myclass.requestType;
// etc...
}
protected void Page_Load(object sender, EventArgs e)
{
ProcessRequest();
}