Как мне устранить внутреннюю ошибку сервера 500 в Java?

#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?