詳解在TodoController中引用TodoRepository
這篇文章主要介紹了Spring Boot(三)之找回熟悉的Controller,Service,需要的朋友可以參考下
找回熟悉的Controller,Service Controller哪裡去了?
對於許多習慣了Spring開發的同學來講,Controller,Service,DAO 這些套路突然間都沒了會有不適感。其實呢,這些東西還在,只不過對於較簡單的情境下,這些都變成了系統背後幫你做的事情。這一小節我們就先來看看如何將Controller再召喚回來。召喚回來的好處有哪些呢?首先我們可以自訂API URL的路徑,其次可以對參數和傳回的json結構做一定的處理。
如果要讓 TodoController 可以和 TodoRepository 配合工作的話,我們當然需要在 TodoController 中需要引用 TodoRepository。
public class TodoController { @Autowired private TodoRepository repository; //省略其它部分 }
@Autowired 這個修飾符是用來做依賴性注入的,上面的用法叫做 field injection,直接做類別成員的注入。但Spring現在鼓勵用建構函數來做注入,所以,我們來看看建構子的注入方法:
public class TodoController { private TodoRepository repository; @Autowired public TodoController(TodoRepository repository){ this.repository = repository; } //省略其它部分 }
當然我們為了可以讓Spring知道這是一個支援REST API的Controller ,還是需要標記其為@RestController。由於預設的路徑映射會在資源根用複數形式,由於todo是輔音後的o結尾,按英語習慣,會映射成 todoes。但這裡用 todos 比 todoes 舒服一些,所以我們再用另一個 @RequestMapping("/todos") 來自定義路徑。這個 Controller 中的其它方法比較簡單,就是利用repository中的方法去增刪改查即可。
package dev.local.todo; import org.bson.types.ObjectId; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; import java.util.List; @RestController @RequestMapping("/todos") public class TodoController { private TodoRepository repository; @Autowired public TodoController(TodoRepository repository){ this.repository = repository; } @RequestMapping(method = RequestMethod.GET) public List<Todo> getAllTodos(@RequestHeader(value = "userId") String userId) { return repository.findByUserId(new ObjectId(userId)); } @RequestMapping(method = RequestMethod.POST) Todo addTodo(@RequestBody Todo addedTodo) { return repository.insert(addedTodo); } @RequestMapping(value = "/{id}", method = RequestMethod.GET) public Todo getTodo(@PathVariable String id) { return repository.findOne(id); } @RequestMapping(value = "/{id}", method = RequestMethod.PUT) Todo updateTodo(@PathVariable String id, @RequestBody Todo updatedTodo) { updatedTodo.setId(id); return repository.save(updatedTodo); } @RequestMapping(value = "/{id}", method = RequestMethod.DELETE) Todo removeTodo(@PathVariable String id) { Todo deletedTodo = repository.findOne(id); repository.delete(id); return deletedTodo; } }
上面的程式碼中需要再說明幾個要點:
為什麼在類別上標記@RequestMapping("/todos") 之後在每個方法上還需要加入@RequestMapping?類別上面定義的 @RequestMapping 的參數會預設套用到所有方法,但如果我們發現某個方法需要有自己的特殊值時,就需要定義這個方法的映射參數。例如上面例子中 addTodo,路徑也是 todos,但要求 Request的方法是 POST,所以我們給了 @RequestMapping(method = RequestMethod.POST)。但getTodo 方法的路徑應該是todos/:id,這時我們要給出@RequestMapping(value = "/{id}", method = RequestMethod.GET)
這些方法接受的參數也使用了各種修飾符,@PathVariable 表示參數是從路徑中得來的,而@RequestBody 表示參數應該從Http Request的body 中解析,類似的@RequestHeader 表示參數是Http Request的Header中定義的。
在可以測試之前,我們還需要使用 @Repository 來標記 TodoRepository,以便於Spring可以在依賴注入時可以找到這個類別。
package dev.local.todo; import org.bson.types.ObjectId; import org.springframework.data.mongodb.repository.MongoRepository; import org.springframework.stereotype.Repository; import java.util.List; /** * Created by wangpeng on 2017/1/26. */ @Repository public interface TodoRepository extends MongoRepository<Todo, String>{ List<Todo> findByUserId(ObjectId userId); }
接下來就可以用PostMan
來做測試:
#測試
Controller Service呢?在哪裡?
熟悉Spring的童鞋一定會問,我們剛才的做法等於直接是Controller訪問Data了,隔離不夠啊。其實我覺得有很多時候,這種簡單設計是挺好的,因為業務還沒到那步,過於複雜的設計其實沒啥太大意義。但這裡我們還是一步步實踐一下,找回大家熟悉的感覺。
回到原來的熟悉模式再簡單不過的,新建一個TodoService 介面,定義一下目前的增刪改查幾個操作:
public interface TodoService { Todo addTodo(Todo todo); Todo deleteTodo(String id); List<Todo> findAll(String userId); Todo findById(String id); Todo update(Todo todo); }
為預防我們以後使用MySQL 等潛在的“可擴展性”,我們將這個介面的實作命名為MongoTodoServiceImpl,然後把Controller 中的大部分程式碼拿過來改改就行了。當然為了系統可以找到這個依賴並註入需要的類別中,我們標記它為 @Service
@Service public class MongoTodoServiceImpl implements TodoService{ private final TodoRepository repository; @Autowired MongoTodoServiceImpl(TodoRepository repository) { this.repository = repository; } @Override public Todo addTodo(Todo todo) { return repository.insert(todo); } @Override public Todo deleteTodo(String id) { Todo deletedTodo = repository.findOne(id); repository.delete(id); return deletedTodo; } @Override public List<Todo> findAll(String userId) { return repository.findByUserId(new ObjectId(userId)); } @Override public Todo findById(String id) { return repository.findOne(id); } @Override public Todo update(Todo todo) { repository.save(todo); return todo; } }
最後把Controller中的所有方法改為使用Service的簡單呼叫就大功告成了。
public class TodoController { private TodoService service; @Autowired public TodoController(TodoService service){ this.service = service; } @RequestMapping(method = RequestMethod.GET) public List<Todo> getAllTodos(@RequestHeader(value = "userId") String userId) { return service.findAll(userId); } @RequestMapping(method = RequestMethod.POST) Todo addTodo(@RequestBody Todo addedTodo) { return service.addTodo(addedTodo); } @RequestMapping(value = "/{id}", method = RequestMethod.GET) public Todo getTodo(@PathVariable String id) { return service.findById(id); } @RequestMapping(value = "/{id}", method = RequestMethod.PUT) Todo updateTodo(@PathVariable String id, @RequestBody Todo updatedTodo) { updatedTodo.setId(id); return service.update(updatedTodo); } @RequestMapping(value = "/{id}", method = RequestMethod.DELETE) Todo removeTodo(@PathVariable String id) { return service.deleteTodo(id); } }
說實話如果每個簡單類別都這麼寫,我深深地趕腳背離了Spring Boot的意圖,雖然你能舉出1000個理由這麼做有好處。類似的,DAO或DTO要寫起來也很簡單,但我還是建議在業務沒有複雜之前還是享受Spring Boot帶給我們的便利吧。
【相關推薦】
1. Java免費影片教學
#2. 極客學院Java影片教學
#3. JAVA教學手冊
以上是詳解在TodoController中引用TodoRepository的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

Java 8引入了Stream API,提供了一種強大且表達力豐富的處理數據集合的方式。然而,使用Stream時,一個常見問題是:如何從forEach操作中中斷或返回? 傳統循環允許提前中斷或返回,但Stream的forEach方法並不直接支持這種方式。本文將解釋原因,並探討在Stream處理系統中實現提前終止的替代方法。 延伸閱讀: Java Stream API改進 理解Stream forEach forEach方法是一個終端操作,它對Stream中的每個元素執行一個操作。它的設計意圖是處

膠囊是一種三維幾何圖形,由一個圓柱體和兩端各一個半球體組成。膠囊的體積可以通過將圓柱體的體積和兩端半球體的體積相加來計算。本教程將討論如何使用不同的方法在Java中計算給定膠囊的體積。 膠囊體積公式 膠囊體積的公式如下: 膠囊體積 = 圓柱體體積 兩個半球體體積 其中, r: 半球體的半徑。 h: 圓柱體的高度(不包括半球體)。 例子 1 輸入 半徑 = 5 單位 高度 = 10 單位 輸出 體積 = 1570.8 立方單位 解釋 使用公式計算體積: 體積 = π × r2 × h (4
