我写了一个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;
}
}