#java #spring-boot #basic-authentication #resttemplate #internal-server-error
#java #весенняя загрузка #базовая аутентификация #resttemplate #внутренняя ошибка сервера
Вопрос:
Я получаю ошибку внутреннего сервера 500 в Java
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'transformToListClass': Invocation of init method failed; nested exception is java.lang.RuntimeException: org.springframework.web.client.HttpServerErrorException$InternalServerError: 500 Internal Server Error: [{"timestamp":"2020-08-20T20:48:50.993 0000","status":500,"error":"Internal Server Error","message":"Request processing failed; nested exception is java.lang.Exception: java.lang.RuntimeException: error while fopping..","path":"/v1/en/E_TEMPLATE"}]
Caused by: java.lang.RuntimeException: org.springframework.web.client.HttpServerErrorException$InternalServerError: 500 Internal Server Error: [{"timestamp":"2020-08-20T20:48:50.993 0000","status":500,"error":"Internal Server Error","message":"Request processing failed; nested exception is java.lang.Exception: java.lang.RuntimeException: error while fopping..","path":"/v1/en/E_TEMPLATE"}]
Caused by: org.springframework.web.client.HttpServerErrorException$InternalServerError: 500 Internal Server Error: [{"timestamp":"2020-08-20T20:48:50.993 0000","status":500,"error":"Internal Server Error","message":"Request processing failed; nested exception is java.lang.Exception: java.lang.RuntimeException: error while fopping..","path":"/v1/en/E_TEMPLATE"}]
Я открыл два приложения Spring, одно из которых запущено на порту 8080
, а другое — на порту 8013
.
Я отправляю post-запрос следующим образом с того, что в порту 8080
, на тот, что в порту 8013
:
Я также использую базовую аутентификацию, встроенную в заголовки RestTemplate
public ImageDescriptor generateImage(String payLoad, String templateName) {
try {
ImageDescriptor descriptor = new ImageDescriptor();
String MEl = "http://localhost:8013/v1/en";
String eURL = MEL.concat(Constant.F_SLASH).concat(templateName);
log.info("payload" payLoad);
ResponseEntity<Resource> responseEntity = restTemplate.exchange(
eURL,
HttpMethod.POST,
ncbiService.getStringHttpEntityWithPayload(payLoad),
Resource.class);
log.info(String.format("%s generateImage Result: [%s] ", responseEntity.getBody().getInputStream()));
descriptor.setInputStream(Objects.requireNonNull(responseEntity.getBody()).getInputStream());
convert(responseEntity.getBody().getInputStream(), "sherrr.pdf");
log.info("file is:" convert(responseEntity.getBody().getInputStream(), "sherrr.pdf"));
return descriptor;
} catch (IOException e) {
e.printStackTrace();
log.error(" generate image failed " e.getMessage());
throw new RuntimeException(e);
}
}
Ниже приведена служба в порту 8013, которую я вызываю в порту 8080:
@RestController()
@RequestMapping("/v1/e")
public class EcrionController {
@Autowired
private FOPService fopService;
@PostMapping(path = "{documentType}", consumes = "application/json", produces = "application/json")
public ResponseEntity<InputStreamResource> createDocument(@PathVariable DocType documentType, @RequestBody String payload) throws Exception {
InputStream inputStream = null;
try {
LOGGER.info(String.format("Document Type: ", documentType.toString()));
LOGGER.info(String.format("PayLoad : %s", payload));
inputStream = fopService.doFOP(payload, documentType);
InputStreamResource streamResource = new InputStreamResource(inputStream);
return ResponseEntity.ok()
.contentType(MediaType.parseMediaType(MediaType.APPLICATION_PDF_VALUE))
.body(streamResource);
} catch (Exception ex) {
LOGGER.error("Error", ex);
throw new Exception(ex);
}
}
Служба безопасности в порту 8013 выглядит следующим образом
@Configuration
@EnableWebSecurity
public class SecurityConfig extends WebSecurityConfigurerAdapter {
@Value("${spring.security.user.name}")
private String username;
@Value("${spring.security.user.password}")
private String password;
@Value("${spring.security.user.roles}")
private String roles;
@Override
protected void configure(HttpSecurity http) throws Exception {
http
.csrf().disable()
.authorizeRequests().anyRequest().authenticated()
.and()
.httpBasic();
}
@Override
protected void configure(AuthenticationManagerBuilder auth) throws Exception {
auth.inMemoryAuthentication()
.withUser(username)
.password(passwordEncoder().encode(password))
.roles(roles);
}
@Bean
public PasswordEncoder passwordEncoder() {
return new BCryptPasswordEncoder();
}
}
Как мне избавиться от внутренней ошибки сервера 500 в java?