Ajax跨域Post方法调用Web Api(NuGet配置的环境)
没安装
的去NuGet安装,
然后安装
,
建立Web Api项目.需要在
里的WebApiConfig.cs里配置
 config.EnableSystemDiagnosticsTracing(); //感觉这句像是跨域的开关,
            //配置返回的时间类型数据格式  ,返回Json格式的数据,并且加入时间类型的格式
            GlobalConfiguration.Configuration.Formatters.JsonFormatter.SerializerSettings.Converters.Add(
                new Newtonsoft.Json.Converters.IsoDateTimeConverter()
                {
                    DateTimeFormat = "yyyy-MM-dd hh:mm:ss"
                }
            );

并且在Web.Config里加入
<httpProtocol>
      <customHeaders>
        <add name="Access-Control-Allow-Origin" value="*" />
        <add name="Access-Control-Allow-Headers" value="Content-Type" />
        <add name="Access-Control-Allow-Methods" value="GET, POST, PUT, DELETE, OPTIONS" />
      </customHeaders>
    </httpProtocol>
    <modules runAllManagedModulesForAllRequests="true" />
位置

总体来说就可以跨域了.
实验下写个小Demo
自己新建个控制器,
自己弄点儿东西,
public class TryApiController : ApiController
{
[HttpPost]
public ResponseData MethodMapping([FromBody] RequestData requestData)
{
if (requestData.ActionCode != null && requestData.ActionCode != "")
{
string command = requestData.ActionCode;
System.Reflection.MethodInfo method = this.GetType().GetMethod(command);
if (method != null)
{
return (ResponseData)method.Invoke(this, new object[] { requestData.RequertParams });
}
else
return new ResponseData() { ErrorMsg = "请求函数名<ActionCode>不能为空", RequestStatus = "FAIL", ResponseEntity = null };
}
else
{
return new ResponseData() { ErrorMsg = "请求函数名<ActionCode>不能为空", RequestStatus = "FAIL", ResponseEntity = null };
}
} public ResponseData TheApi(string str)
{
ResponseData rd = new ResponseData();
rd.ResponseEntity = str;
return rd;
}
}
}
public class ResponseData
{
public string RequestStatus { get; set; }
public string ErrorMsg { get; set; }
public string ResponseEntity { get; set; }
}
public class RequestData
{
public string ActionCode { get; set; }
public string RequertParams { get; set; }
}
这是传入一个类,第一个参数是要求调用TheApi函数, 第二个参数是给被调用的函数传入的参数,
然后写个Ajax调用,
 Ajax: function (url, data, success, error) {
        if (error) {
            $.ajax({
                type: "Post",
                url: url,
                dataType: "json",
                data: data,
                success: success,
                //error: error
            });
        } else {
            $.ajax({
                type: "Post",
                url: url,
                dataType: "json",
                data: data,
                success: success,
                error: function (XmlHttpRequest, textStatus, errorThrown) {
                    // alert(XmlHttpRequest.responseText);
                }
            });
        }
    },
Cmd.Ajax("http://localhost:8088/api/TryApi/MethodMapping", { ActionCode: "TheApi", RequertParams: "haha" }, function (result) {
                alert(result.ResponseEntity)
            })
那个haha就会被弹出来...写的很草,主要是备忘,
当然也可以用Cors.
Ajax跨域Post方法调用Web Api(NuGet配置的环境)的更多相关文章
- 支持Ajax跨域访问ASP.NET Web Api 2(Cors)的简单示例教程演示
		
随着深入使用ASP.NET Web Api,我们可能会在项目中考虑将前端的业务分得更细.比如前端项目使用Angularjs的框架来做UI,而数据则由另一个Web Api 的网站项目来支撑.注意,这里是 ...
 - AJAX跨域问题解决方法(4)——调用方解决跨域
		
调用方解决跨域的方法只有一种,那就是隐藏跨域. 何为隐藏跨域? 隐藏跨域的核心思路是通过反向代理隐藏跨域以欺骗浏览器 什么是反向代理?反向代理是指通过中间服务器使得访问同一个域名的两个不同url最终会 ...
 - ASP.NET MVC 实现AJAX跨域请求方法《1》
		
