您好,登錄后才能下訂單哦!
這篇文章主要講解了“Spring Boot開發人員應該知道的技巧有哪些”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Spring Boot開發人員應該知道的技巧有哪些”吧!
通常有部分的開發人員在請求參數會選擇使用 Map<String, String>
@GetMapping
public SomeDto getAll(@RequestParam Map<String, String> params)
雖然它沒有任何問題,但它缺少可讀性。如果另一個開發人員想知道支持哪些參數,那么開發人員需要仔細閱讀代碼并且必須費力地找到所有參數。 此外,Swagger 2.0
規范不支持 Map<String, String>
。
@ModelAttribute
注解可用于將請求參數映射到 Java 對象。Java 對象可以具有 API 期望的所有請求參數。這樣你就可以在 java 對象上使用所有 javax
驗證。
@GetMapping
public SomeDto getAll(@Valid @ModelAttribute SomeObject params)
為所有 FeignException 設置一個全局異常處理程序是很好的。大多數情況下,都希望發送與底層服務發送的相同的錯誤響應。
@RequiredArgsConstructor
@ControllerAdvice
public class ExceptionControllerAdvice {
private final ObjectMapper mapper;
@ExceptionHandler(FeignException.class)
public final ResponseEntity < String > handleFeignException(FeignException fex) {
log.error("Exception from downstream service call - ", fex);
HttpStatus status = Optional.ofNullable(HttpStatus.resolve(fex.status()))
.orElse(HttpStatus.INTERNAL_SERVER_ERROR);
String body = Strings.isNullOrEmpty(fex.contentUTF8()) ? fex.getMessage() : fex.contentUTF();
return new ResponseEntity < > (
body,
getHeadersWithContentType(body),
status
);
}
private MultiValueMap < String, String > getHeadersWithContentType(String body) {
HttpHeaders headers = new HttpHeaders();
String contentType = isValidJSON(body) ? "application/json" : "text/plain";
headers.add(HttpHeaders.CONTENT_TYPE, contentType);
return headers;
}
private boolean isValidJSON(String body) {
try {
if (Strings.isNullOrEmpty(body)) return false;
mapper.readTree(body);
return true;
} catch (JacksonException e) {
return false;
}
}
}
對于集成測試,很多人很可能會使用 @SpringBootTest
注釋測試類;此注釋的問題在于它將啟動整個應用程序上下文。但有時候你也可以避免它,考慮到你只是在測試服務層,而唯一需要的是 JPA 連接。
在這種情況下,可以使用@DataJpaTest
注釋來啟動 JPA
組件和存儲庫 bean
。并使用@Import
注釋加載服務類本身。
@DataJpaTest(showSql = false)
@Import(TestService.class)
public class ServiceTest {
@Autowired
private TestService service;
@Test
void testFindAll() {
List<String> values = service.findAll();
assertEquals(1, values.size());
}
}
如果你希望你的項目中只有一個配置 (application.yml
) 文件,那么你可以使用三個破折號分隔每個配置文件配置。
api.info:
title: rest-serice
description: some description
version: 1.0client.url: http://dev.server
---
spring.config.activate.on-profile: integration-test
client.url: http://mock-server
---
spring.config.activate.on-profile: prod
client.url: http://real-server
感謝各位的閱讀,以上就是“Spring Boot開發人員應該知道的技巧有哪些”的內容了,經過本文的學習后,相信大家對Spring Boot開發人員應該知道的技巧有哪些這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。