基本HTTP認証をに追加する方法は複数ありますRestTemplate
。
1.単一のリクエストの場合
try {
String url = "https://jsonplaceholder.typicode.com/posts";
String authStr = "username:password";
String base64Creds = Base64.getEncoder().encodeToString(authStr.getBytes());
HttpHeaders headers = new HttpHeaders();
headers.add("Authorization", "Basic " + base64Creds);
HttpEntity request = new HttpEntity(headers);
ResponseEntity<String> response = new RestTemplate().exchange(url, HttpMethod.GET, request, String.class);
String json = response.getBody();
} catch (Exception ex) {
ex.printStackTrace();
}
Spring5.1
以降を使用している場合は、認証ヘッダーを手動で設定する必要がなくなりました。headers.setBasicAuth()
代わりにメソッドを使用してください。
HttpHeaders headers = new HttpHeaders();
headers.setBasicAuth("username", "password");
2.リクエストのグループの場合
@Service
public class RestService {
private final RestTemplate restTemplate;
public RestService(RestTemplateBuilder restTemplateBuilder) {
this.restTemplate = restTemplateBuilder
.basicAuthentication("username", "password")
.build();
}
}
3.すべてのリクエストに対して
@Bean
RestOperations restTemplateBuilder(RestTemplateBuilder restTemplateBuilder) {
return restTemplateBuilder.basicAuthentication("username", "password").build();
}
お役に立てば幸いです。