将值传递给jQuery的Web服务调用?

时间:2011-04-05 12:50:06

标签: jquery web-services

我正在关注各种在线示例但没有取得任何成功。我只是想创建一个将值传递给Web服务调用的初始示例。

我做错了什么?

我可以用HttpHandlers轻松做到这一点......这个简单的东西不应该这么难吗?

更新:
它失败的原因是因为缺少“contentType”属性。这在following answer中列出。

以下是我不断获取的错误:

System.InvalidOperationException: Missing parameter: key.\r\n at System.Web.Services.Protocols.ValueCollectionParameterReader.Read(NameValueCollection collection)\r\n at System.Web.Services.Protocols.HtmlFormParameterReader.Read(HttpRequest request)\r\n at System.Web.Services.Protocols.HttpServerProtocol.ReadParameters()\r\n at System.Web.Services.Protocols.WebServiceHandler.CoreProcessRequest()

这是HTML:

<script type="text/javascript">

    var url = '<%=ResolveUrl("~/Services/ProjectDialog.asmx/TryThis")%>';

    function callWebService() {

        jQuery.ajax({
            cache: false,
            type: 'POST',
            complete: onComplete,
            data: '{ "key": 42 }',
            dataType: 'application/json; charset=utf-8',
            error: onError,
            success: onSuccess,
            url: url
        });
    }

    function onComplete(status, xmlHttpRequest) {
        var stop = "";
    }
    function onError(xmlHttpRequest, status, error) {
        var stop = "";
    }
    function onSuccess(data, status, xmlHttpRequest) {
        var stop = "";
    }

    jQuery(document).ready(function() {
    });

</script>

<input type="button" value="Run Web Service" onclick="callWebService();" />

这是网络服务:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Services;
using System.Web.Script.Serialization;

namespace My.Services
{
    /// <summary>
    /// Summary description for ProjectDialog
    /// </summary>
    [WebService(Namespace = "http://tempuri.org/")]
    [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
    [System.ComponentModel.ToolboxItem(false)]
    [System.Web.Script.Services.ScriptService]
    public class ProjectDialog : System.Web.Services.WebService
    {
         [WebMethod]
         [ScriptMethod(ResponseFormat = ResponseFormat.Json)]
         public string TryThis(Int32 key)
         {
             return key.ToString();
         }
    }
}

4 个答案:

答案 0 :(得分:4)

尝试替换以下行:

  

数据:'{“key”:42}',

使用:

  

data:JSON.stringify(data),

其中data是先前声明为:

的变量
  

var data = {key:42};

这取自以下答案:Calling .Net webservice with Jquery is causing woe when trying to post data

<强>已更新

上述建议不是问题,正如作者所指出的那样,问题结果是没有正确设置contentType。但是,上述链接确实指出了这一点。

答案 1 :(得分:1)

我认为您的问题在于如何设置数据参数,我认为您不需要引号:

data: ({ key: 42 }),

答案 2 :(得分:0)

我认为您的报价可能需要更改;

 data: '{ "key": 42 }',

应该是

data: "{ 'key': 42 }",

答案 3 :(得分:0)

您能否尝试GET并将“密钥”作为参数传递给网址?