C#.NET: Access OAuth REST Web API Method
OAuth is a token base authorization mechanism for REST Web API. You develop the authorization with the API only once up until the expiration time of the token. The generated token is then used each time the REST Web API is called, saving authorization step every time the REST Web API is called. Authentication is still there which is now replace with the generated authorize token available for certain period.
Today, I shall be demonstrating consumption of OAuth authorization for REST Web API methods using C#.NET Console Application.
1) Create new C#.NET Console Application project and name it "AccessOAuthRESTApi".
2) Create target JSON object mappers for request/response objects as according to ASP.NET MVC - OAuth 2.0 REST Web API Authorization server side solution.
3) Install "Newtonsoft.Json" & "Microsoft.AspNet.WebApi.Client" NuGet libraries.
4) Create "GetAuthorizeToken(...)" method in "Program.cs" file and replace following code in it i.e.
In the above code, I am using POST type API call to authorize and generate the authorization token, which will be then used to authenticate and access the REST Web API methods. I have also passed the require authorization scheme and authorization credentials to the API server as a key value pair. The returning JSON packet will provide the access token along with access token type and expiration.
5) Now, create "GetInfo(...)" method in "Program.cs" file and replace following code in it i.e.
In the above code, I am first providing authorized access token, which I have just generated to my REST Web API call for authentication. Then, I call my REST Web API and finally, I read the response and process my response according to my business requirements.
6) In "Program.cs" file "Main" method write following line of code to first generate authorize access token and then call the GET type REST Web API method i.e.
In the above lines of code, I am generating authorize access token first and after process the response packet, I am calling GET type REST web API method and process my response accodringly.
Today, I shall be demonstrating consumption of OAuth authorization for REST Web API methods using C#.NET Console Application.
Prerequisites:
Following are some prerequisites before you proceed any further in this tutorial:- Understanding of JSON Object Mapper.
- Knowledge of REST Web API.
- Knowledge of ASP.NET MVC5.
- Knowledge of C# Programming.
Download Now!
Let's begin now.1) Create new C#.NET Console Application project and name it "AccessOAuthRESTApi".
2) Create target JSON object mappers for request/response objects as according to ASP.NET MVC - OAuth 2.0 REST Web API Authorization server side solution.
3) Install "Newtonsoft.Json" & "Microsoft.AspNet.WebApi.Client" NuGet libraries.
4) Create "GetAuthorizeToken(...)" method in "Program.cs" file and replace following code in it i.e.
... public static async Task<string> GetAuthorizeToken() { // Initialization. string responseObj = string.Empty; ... // Posting. using (var client = new HttpClient()) { // Setting Base address. client.BaseAddress = new Uri("http://localhost:3097/"); // Setting content type. client.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json")); ... // Initialization. HttpResponseMessage response = new HttpResponseMessage(); List<KeyValuePair<string, string>> allIputParams = new List<KeyValuePair<string, string>>(); // Convert Request Params to Key Value Pair. ... // URL Request parameters. HttpContent requestParams = new FormUrlEncodedContent(allIputParams); // HTTP POST response = await client.PostAsync("Token", requestParams).ConfigureAwait(false); // Verification if (response.IsSuccessStatusCode) { // Reading Response. ... } } return responseObj; } ...
In the above code, I am using POST type API call to authorize and generate the authorization token, which will be then used to authenticate and access the REST Web API methods. I have also passed the require authorization scheme and authorization credentials to the API server as a key value pair. The returning JSON packet will provide the access token along with access token type and expiration.
5) Now, create "GetInfo(...)" method in "Program.cs" file and replace following code in it i.e.
... public static async Task<string> GetInfo(string authorizeToken) { // Initialization. string responseObj = string.Empty; // HTTP GET. using (var client = new HttpClient()) { // Initialization string authorization = authorizeToken; // Setting Authorization. client.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Bearer", authorization); // Setting Base address. client.BaseAddress = new Uri("https://localhost:44334/"); // Setting content type. client.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json")); // Initialization. HttpResponseMessage response = new HttpResponseMessage(); // HTTP GET response = await client.GetAsync("api/WebApi").ConfigureAwait(false); // Verification if (response.IsSuccessStatusCode) { // Reading Response. ... } } return responseObj; } ...
In the above code, I am first providing authorized access token, which I have just generated to my REST Web API call for authentication. Then, I call my REST Web API and finally, I read the response and process my response according to my business requirements.
6) In "Program.cs" file "Main" method write following line of code to first generate authorize access token and then call the GET type REST Web API method i.e.
... // Generate Authorize Access Token to authenticate REST Web API. string oAuthInfo = Program.GetAuthorizeToken().Result; // Process response access token info. ... // Call REST Web API method with authorize access token. string responseObj = Program.GetInfo(obj.access_token).Result; // Process Result. ...
In the above lines of code, I am generating authorize access token first and after process the response packet, I am calling GET type REST web API method and process my response accodringly.