我们创建了一个Web api,并尝试使用该API从ajax发布数据。当我尝试使用邮递员插件时,Web API 适用于 POST 请求,但当我们使用 JSON 数据通过 Ajax 调用发布时不起作用。
我们收到XMLHttpRequest无法加载 http://localhost:922/api/leaddetails/createlead 的错误。预检响应具有无效的 HTTP 状态代码 400
这是 ajax 调用代码:
function SaveLead() {
var Lead = {
"lead_owner": "Pritam",
"company_name": "C",
"title": "T",
"first_name": "Santosh",
"last_name": "M",
"address1": "Rajasthan",
"address2": "d",
"city": "d",
"state": "d",
"country": "d",
"postal_code": "d",
"email": "vaya@gmail.com",
"phone": "d",
"website": "d",
"mobile": "8787878787",
"lead_status": "d",
"lead_source": "d",
"industry": "d",
"annual_revenue": "d",
"skype_id": "d",
"campaign_source": "d",
"description": "d",
"created_by": "A",
"updated_by": "a"
};
$.ajax({
type: "POST",
contentType: "application/json",
url: 'http://localhost:922/api/leaddetails/createlead',
data: JSON.stringify(Lead),
crossOrigin: true,
dataType: "json",
success: function (res) {
alert("The result is : " + res);
},
error: function (xhr) {
alert(xhr.responseText);
}
})
}
这是我的web.config文件:
<handlers>
<remove name="WebDAV"/>
<remove name="OPTIONSVerbHandler" />
<remove name="TRACEVerbHandler" />
<remove name="ExtensionlessUrlHandler-ISAPI-4.0_32bit" />
<remove name="ExtensionlessUrlHandler-ISAPI-4.0_64bit" />
<remove name="ExtensionlessUrlHandler-Integrated-4.0" />
<add name="ExtensionlessUrlHandler-ISAPI-4.0_32bit" path="*." verb="GET,HEAD,POST,DEBUG,PUT,DELETE,PATCH,OPTIONS" modules="IsapiModule" scriptProcessor="%windir%Microsoft.NETFrameworkv4.0.30319aspnet_isapi.dll" preCondition="classicMode,runtimeVersionv4.0,bitness32" responseBufferLimit="0" />
<add name="ExtensionlessUrlHandler-ISAPI-4.0_64bit" path="*." verb="GET,HEAD,POST,DEBUG,PUT,DELETE,PATCH,OPTIONS" modules="IsapiModule" scriptProcessor="%windir%Microsoft.NETFramework64v4.0.30319aspnet_isapi.dll" preCondition="classicMode,runtimeVersionv4.0,bitness64" responseBufferLimit="0" />
<add name="ExtensionlessUrlHandler-Integrated-4.0" path="*." verb="GET,HEAD,POST,DEBUG,PUT,DELETE,PATCH,OPTIONS" type="System.Web.Handlers.TransferRequestHandler" preCondition="integratedMode,runtimeVersionv4.0" />
<add name="OPTIONSVerbHandler" path="*" verb="OPTIONS" modules="ProtocolSupportModule" requireAccess="None" responseBufferLimit="4194304" />
</handlers>
<httpProtocol>
<customHeaders>
<add name="Access-Control-Allow-Origin" value="*" />
<add name="Access-Control-Allow-Headers" value="Content-Type, Accept" />
<add name="Access-Control-Allow-Methods" value="GET, POST, PUT, DELETE, OPTIONS" />
</customHeaders>
</httpProtocol>
我尝试从邮递员插件发布。从那里它完美地发布数据。
终于从朋友那里得到了答案。我不知道这是不是解决方案,但更改 ajax 语法对我有用。
var apiurl = 'http://localhost:922/api/leaddetails/createlead';
var a = new XMLHttpRequest();
function SaveLead() {
var Lead = {
"lead_owner": "Pritam",
"company_name": "C",
"title": "T",
"first_name": "Sourav",
"last_name": "M",
"address1": "Bhilai",
"address2": "d",
"city": "d",
"state": "d",
"country": "d",
"postal_code": "d",
"email": "vaya@gmail.com",
"phone": "d",
"website": "d",
"mobile": "8787878787",
"lead_status": "d",
"lead_source": "d",
"industry": "d",
"annual_revenue": "d",
"skype_id": "d",
"campaign_source": "d",
"description": "d",
"created_by": "A",
"updated_by": "a"
};
a.open('POST',apiurl,true),
$.ajax({
url: apiurl,
type: "POST",
ContentType: "application/json; charset=utf-8",
data: Lead,
crossOrigin: true,
dataType: "json",
cache: false,
complete: function (res) {
alert("Data Added Successfully");
},
error: function (xhr) {
alert("Error");
}
})
}
谢谢大家的回复。