国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - ASP.NET教程 - 支持Ajax跨域訪問ASP.NET Web Api 2(Cors)的示例教程

支持Ajax跨域訪問ASP.NET Web Api 2(Cors)的示例教程

2020-01-04 16:05一個人的長征 ASP.NET教程

這篇文章主要介紹了支持Ajax跨域訪問ASP.NET Web Api 2(Cors)的示例教程,需要的朋友可以參考下

隨著深入使用ASP.NET Web Api,我們可能會在項目中考慮將前端的業(yè)務(wù)分得更細(xì)。比如前端項目使用Angularjs的框架來做UI,而數(shù)據(jù)則由另一個Web Api 的網(wǎng)站項目來支撐。注意,這里是兩個Web網(wǎng)站項目了,前端項目主要負(fù)責(zé)界面的呈現(xiàn)和一些前端的相應(yīng)業(yè)務(wù)邏輯處理,而Web Api則負(fù)責(zé)提供數(shù)據(jù)。

這樣問題就來了,如果前端通過ajax訪問Web Api項目話,就涉及到跨域了。我們知道,如果直接訪問,正常情況下Web Api是不允許這樣做的,這涉及到安全問題。所以,今天我們這篇文章的主題就是討論演示如何配置Web Api以讓其支持跨域訪問(Cors)。好了,下面我們以一個簡單的示例直接進(jìn)入本文的主題。

首先打開Visual Studio 2013,創(chuàng)建一個空白的解決方案,命名為:CrossDomainAccessWebAPI。

再創(chuàng)建一個空的Web Api項目,命名為:CrossDomainAccess.WebAPI

支持Ajax跨域訪問ASP.NET Web Api 2(Cors)的示例教程

接著我們右鍵單擊剛才創(chuàng)建的解決方案,創(chuàng)建一個空的Web項目用來模擬我們的網(wǎng)站對WebAPI項目進(jìn)行跨域調(diào)用,如下:

支持Ajax跨域訪問ASP.NET Web Api 2(Cors)的示例教程

完成以上步驟以后,我們的解決方案目錄如下圖所示:

支持Ajax跨域訪問ASP.NET Web Api 2(Cors)的示例教程

下面我們在模擬網(wǎng)站的Web項目中通過Nuget添加jQuery,一下是添加jQuery包的界面:

支持Ajax跨域訪問ASP.NET Web Api 2(Cors)的示例教程

添加完成后,到這里我們就完成了前期的準(zhǔn)備工作。下面在WebAPI項目的Models文件夾中添加是一個實體類UserInfo,具體代碼如下:

支持Ajax跨域訪問ASP.NET Web Api 2(Cors)的示例教程

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
 
namespace CrossDomainAccess.WebAPI.Models
{
 public class UserInfo
 {
  public int Id { get; set; }
 
  public string UserName { get; set; }
 
  public string UserPass { get; set; }
 
  public string Email { get; set; }
 
  public DateTime RegTime { get; set; }
 }
}

然后在WebAPI項目中添加一個示例控制器:UserInfoController,這個控制器用來返回數(shù)據(jù)集合,具體代碼如下:

支持Ajax跨域訪問ASP.NET Web Api 2(Cors)的示例教程

支持Ajax跨域訪問ASP.NET Web Api 2(Cors)的示例教程

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Net.Http;
using System.Web.Http;
using CrossDomainAccess.WebAPI.Models;
 
namespace CrossDomainAccess.WebAPI.Controllers
{
 public class UserInfoController : ApiController
 {
  /// <summary>
  /// 獲取用戶信息集合的方法
  /// </summary>
  /// <returns>返回用戶信息集合</returns>
  public IHttpActionResult GetList()
  {
   //對象集合模擬數(shù)據(jù)
   List<UserInfo> list = new List<UserInfo>()
   {
    new UserInfo()
    {
     Id = 1,
     UserName = "張三",
     UserPass = "FDASDFAS",
     Email = "zhangsan@163.com",
     RegTime = DateTime.Now
    },
    new UserInfo()
    {
     Id = 2,
     UserName = "李四",
     UserPass = "FDASDFAS",
     Email = "lisi@163.com",
     RegTime = DateTime.Now
    },
    new UserInfo()
    {
     Id = 3,
     UserName = "王五",
     UserPass = "FDASDFAS",
     Email = "wangwu@163.com",
     RegTime = DateTime.Now
    },
    new UserInfo()
    {
     Id = 4,
     UserName = "趙六",
     UserPass = "FDASDFAS",
     Email = "zhaoliu@163.com",
     RegTime = DateTime.Now
    },
    new UserInfo()
    {
     Id = 5,
     UserName = "田七",
     UserPass = "FDASDFAS",
     Email = "tianqi@163.com",
     RegTime = DateTime.Now
    },
    new UserInfo()
    {
     Id = 6,
     UserName = "王八",
     UserPass = "FDASDFAS",
     Email = "wangba@163.com",
     RegTime = DateTime.Now
    }
   };
   return Ok(list);
  }
 }
}

