HttpMessageNotWritableException: не найдено преобразователя для возвращаемого значения типа: класс java.util.HashMap в Spring MVC - PullRequest
0 голосов
/ 25 мая 2018

Я пытаюсь вернуть JSON с помощью HashMap, как это в методе в контроллере

//list all users
    @RequestMapping(value = "/user",method = RequestMethod.GET)
    public ResponseEntity<Map<String,Object>> handleRequest() throws Exception{
        List<User> users = userService.list();          
        Map<String, Object> message = new HashMap<String, Object>();

        message.put("severity", "info");
        message.put("user", users);
        message.put("summary", "Not successfully.");
        message.put("code", 200);

        Map<String, Object> json = new HashMap<String, Object>();
        json.put("success", true);
        json.put("message", message);

        return new ResponseEntity<Map<String,Object>>(message,HttpStatus.CREATED);
    }

Когда я нажимаю этот метод в PostMan, я получаю эту ошибку

org.springframework.http.converter.HttpMessageNotWritableException: No converter found for return value of type: class java.util.HashMap
org.springframework.web.servlet.mvc.method.annotation.AbstractMessageConverterMethodProcessor.writeWithMessageConverters(AbstractMessageConverterMethodProcessor.java:226)
org.springframework.web.servlet.mvc.method.annotation.RequestResponseBodyMethodProcessor.handleReturnValue(RequestResponseBodyMethodProcessor.java:180)
org.springframework.web.method.support.HandlerMethodReturnValueHandlerComposite.handleReturnValue(HandlerMethodReturnValueHandlerComposite.java:82)
org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:119)
org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:877)
org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:783)
org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87)
org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:991)
org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:925)
org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:974)
org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:866)
javax.servlet.http.HttpServlet.service(HttpServlet.java:635)
org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:851)
javax.servlet.http.HttpServlet.service(HttpServlet.java:742)
org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)

ЭтоКак я настроил приложение

@Configuration
@ComponentScan("com.fyt.fyt")
@EnableTransactionManagement
public class ApplicationContextConfig {


    @Bean
    public InternalResourceViewResolver getViewResolver() {
        InternalResourceViewResolver internalResourceViewResolver = new InternalResourceViewResolver();
        internalResourceViewResolver.setPrefix("/WEB-INF/views/");
        internalResourceViewResolver.setSuffix(".jsp");
        return internalResourceViewResolver;
    }

    @Bean
    public DataSource getDataSource() {
        BasicDataSource dataSource = new BasicDataSource();
        dataSource.setDriverClassName("com.mysql.jdbc.Driver");
        dataSource.setUrl("jdbc:mysql://localhost:3306/fyt");
        dataSource.setUsername("root");
        dataSource.setPassword("");
        return dataSource;
    }

    @Bean
    public LocalSessionFactoryBean getSessionFactory() {

        LocalSessionFactoryBean factoryBean = new LocalSessionFactoryBean();
        factoryBean.setDataSource(getDataSource());
        factoryBean.setHibernateProperties(getHibernateProperties());
        factoryBean.setAnnotatedClasses(User.class);
        return factoryBean;

    }

    private Properties getHibernateProperties() {
        Properties properties = new Properties();
        properties.put("hibernate.show_sql", "true");
        properties.put("hibernate.dialect", "org.hibernate.dialect.MySQLDialect");
        return properties;
    }

    @Bean
    public HibernateTransactionManager getTransactionManager() {
        HibernateTransactionManager transactionManager = new HibernateTransactionManager();
        transactionManager.setSessionFactory(getSessionFactory().getObject());
        return transactionManager;
    }

    @Bean
    public UserDao userDao() {
        return new UserDaoImpl();
    }
}

В сообщении об ошибке говорится, что он не может преобразовать список в httpmessges, поэтому мне нужны какие-либо конвертеры или что-то в этом роде?Что я что-то упустил?

Ответы [ 4 ]

0 голосов
/ 25 мая 2018

Я думаю, вам нужен настраиваемый httpmessageconvertor для этого.
add Dependency

<dependency>
     <groupId>com.fasterxml.jackson.core</groupId>
     <artifactId>jackson-databind</artifactId>
     <version>2.5.0</version>
</dependency>

, если это не работает, попробуйте настроить пользовательскую конфигурацию для MappingJackson для HttpMessage Convertor в вашей конфигурацииФайл.

0 голосов
/ 25 мая 2018

Вы можете просто вернуть карту типа этой и пользовательскую аннотацию @RestController поверх вашего класса:

    @RequestMapping(value = "/user",method = RequestMethod.GET)
    public Map<String,Object> handleRequest() throws Exception{
        List<User> users = userService.list();          
        Map<String, Object> message = new HashMap<String, Object>();

        message.put("severity", "info");
        message.put("user", users);
        message.put("summary", "Not successfully.");
        message.put("code", 200);

        Map<String, Object> json = new HashMap<String, Object>();
        json.put("success", true);
        json.put("message", message);

        message.putAll(json);
        return message;
    }
0 голосов
/ 25 мая 2018

Обеспечить @ RestController на уровне класса контроллера, в противном случае укажите @ ResponseBody на уровне метода.Убедитесь, что все связанные с Джексоном банки находятся в пути к классам.

Добавьте связанные с Джексоном зависимости в ваш pom.xml

@RequestMapping(value = "/user",method = RequestMethod.GET)
@ResponseBody
    public ResponseEntity<Map<String,Object>> handleRequest() throws Exception{
        List<User> users = userService.list();          
        Map<String, Object> message = new HashMap<String, Object>();

        message.put("severity", "info");
        message.put("user", users);
        message.put("summary", "Not successfully.");
        message.put("code", 200);

        Map<String, Object> json = new HashMap<String, Object>();
        json.put("success", true);
        json.put("message", message);

        return new ResponseEntity<Map<String,Object>>(message,HttpStatus.CREATED);
    }

Образец зависимостей pom для Джексона.

<dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-core</artifactId>
        <version>2.8.1</version>
    </dependency>
    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-databind</artifactId>
        <version>2.8.1</version>
    </dependency>
    <dependency>
        <groupId>org.codehaus.jackson</groupId>
        <artifactId>jackson-mapper-asl</artifactId>
        <version>1.9.13</version>
        </dependency>
0 голосов
/ 25 мая 2018

пользователь @ResponseBody аннотация поверх метода.

@RequestMapping(value = "/user",method = RequestMethod.GET)
@ResponseBody

И убедитесь, что у сущности пользователя есть геттеры и сеттеры.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...