码迷,mamicode.com
首页 > Web开发 > 详细

JSONP调用MVC后台接口

时间:2016-01-29 15:56:21      阅读:482      评论:0      收藏:0      [点我收藏+]

标签:

JSONP前台调用代码:

1、Jquery第一种方式:

技术分享
 $.ajax({
                "url": "http://localhost:59403/api/Login",    //url自行设定
                "type": "get",
                "timeout": 1000,
                "async": false,
                "data": {
                    "userName": txtName,
                    "pwd": txtPwd
                },
                "dataType": "jsonp",
                "jsonp": "CallBackFun_Key",    //这是告诉后台:我的【回调函数】这个参数的key(其实就是回调函数的名字的名字,干!)
                "jsonpCallback": "CallBackFun_Name",    //这是告诉后台:我的【回调函数】这个参数的value(其实就是回调函数的名字)
                "success": function (data) {
                    alert("success:" + data);
                },
                "error": function (XMLHttpRequest, textStatus, errorThrown) {
                    switch (XMLHttpRequest.readyState) {
                        case 0:
                            //(未初始化)还没有调用send()方法
                            break;
                        case 1:
                            //(载入)已调用send()方法,正在发送请求
                            break;
                        case 2:

                            //(载入完成)send()方法执行完成,已经接收到全部响应内容
                            break;
                        case 3:
                            //(交互)正在解析响应内容
                            break;
                        case 4:
                            //(完成)响应内容解析完成,可以在客户端调用了
                            break;
                    }
                    alert("Exception");
                }
            });
View Code

 2、Jquery第二种方式:

$.getJSON("http://localhost:59403/api/Orgs?jsonpcallback=?",
            function (json) {
                alert(json[0].OrgId);
  }

 .net 后台程序

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using LionTravel.LionTalk.ApiServer.Common;
using System.Net.Http;
using System.Text;

     //后台创建如下方法:
        public HttpResponseMessage Get(string userName, string pwd)
        {
            //控制器捕获到的请求参数,默认下标为0的,是回调函数的信息:{key:value} ==> {ajax中jsonp参数 : ajax中jsonpCallback参数}
            string ClientCallBackFunName = this.Request.GetQueryNameValuePairs().ToList()[0].Value;
            //拼接返回参数
            HttpResponseMessage result = new HttpResponseMessage
            {
                //这里回调函数直接用上方获取的变量
                Content = new StringContent(ClientCallBackFunName + "(1000)",
                    Encoding.GetEncoding("UTF-8"), "application/json")
            };

            return result;
        }

 

JSONP调用MVC后台接口

标签:

原文地址:http://www.cnblogs.com/zhangweidong/p/5168832.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!