介紹asp.net MVC下使用rest的方法

來源:互聯網
上載者:User
本篇文章主要介紹了asp.net MVC下使用rest的方法,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

前言

最近做了下個MVC的項目,需要用到rest介面,與java寫的應用程式通訊,包括資料的接收和發送,那麼我將用實用的角度來全面的講解一下它的使用方法

一、建立rest服務

首先建立一個Asp.Net Web應用程式(我這裡用的是Visual Studio 2013,它已經內建了Web API2)。

在出來的模板中選擇Empty(空項目),並勾選WebAPI。點擊確定後,就建立了一個空的WebAPI服務。

此時只有一個空項目,還沒有任何功能,在進行下一步之前,首先我們來看一下REST的基本操作模型,大致可以分為如下四種:

  • POST — 建立資源

  • GET — 檢索資源

  • PUT — 更新資源

  • DELETE — 刪除資源

非常經典的CRUD模型。在Web API中實現這樣一個的模型是非常簡單的,直接使用嚮導建一個Controller即可

如果用傳統的嚮導,記得把嚮導後面的那個1給去掉:

預設的模板內容如下:


   public class ValuesController : ApiController  {    // GET api/<controller>    publicIEnumerable<string> Get()    {      returnnewstring[] { "value1", "value2" };    }    // GET api/<controller>/5    publicstring Get(int id)    {      return"value";    }    // POST api/<controller>    publicvoid Post([FromBody]string value)    {    }    // PUT api/<controller>/5    publicvoid Put(int id, [FromBody]string value)    {    }    // DELETE api/<controller>/5    publicvoid Delete(int id)    {    }  }

這其實已經幫我們實現了一個最基本的服務了,這樣別人就可以訪問我們的服務中的方法

二、調用其它應用程式的rest服務

1、RestClient類

為了便於使用,我們需要封裝客房端的rest類,話不多說,我們直接上這個類的代碼:


using System;using System.Collections.Generic;using System.IO;using System.Linq;using System.Net;using System.Text;using System.Web;namespace OilDigital.A2_A27.Web{  public class RestClient  {    public string EndPoint { get; set; }  //請求的url地址     public HttpVerb Method { get; set; }  //請求的方法     public string ContentType { get; set; } //格式類型:我用的是application/json,text/xml具體使用什麼,看需求吧     public string PostData { get; set; }  //傳送的資料,當然了我使用的是json字串     public RestClient()    {      EndPoint = "";      Method = HttpVerb.GET;      ContentType = "application/x-www-form-urlencoded";      PostData = "";    }    public RestClient(string endpoint)    {      EndPoint = endpoint;      Method = HttpVerb.GET;      ContentType = "application/json";      PostData = "";    }    public RestClient(string endpoint, HttpVerb method)    {      EndPoint = endpoint;      Method = method;      ContentType = "application/json";      PostData = "";    }    public RestClient(string endpoint, HttpVerb method, string postData)    {      EndPoint = endpoint;      Method = method;      ContentType = "application/json";      PostData = postData;    }    public RestClient(string endpoint, HttpVerb method, string postData, string contentType)    {      EndPoint = endpoint;      Method = method;      ContentType = contentType;      PostData = postData;    }    public string MakeRequest()    {      return MakeRequest("");    }    public string MakeRequest(string parameters)    {      var request = (HttpWebRequest)WebRequest.Create(EndPoint + parameters);      request.Method = Method.ToString();      request.ContentType = ContentType;            if (!string.IsNullOrEmpty(PostData) && Method == HttpVerb.POST)//如果傳送的資料不為空白,並且方法是post       {        var encoding = new UTF8Encoding();           var bytes = Encoding.GetEncoding("iso-8859-1").GetBytes(PostData);//編碼方式按自己需求變更,我在項目中使用的是UTF-8         request.ContentLength = bytes.Length;        using (var writeStream = request.GetRequestStream())        {          writeStream.Write(bytes, 0, bytes.Length);        }      }      if (!string.IsNullOrEmpty(PostData) && Method == HttpVerb.PUT)//如果傳送的資料不為空白,並且方法是put       {        var encoding = new UTF8Encoding();        var bytes = Encoding.GetEncoding("iso-8859-1").GetBytes(PostData);//編碼方式按自己需求變更,我在項目中使用的是UTF-8         request.ContentLength = bytes.Length;        using (var writeStream = request.GetRequestStream())        {          writeStream.Write(bytes, 0, bytes.Length);        }      }      using (var response = (HttpWebResponse)request.GetResponse())      {        var responseValue = string.Empty;        if (response.StatusCode != HttpStatusCode.OK)        {          var message = String.Format("Request failed. Received HTTP {0}", response.StatusCode);          throw new ApplicationException(message);        }        // grab the response         using (var responseStream = response.GetResponseStream())        {          if (responseStream != null)            using (var reader = new StreamReader(responseStream))            {              responseValue = reader.ReadToEnd();            }        }        return responseValue;      }    }  }  public enum HttpVerb  {    GET,      //method 常用的就這幾樣,當然你也可以添加其他的  get:擷取  post:修改  put:寫入  delete:刪除     POST,    PUT,    DELETE  }}

2、RestClient類使用

有了這個類後我們就很方便的去調用別人的rest服務了,使用方法如下:

①,基本的調用:


var client = new RestClient();string endPoint = @"http:\\myRestService.com\api\";var client = new RestClient(endPoint);var json = client.MakeRequest();

②,如果你想帶入參數


var json = client.MakeRequest("?param=0");

③,使用最多的方式


var client = new RestClient();client.EndPoint = @"http:\\myRestService.com\api\"; ;client.ContentType = "application/json";client.Method = HttpVerb.POST;client.PostData = "{postData: value}";var json = client.MakeRequest();

三、我自己項目中的使用

1、首先我測試了一下,我調用我自己的rest服務的帶參的get方法,當然我這裡傳的參數直接寫在url的後面在,參數形式是string,所以接收的get方法的形參也要改成string,這樣你就

可以接收到傳過去的參數了。當然別人應用程式也是可以調的。只要把url給他就行了。


/// <summary>    /// 從介面中擷取目前使用者所有資訊    /// </summary>    /// <param name="userId">使用者ID</param>    /// <returns>json對象</returns>    public string GetCurrentUserInfo()    {      string userId = GetCurrentUserId();      string endPoint = "http://localhost:100/Api/RestService/"+userId;      var client = new RestClient(endPoint);      var userInfo = client.MakeRequest();      return userInfo;    }

2、接下來,我要開始試用java寫的應用程式下的rest服務了,我通過我傳過去的使用者ID擷取到了使用者的所有資訊,當然我在項目中使用了緩衝技術,還將返回回來的json字串轉換成了json對象,以便我後面好用linq對其進行操作,關於linq to json 可以參考我的linq專題相關文章 ,我在項目中的代碼是醬子的:


/// <summary>    /// 從介面中擷取使用者所有資訊    /// </summary>    /// <param name="userId">使用者ID</param>    /// <returns></returns>    public static JObject CacheUser()    {      try      {        string currentUser = GetCurrentUserId();        if (HttpRuntime.Cache.Get("user$" + GetCurrentUserId()) == null)        {          string endPoint = "http://66.66.66.666:6666/DASBASE/restServices/dataCollectionService/getUserPermissions";          string postData = "jsonData={\"userCode\": \"kfry\",\"systemId\": \"1E1A7AC94BFC41D4BEBED8942EB69689\"}";          var client = new RestClient(endPoint, HttpVerb.POST, postData, "application/x-www-form-urlencoded");          var u = client.MakeRequest();          JObject userInfo = JObject.Parse(u);          //插入緩衝          HttpRuntime.Cache.Insert("user$" + currentUser, userInfo, null, System.DateTime.UtcNow.AddMinutes(30), TimeSpan.Zero);        }        return (JObject)HttpRuntime.Cache.Get("user$" + GetCurrentUserId());      }      catch (Exception ex)      {        throw new ApplicationException("擷取使用者資訊出錯:"+ex.Message);      }    }
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.