jsonp调用webapi和mvc

webapi代码如下:

        public string Get(int id)
        {
            var callback = HttpContext.Current.Request["callback"];
            var u = new User { Name = "AA", Age = id };
            var result = new JavaScriptSerializer().Serialize(u);
            if (string.IsNullOrWhiteSpace(callback))
                return result;
            else
            {
                HttpContext.Current.Response.Write(string.Format("{0}({1})", callback, result));
                HttpContext.Current.Response.End();
            }
            return "";
        }

注:这种写法必须要用

HttpContext.Current.Response.Write方式返回,具体原因暂时不知道,如果直接返回,前台会请求成功,但是解析时会报错。

MVC写法如下:

        public string Index()
        {            
            var callback = Request["callback"];
            return string.Format("{0}({1})", callback, "{\"n\":111}");
        }

注:

callback是自定义的回调与jquery保持一致,具体为什么可以了解jsonp原理,也可以通过chrome的network瞅瞅交易的过程

html代码如下:
                $.ajax({
                    type: "get",
                    url: "http://localhost:21931/api/myapi/12311111",
                    dataType: "jsonp",
                    jsonp: "callback",
                    success: function (msg) {
                        jalert(JSON.stringify(msg));
                    },
                    error: function (a, b, c) {
                        jalert("error");
                    }
                });

 服务启动后,直接通过浏览器打开页面就可以获取到数据

转载于:https://www.cnblogs.com/wujf/p/5171114.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值