ASP.NET MVC 实现AJAX跨域请求的两种方法 通常发送AJAX请求都是在本域内完成的,也就是向本域内的某个URL发送请求,完成部分页面的刷新.但有的时候需要向其它域发送AJAX请求,完成数据 ...
 - ajax 跨域解决方法
		
最近在开发过程中,使用ajax去异步调取图片.在开发中这个功能没什么问题,可以后来提测,重新部署之后就有问题了,这就是ajax的跨域问题. ajax核心对象XMLHttpRequest本身是不支持跨域 ...
 - Ajax跨域通信方法
		
1.Jsonp.document.domain+iframe.window.name.window.postMessage.服务器上设置代理页面. 2.Jsonp(json with padding) ...
 - 转载的别人的ajax跨域解决方法
		
http://dynamic.vip.xxxxxx.com/active/<controllers>/<active>/<id> 放在浏览器地址栏中访问可以得到正确 ...
 - AJAX跨域问题解决方法(3)——被调用方解决跨域
		
被调用方解决跨域是指在HTTP响应头中增加指定的字段,允许调用方调用 可以在两种地方增加1.apache/nginx(HTTP服务器)2.tomcat(应用服务器) 浏览器如何判断跨域?仔细观察可以发 ...
 - 解决ajax跨域的方法原理详解之Cors方法
		
1.神马是跨域(Cross Domain) 对于端口和协议的不同,只能通过后台来解决. 一句话:同一个ip.同一个网络协议.同一个端口,三者都满足就是同一个域,否则就是 跨域问题了.而为什么开 ...
 - ajax跨域--jsop方法
		
1.什么是JSONP? 要了解JSONP,不得不提一下JSON,那么什么是json ? json简单说就是javascript中的对象和数组,所以这两种结构就是对象和数组两种结构,通过这两种结构可以表 ...
 
随机推荐
- mysql获取一个表中的下一个自增(id)值的方法
			
SELECT Auto_increment FROM information_schema.`TABLES` WHERE Table_Schema='数据库名' AND table_name = '表 ...
 - 【转】MySQL性能优化的最佳21条经验
			
文章转自: http://blog.csdn.net/waferleo/article/details/7179009 今天,数据库的操作越来越成为整个应用的性能瓶颈了,这点对于Web应用尤其明显.关 ...
 - 我们为什么要看《超实用的Node.JS代码段》
			
不知道自己Node.JS水平如何?看这张图 如果一半以上的你都不会,必须看这本书,一线工程师用代码和功能页面来告诉你每一个技巧点. 都会一点,但不知道如何检验自己,看看本书提供的面试题: 1. ...
 - 深入浅析JAVA注解
			
注解,相信大家都会知道,像@requestMapping,@Resource,@Controller等等的一些注解,大家都用过,那么,他的工具类你用过吗?下面就和大家一起来分享一下注解工具类. 注解的 ...
 - Hadoop基础思维导图
 - python之路十四
			
概述 HTML是英文Hyper Text Mark-up Language(超文本标记语言)的缩写,他是一种制作万维网页面标准语言(标记).相当于定义统一的一套规则,大家都来遵守他,这样就可以让浏览器 ...
 - nova instance出错:"message": "Proxy error: 502 Read from server failed
			
执行 $ nova resize instance1 时候出错: {, "details": " File \"/opt/stack/nova/nova/com ...
 - DevExpress 隐藏Ribbon中barbuttonItem的SuperTip(2)
			
在form界面增加 toolTipController 工具 然后将 ribbonControl.ToolTipController 的属性设置成 toolTipController toolTipC ...
 - 第3章   拍摄UFO——单一职责原则
			
就一个类而言,应该仅有一个引起它变化的原因
 - dreamweaver cs6 mac破解版
			
http://www.sdifenzhou.com/dreamweaver-cs6-mac.html