java.util.MissingFormatArgumentException:格式说明符'%s'

时间:2016-06-29 10:14:42

标签: java controller response resttemplate

我显然遗漏了一些东西,但我不知道是什么...... 愚蠢的是,有多少小事让你变得疯狂,而不是复杂的......
这是控制器的代码:

    @RequestMapping(value = "/getClienteNomeCognome", method = RequestMethod.GET)
public ResponseEntity<List<Object>> getClienteNomeCognome(@RequestParam("nomeCliente") String nomeCliente,
        @RequestParam("cognomeCliente") String cognomeCliente) {
    List<Object> listaRisultati = new ArrayList<Object>();
    try {
        listaRisultati = serviziDocumentaleService.getClienteNomeCognome(nomeCliente, cognomeCliente);
    } catch (Exception e) {
        LOGGER.warn(String.format("Errore inatteso sulla chiamata del servizio: [%s]", e.toString()));
    }
    LOGGER.info(String.format("Avvio ricerca cliente con nome: %s, cognome: %s)", nomeCliente, cognomeCliente));
    return new ResponseEntity<List<Object>>(listaRisultati, HttpStatus.OK);
}

这是getClienteNomeCognome:

    public List<Object> getClienteNomeCognome(String nome, String cognome) throws Exception {
    try {
        final RestTemplate restTemplate = new RestTemplate();
        final String url = "somelink?cognome=%25"+cognome+"%25&nome=%25"+nome+"%25";
        final ResponseEntity<List> response = (ResponseEntity<List>) restTemplate.getForObject(url, List.class);
        if (response.getBody() != null && response.getBody().toString().contains("<error>")) {
            throw new Exception(String.format(
                    "La risposta del servizio contiene degli errori: %s",
                    response.getBody()));
        } else {
            LOGGER.debug("Fine chiamata al servizio di ricerca cliente");
            return response.getBody();
        }
    } catch (HttpClientErrorException hcee) {
        throw new Exception(String.format(
                "Errore durante la chiamata. Error: %s",
                hcee.getMessage()));
    } catch (Exception e) {
        throw new Exception(String.format(
                "Errore generico durante la chiamata al servizio. Error: %s"
                        + e.getMessage()));
    }

}

2 个答案:

答案 0 :(得分:6)

    throw new Exception(String.format(
            "Errore generico durante la chiamata al servizio. Error: %s"
                    + e.getMessage()));

应该是

    throw new Exception(String.format(
            "Errore generico durante la chiamata al servizio. Error: %s",
                    e.getMessage()));

答案 1 :(得分:0)

我无法100%确定问题,因为它丢失了代码,所以我可以从这里模拟它。但它看起来像:

LOGGER.info(String.format("Avvio ricerca cliente con nome: %s, cognome: %s)", nomeCliente, cognomeCliente));

在最后)之后有一个额外的%s,所以也许它只是没有正确阅读?除非在这里复制粘贴代码时只是一个错误。

如果有效,请告诉我们。