使用jquery Ajax调用WCF服务失败,错误的请求响应

时间:2020-07-14 11:23:31

标签: javascript jquery ajax wcf iis

调用wcf Web服务使用jquery-Ajax失败,请求失败,却不知道确切的问题。 它甚至都没有称任何方法成功或失败。 使用iis将Web服务和网站都部署在同一服务器上

错误:

Failed to load resource: the server responded with a status of 400 (Bad Request)

该代码用于调用服务方法:

function test(){
     try {

       
        code = getValuesWrittenInTheURL[0] + "";

       
        var query = "select taskstatus,tasksubstatus,Lat,Lng,elementID from tasks_gvt where code = '" + code + "'";
        
        $.ajax({
            type: "POST",
            async: true,
            url: IP + "/GetData", 
            data: JSON.stringify({ Query: query }),
            dataType: "json",
            success: function (data) {
                debugger;
                console.log("data: ",data);
           
            },
            failure: function (errMsg) {
                debugger;
                console.log("err",errMsg);
                
            }
           
        });
    } catch (error) {
        console.log("alaaError", error.message);
    }
    
}

WCF Web服务运营合同:

 [WebInvoke(Method = "POST", RequestFormat = WebMessageFormat.Json, UriTemplate = "GetData", BodyStyle = WebMessageBodyStyle.WrappedRequest)]
        Response GetData(String Query);

准备为您提供更多详细信息。

1 个答案:

答案 0 :(得分:1)

下面是我成功访问该服务的Ajax,您可以参考它:

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>Ajax</title>
    <script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js">
    </script>
    <script>
$(document).ready(function(){
    $("button").click(function () {
        code = "code";
        var query = "select taskstatus,tasksubstatus,Lat,Lng,elementID from tasks_gvt where code = '" + code + "'";
        da={"Query":query}
        $.ajax({
            type: "Post",
            dataType: "json",
           contentType: "application/json;charset=utf-8",
           data: JSON.stringify(da),
            url: "http://localhost/Service1.svc/GetData", success: function (result) {
        }});
    });
});
    </script>
</head>
<body>


    <button>Call WCF Rest Service</button>

</body>
</html>

您需要设置contentType,我看到您将BodyStyle设置为Wrapped,如果将其设置为Wrapped,则请求格式应如下所示:

{"Query":query}