接著我們需要修改一下App_Start目錄下的WebApiConfig.cs文件中webapi的路由規(guī)則,以便通過api/{controller}/{action}的方式進(jìn)行訪問,同時讓修改序列化方式,讓W(xué)ebAPI默認(rèn)輸出json格式的數(shù)據(jù),具體操作如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net.Http.Formatting;
using System.Web.Http;
 
namespace CrossDomainAccess.WebAPI
{
 public static class WebApiConfig
 {
  public static void Register(HttpConfiguration config)
  {
   // Web API 配置和服務(wù)
 
   // Web API 路由
   config.MapHttpAttributeRoutes();
 
   config.Routes.MapHttpRoute(
    name: "DefaultApi",
    routeTemplate: "api/{controller}/{action}/{id}",
    defaults: new { id = RouteParameter.Optional }
   );
   //清除所有序列化格式
   config.Formatters.Clear();
   //添加Json格式的序列化器
   config.Formatters.Add(new JsonMediaTypeFormatter());
  }
 }
}

重新生成一下項目,并在瀏覽器中訪問,這時我們可以的到j(luò)son格式的數(shù)據(jù),如下:

 

復(fù)制代碼 代碼如下:
[{"Id":1,"UserName":"張三","UserPass":"FDASDFAS","Email":"zhangsan@163.com","RegTime":"2016-04-21T10:36:50.7800569+08:00"},{"Id":2,"UserName":"李四","UserPass":"FDASDFAS","Email":"lisi@163.com","RegTime":"2016-04-21T10:36:50.7800569+08:00"},{"Id":3,"UserName":"王五","UserPass":"FDASDFAS","Email":"wangwu@163.com","RegTime":"2016-04-21T10:36:50.7800569+08:00"},{"Id":4,"UserName":"趙六","UserPass":"FDASDFAS","Email":"zhaoliu@163.com","RegTime":"2016-04-21T10:36:50.7800569+08:00"},{"Id":5,"UserName":"田七","UserPass":"FDASDFAS","Email":"tianqi@163.com","RegTime":"2016-04-21T10:36:50.7800569+08:00"},{"Id":6,"UserName":"王八","UserPass":"FDASDFAS","Email":"wangba@163.com","RegTime":"2016-04-21T10:36:50.7800569+08:00"}]

 

好了,到這里我們Web Api端的數(shù)據(jù)輸出就準(zhǔn)備好了。為了測試是否可以跨域訪問,我們再轉(zhuǎn)到CorsDemo.UI網(wǎng)站項目中。首先創(chuàng)建一個index.aspx頁面(這個命名自己可以任意取)后打開,修改成如下的代碼:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Index.aspx.cs" Inherits="CrossDomainAccess.Web.Index" %>
 
<!DOCTYPE html>
 
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 <title></title>
 <script src="Scripts/jquery-2.2.3.min.js"></script>
 <script type="text/javascript">
  $(function () {
   $('#getData').click(function () {
    $.ajax({
     url: 'http://localhost:29867/api/UserInfo/getlist',
     dataType: 'json',
     success: function (data) {
      //以表格的形式在瀏覽器控制臺顯示數(shù)據(jù),IE下不支持
      console.table(data);
     }
    });
   });
  });
 </script>
</head>
<body>
 <form id="form1" runat="server">
  <div>
   <input type="button" value="跨域獲取數(shù)據(jù)" id="getData" />
  </div>
 </form>
</body>
</html>

完成以上步驟以后,啟動WebAPI項目和Web項目,并在Web項目的Index頁面中點擊跨域獲取數(shù)據(jù)按鈕,打開瀏覽器控制臺查看請求結(jié)果,在控制臺會出現(xiàn)如下結(jié)果:

支持Ajax跨域訪問ASP.NET Web Api 2(Cors)的示例教程

