Thursday, September 18, 2025

REST in .NET Explained: A Complete Guide with Examples

If you are working with ASP.NET Core Web API, you will frequently hear the term REST API. But what does REST actually mean, and how do you implement it properly in .NET? Let’s break it down step by step with practical examples.


What is REST?

REST stands for Representational State Transfer. It is an architectural style for building distributed systems, especially web services, that communicate over HTTP.

Key REST principles:

  • Resources, not actions → Think in nouns like /api/books instead of verbs like /api/getBooks.

  • HTTP methods define actions

    • GET → fetch data

    • POST → create

    • PUT → replace

    • PATCH → partial update

    • DELETE → remove

  • Stateless → Each request contains everything needed. The server does not store session data.

  • Multiple representations → Same resource can be returned in JSON, XML, etc.

  • Cacheable → Responses should support caching for performance.

In short: REST APIs are about clean URLs, proper HTTP methods, and stateless communication.


REST in .NET

In ASP.NET Core, REST APIs are built using:

  • Controllers or Minimal APIs

  • Attributes like [HttpGet], [HttpPost], [HttpPut], [HttpDelete]

  • Model binding & validation

  • ActionResult / IActionResult for proper HTTP responses


Example: Building a REST API in ASP.NET Core

1. Define a Model (DTO)

public record BookDto
{
    public int Id { get; init; }
    public string Title { get; init; } = "";
    public string Author { get; init; } = "";
}

2. In-memory Repository

public interface IBookRepository
{
    Task<IEnumerable<BookDto>> GetAllAsync();
    Task<BookDto?> GetByIdAsync(int id);
    Task<BookDto> CreateAsync(BookDto book);
    Task UpdateAsync(BookDto book);
    Task DeleteAsync(int id);
}

public class InMemoryBookRepository : IBookRepository
{
    private readonly List<BookDto> _books = new();
    private int _nextId = 1;

    public Task<IEnumerable<BookDto>> GetAllAsync() =>
        Task.FromResult(_books.AsEnumerable());

    public Task<BookDto?> GetByIdAsync(int id) =>
        Task.FromResult(_books.FirstOrDefault(b => b.Id == id));

    public Task<BookDto> CreateAsync(BookDto book)
    {
        var created = book with { Id = _nextId++ };
        _books.Add(created);
        return Task.FromResult(created);
    }

    public Task UpdateAsync(BookDto book)
    {
        var idx = _books.FindIndex(b => b.Id == book.Id);
        if (idx >= 0) _books[idx] = book;
        return Task.CompletedTask;
    }

    public Task DeleteAsync(int id)
    {
        var book = _books.FirstOrDefault(x => x.Id == id);
        if (book != null) _books.Remove(book);
        return Task.CompletedTask;
    }
}

3. Create a REST Controller

[ApiController]
[Route("api/[controller]")]
public class BooksController : ControllerBase
{
    private readonly IBookRepository _repo;

    public BooksController(IBookRepository repo) => _repo = repo;

    [HttpGet]
    public async Task<ActionResult<IEnumerable<BookDto>>> GetAll()
    {
        var items = await _repo.GetAllAsync();
        return Ok(items);
    }

    [HttpGet("{id}")]
    public async Task<ActionResult<BookDto>> Get(int id)
    {
        var book = await _repo.GetByIdAsync(id);
        return book is null ? NotFound() : Ok(book);
    }

    [HttpPost]
    public async Task<ActionResult<BookDto>> Create(BookDto dto)
    {
        var created = await _repo.CreateAsync(dto);
        return CreatedAtAction(nameof(Get), new { id = created.Id }, created);
    }

    [HttpPut("{id}")]
    public async Task<IActionResult> Update(int id, BookDto dto)
    {
        if (id != dto.Id) return BadRequest();
        var existing = await _repo.GetByIdAsync(id);
        if (existing is null) return NotFound();

        await _repo.UpdateAsync(dto);
        return NoContent();
    }

    [HttpDelete("{id}")]
    public async Task<IActionResult> Delete(int id)
    {
        var existing = await _repo.GetByIdAsync(id);
        if (existing is null) return NotFound();

        await _repo.DeleteAsync(id);
        return NoContent();
    }
}

RESTful API Best Practices in .NET

✅ Use plural nouns for resources → /api/books
✅ Return correct status codes200, 201, 204, 404, 400
✅ Implement input validation and return problem details
✅ Add Swagger/OpenAPI for documentation
✅ Support paging, filtering, sorting with query parameters
✅ Use JWT authentication for secure APIs
✅ Apply versioning (e.g., /api/v1/books)


When NOT to Use REST

  • Use gRPC for high-performance internal service-to-service communication.

  • Use GraphQL when clients need flexible queries and avoid multiple endpoints.

REST is best when:

  • You want simplicity

  • Standard HTTP semantics are enough

  • Clients benefit from caching


Conclusion

