Knowledge Guide
HomeSystem DesignMicroservices Patterns

BFF Pattern An Example

Let's take a look at a simple Java example implementing the BFF pattern.

Coding Example

Let’s say we have an e-commerce application with a web frontend and a mobile app.

1. Product Service (Main Backend Service):

2. Web BFF:

3. Mobile BFF:

1. Product Service (Main Backend)

This is the main backend microservice that deals with products.

@RestController @RequestMapping("/products") public class ProductServiceController { @Autowired private ProductRepository productRepository; @GetMapping("/{productId}") public Product getProductById(@PathVariable String productId) { return productRepository.findById(productId) .orElseThrow(() -> new ProductNotFoundException(productId)); } }

In this simple controller, we have a method getProductById that fetches a product based on its ID. It interacts with a ProductRepository to fetch product data from the database. The Product class would contain all the detailed information about a product.

2. Web BFF

The Web BFF is tailored for the web frontend.

@RestController @RequestMapping("/web/products") public class WebProductController { @Autowired private ProductServiceClient productServiceClient; @GetMapping("/{productId}") public ProductDetails getProductDetails(@PathVariable String productId) { Product product = productServiceClient.getProductById(productId); return convertToWebProductDetails(product); } private ProductDetails convertToWebProductDetails(Product product) { // Logic to convert product to a detailed view suitable for web. // This could include adding more descriptions, images, etc. } }

Here, ProductServiceClient is a Feign client or any HTTP client that you are using to communicate with the Product Service. The getProductDetails method fetches a product and then converts it to a ProductDetails object, which is a detailed view tailored for web users.

3. Mobile BFF

The Mobile BFF is tailored for the mobile frontend.

@RestController @RequestMapping("/mobile/products") public class MobileProductController { @Autowired private ProductServiceClient productServiceClient; @GetMapping("/{productId}") public SimpleProductDetails getProductDetails(@PathVariable String productId) { Product product = productServiceClient.getProductById(productId); return convertToMobileProductDetails(product); } private SimpleProductDetails convertToMobileProductDetails(Product product) { // Logic to convert product to a concise view suitable for mobile. // This could include stripping down descriptions, using smaller images, etc. } }

In the Mobile BFF, the getProductDetails method fetches the product just like in the Web BFF, but it converts the product to a SimpleProductDetails object, which is a more concise view tailored for mobile users.

In Action

So in this setup:

Each frontend gets exactly what it needs, and the backend logic is tailored to provide the best possible user experience.

🤖 Don't fully get this? Learn it with Claude

Stuck on BFF Pattern An Example? Open Claude, copy a block below, and it'll teach you this exact concept — visually and interactively.

🎨 Explain it visually

Build the mental picture, not memorization.

I just read a lesson on **BFF Pattern An Example** (System Design) and want to truly understand it. Explain BFF Pattern An Example from first principles using ONE vivid real-world analogy and a visual mental model — draw it as ASCII art or a clear step-by-step diagram — with a concrete example using real numbers. Then ask me one question to check I got the mental picture, and wait for my reply. If you're unsure or a claim isn't standard, say so and reason from first principles instead of guessing.
🤔 Walk me through it (interactive)

Socratic — adapts to where you're stuck.

Teach me **BFF Pattern An Example** interactively. Ask me ONE guiding question at a time, wait for my answer, and adapt to my confusion — build the idea with me step by step instead of explaining it all at once. If you're unsure or a claim isn't standard, say so and reason from first principles instead of guessing.
🧪 Quiz me & fix my gaps

Active recall exposes what you missed.

Quiz me on **BFF Pattern An Example** with 5 questions, easy to tricky, ONE at a time. Tell me if each answer is right; at the end, explain clearly what I got wrong and why. If you're unsure or a claim isn't standard, say so and reason from first principles instead of guessing.
🧠 Make it stick

Intuition + hook + flashcards for long-term memory.

Help me remember **BFF Pattern An Example** for the long term: give the one-sentence intuition, a memorable hook/mnemonic, a tiny worked example, and 3 active-recall flashcards (Q -> A). If you're unsure or a claim isn't standard, say so and reason from first principles instead of guessing.

📝 My notes