我写了一个jersey REST API方法,该方法返回使用hibernate从mysql后端查询的人员列表。这是方法

    @Path("Person")
    @GET
    @Produces(MediaType.TEXT_PLAIN)
    public List<Person> person()
    {
        SessionFactory sessionFactory = new Configuration().configure().buildSessionFactory();
        Session session = sessionFactory.openSession();
        Transaction tx = session.beginTransaction();
        Criteria cr = session.createCriteria(Person.class);
        List persons =  cr.list();
        GenericEntity<List<Person>> list = new GenericEntity<List<Person>>(persons) {};
        tx.commit();
        session.close();
        return persons;

    }


这是我的MessageBodyWriter

@Provider
@Produces(MediaType.APPLICATION_JSON)
public class PersonMessageBodyWriter implements MessageBodyWriter<Person> {

@Override
public long getSize(Person arg0, Class<?> arg1, Type arg2, Annotation[] arg3, MediaType arg4) {
    // TODO Auto-generated method stub
    return -1;
}

@Override
public boolean isWriteable(Class<?> type, Type arg1, Annotation[] arg2, MediaType arg3) {
    return Person.class.isAssignableFrom(type);
}

@Override
public void writeTo(Person person, Class<?> type, Type type1, Annotation[] arg3, MediaType arg4,
        MultivaluedMap<String, Object> arg5, OutputStream out) throws IOException, WebApplicationException {
    // TODO Auto-generated method stub
        out.write(person.toString().getBytes());
    }

}


当我对上述方法提出要求时
严重:找不到媒体类型= text / plain,类型= class java.util.ArrayList,genericType = java.util.List的MessageBodyWriter。
有人可以帮我解决这个问题吗?

最佳答案

在这种情况下,我一直要做的是使一个Persons对象包含人员列表。也许有更好的方法,但是如果您在时间紧迫的情况下想要完成它,那么这应该可以工作。如果不起作用,那么我猜没有JSON编组起作用,在这种情况下,您会遇到配置问题。

import java.util.ArrayList;
import java.util.List;

public class Persons
{
    private List<Person> persons = new ArrayList<>();

    public List<Person> getPersons()
    {
        return persons;
    }

    public void setPersons(List<Person> persons)
    {
        this.persons = persons;
    }
}

08-05 09:21
查看更多