In .NET, REST APIs are built using ASP.NET Core’s Web API framework. By following REST principles—resources, HTTP verbs, statelessness, proper status codes—you can build clean, scalable, and maintainable APIs.

Start with a simple controller, use proper response codes, and then enhance with authentication, versioning, and documentation. That’s how you make a professional REST API in .NET.



Wednesday, September 17, 2025

Complete Guide to Azure Functions with Example, Step-by-Step Setup, and Interview Questions

🌟 What are Azure Functions?

Azure Functions is a serverless compute service provided by Microsoft Azure. It allows developers to run small pieces of code, called functions, without worrying about infrastructure.

Instead of setting up servers, scaling manually, or managing infrastructure, you only write the code, and Azure handles the rest.

👉 You pay only for execution time, making it cost-effective and scalable.


🔧 Key Concepts in Azure Functions

  • Trigger → Defines how the function starts (e.g., HTTP request, Timer, Queue, Blob upload).

  • Input Binding → Brings data into the function.

  • Output Binding → Sends processed data out (e.g., to CosmosDB, Storage, Service Bus).

📌 Example: An HTTP Trigger Function can process user input and save it to CosmosDB.


🛠 Step-by-Step Example: Create an Azure Function

Let’s build a C# Azure Function that greets users.

1️⃣ Prerequisites

  • An Azure subscription

  • Visual Studio 2022 or VS Code with Azure Functions extension

  • Azure Functions Core Tools (for CLI usage)


2️⃣ Create a Function in VS Code

  1. Open VS Code → Install Azure Functions Extension.

  2. Click Azure Logo → Create New Project.

  3. Select C# as language.

  4. Choose HTTP trigger.

  5. Name it GreetFunction.

  6. Set Authorization level → Anonymous.


Note : Please Check and debug the code (If not working check latest code in Internet)

3️⃣Add Function Code

using System.IO;
using Microsoft.AspNetCore.Mvc;
using Microsoft.Azure.WebJobs;
using Microsoft.Azure.WebJobs.Extensions.Http;
using Microsoft.AspNetCore.Http;
using Microsoft.Extensions.Logging;

public static class GreetFunction
{
    [FunctionName("GreetFunction")]
    public static IActionResult Run(
        [HttpTrigger(AuthorizationLevel.Anonymous, "get", "post", Route = null)] HttpRequest req,
        ILogger log)
    {
        log.LogInformation("C# HTTP trigger function processed a request.");

        string name = req.Query["name"];

        if (string.IsNullOrEmpty(name))
        {
            return new BadRequestObjectResult("Please pass a name in the query string.");
        }

        return new OkObjectResult($"Hello {name}, Welcome to Azure Functions!");
    }
}

4️⃣ Run Locally

  • Press F5 to run.

  • Open browser:

    http://localhost:7071/api/GreetFunction?name=Cherry
    
  • Output:

    Hello Cherry, Welcome to Azure Functions!
    

5️⃣ Deploy to Azure

  1. In VS Code → Right-click project → Deploy to Function App.

  2. Select subscription & resource group.

  3. Create a new Function App.

  4. After deployment → Test the live URL:

    https://<yourappname>.azurewebsites.net/api/GreetFunction?name=Cherry
    

6️⃣ Monitor & Logs

  • In Azure Portal → Function App → Monitor,

  • Track logs, execution count, and performance metrics.


⚡ Real-World Use Cases of Azure Functions

  • Image Processing → Triggered when a blob is uploaded.

  • Email Notifications → Triggered by Queue messages.

  • Scheduled Jobs → Using Timer Triggers (CRON).

  • ETL Pipelines → Streaming data with Event Hub.

  • IoT Applications → Processing telemetry events in real-time.


🎯 Top Azure Functions Interview Questions

Basics

  1. What are Azure Functions, and how do they differ from WebJobs?

  2. Explain Triggers and Bindings.

  3. What are the different hosting plans (Consumption, Premium, Dedicated)?

  4. What is the cold start problem, and how do you reduce it?

  5. Difference between Azure Functions and Azure Logic Apps.

Development & Deployment

  1. How do you debug Azure Functions locally?

  2. How can one Azure Function call another?

  3. How do you secure Azure Functions? (API Keys, Azure AD, Managed Identity)

  4. How do you manage secrets/configuration? (App settings, Azure Key Vault)

  5. What is a Durable Function, and when should you use it?

Advanced

  1. How do you monitor and log executions?

  2. Can Azure Functions run in a VNET?

  3. How does scaling work in Azure Functions?

  4. How do retries work in queue-triggered functions?

  5. What are Durable Entities in Azure Durable Functions?


✅ Conclusion

Azure Functions is a powerful way to build event-driven, serverless applications on Azure.

  • Easy to create with triggers and bindings.

  • Cost-effective with pay-per-use pricing.

  • Scales automatically with demand.

Whether you’re preparing for an interview or building real-world microservices, mastering Azure Functions gives you a strong edge in modern cloud development.




Don't Copy

Protected by Copyscape Online Plagiarism Checker

Pages