控制臺提示我們跨域請求被阻止,同時提示CORS頭部信息確實,所以我們可以通過去WebAPI配置CORS來讓其支持跨域訪問。

那現(xiàn)在我們在WebAPI項目中通過Nuget添加Microsoft.AspNet.WebApi.Cors ,然后在WebApiConfig.cs文件中配置HttpConfiguration的EnableCors方法即可。具體操作如下:

支持Ajax跨域訪問ASP.NET Web Api 2(Cors)的示例教程

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net.Http.Formatting;
using System.Web.Http;
using System.Web.Http.Cors;
 
namespace CrossDomainAccess.WebAPI
{
 public static class WebApiConfig
 {
  public static void Register(HttpConfiguration config)
  {
   // Web API 配置和服務(wù)
   EnableCrossSiteRequests(config);
   // Web API 路由
   config.MapHttpAttributeRoutes();
 
   config.Routes.MapHttpRoute(
    name: "DefaultApi",
    routeTemplate: "api/{controller}/{action}/{id}",
    defaults: new { id = RouteParameter.Optional }
   );
   //清除所有序列化格式
   config.Formatters.Clear();
   //添加Json格式的序列化器
   config.Formatters.Add(new JsonMediaTypeFormatter());
  }
 
  /// <summary>
  /// 允許跨域調(diào)用
  /// </summary>
  /// <param name="config"></param>
  private static void EnableCrossSiteRequests(HttpConfiguration config)
  {
   //對所有的請求來源沒有任何限制
   var cors = new EnableCorsAttribute(
    origins: "*",
    headers: "*",
    methods: "*"
    );
   config.EnableCors(cors);
  }
 }
}

 

現(xiàn)在,我們再重新生成WebAPI項目并運行,接著在頁面http://localhost:31521/Index.aspx中點擊按鈕“跨域獲取數(shù)據(jù)”,通過firebug的控制臺,我們可以看到數(shù)據(jù)跨域加載成功了,如下:

支持Ajax跨域訪問ASP.NET Web Api 2(Cors)的示例教程

至此,關(guān)于ASP.Net Web Api支持跨域請求的示例和演示就完成了,謝謝大家的閱讀。

延伸 · 閱讀

精彩推薦
Weibo Article 1 Weibo Article 2 Weibo Article 3 Weibo Article 4 Weibo Article 5 Weibo Article 6 Weibo Article 7 Weibo Article 8 Weibo Article 9 Weibo Article 10 Weibo Article 11 Weibo Article 12 Weibo Article 13 Weibo Article 14 Weibo Article 15 Weibo Article 16 Weibo Article 17 Weibo Article 18 Weibo Article 19 Weibo Article 20 Weibo Article 21 Weibo Article 22 Weibo Article 23 Weibo Article 24 Weibo Article 25 Weibo Article 26 Weibo Article 27 Weibo Article 28 Weibo Article 29 Weibo Article 30 Weibo Article 31 Weibo Article 32 Weibo Article 33 Weibo Article 34 Weibo Article 35 Weibo Article 36 Weibo Article 37 Weibo Article 38 Weibo Article 39 Weibo Article 40
主站蜘蛛池模板: 欧美 日韩 中文 | 亚州男人天堂 | 国产精品99久久免费观看 | 亚洲综合精品 | 亚洲综合一区二区三区 | 亚洲国产精品成人 | 亚洲www啪成人一区二区 | 一区中文字幕 | 一区二区免费在线视频 | 欧美日韩日本国产 | 成人网色 | 午夜久久久 | 国产精品久久久久久久久 | 亚洲久久一区二区 | 色综合一区二区三区 | 毛片久久久| 91亚洲精品一区 | 欧美二三区 | 久久免费电影 | 欧美午夜一区二区三区免费大片 | 激情欧美一区二区三区中文字幕 | 丁香婷婷综合激情五月色 | 久久视频一区 | 午夜视频导航 | 免费看黄在线观看 | 91久久久久久久久久久久久久久久 | 伊人网综合 | 日韩精品一二三区 | 欧美日韩免费一区二区三区 | 艹逼网 | 久久久www | 久久先锋| 国产精品三级视频 | 国产精品国产三级国产aⅴ原创 | 国产成人精品一区二 | 精品影视| 成人在线免费看 | 日本精品一区二区三区在线观看 | 一级片在线观看 | 色香蕉在线 | 亚洲一区二区三区蜜桃 |