我在尝试获取实体MonitorFolder的列表时遇到错误。

这就是我构造MonitorFolder类的方式

package dataObjectLayer;

import org.hibernate.annotations.OnDelete;
import org.hibernate.annotations.OnDeleteAction;

import javax.persistence.*;

@Entity
@Table(name = "monitor_folder",
        uniqueConstraints = {@UniqueConstraint(columnNames = "monitor_folder_id", name = "uc_monitorFolderId_monitor_folder"),
                @UniqueConstraint(columnNames = "path", name = "uc_pathFolder_monitor_folder")
        })
public class MonitorFolder {
    private int monitorFolderId;
    private String dateMonitored;
    private String timeMonitored;
    private String pathFolder;
    private User owner;

    public MonitorFolder() {
    }

    public MonitorFolder(int monitorFolderId, String dateMonitored, String timeMonitored, String pathFolder) {
        this.monitorFolderId = monitorFolderId;
        this.dateMonitored = dateMonitored;
        this.timeMonitored = timeMonitored;
        this.pathFolder = pathFolder;
    }

    public MonitorFolder(User owner) {
        this.owner = owner;
    }

    @Column(name = "monitor_folder_id", length = 10)
    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    public int getMonitorFolderId() {
        return monitorFolderId;
    }

    public void setMonitorFolderId(int monitorFolderId) {
        this.monitorFolderId = monitorFolderId;
    }

    @ManyToOne(fetch = FetchType.LAZY)
    @JoinColumn(name = "user_id")
    @OnDelete(action = OnDeleteAction.CASCADE)
    public User getOwner() {
        return owner;
    }

    public void setOwner(User owner) {
        this.owner = owner;
    }

    @Column(name = "date_monitored")
    public String getDateMonitored() {
        return dateMonitored;
    }

    public void setDateMonitored(String dateMonitored) {
        this.dateMonitored = dateMonitored;
    }

    @Column(name = "time_monitored")
    public String getTimeMonitored() {
        return timeMonitored;
    }

    public void setTimeMonitored(String timeMonitored) {
        this.timeMonitored = timeMonitored;
    }

    @Column(name = "path")
    public String getPathFolder() {
        return pathFolder;
    }

    public void setPathFolder(String pathFolder) {
        this.pathFolder = pathFolder;
    }
}


MonitorFolder与用户之间也存在ManyToOne关系。

现在,我尝试使用以下HQL查询获取受用户ID监视的所有文件夹:

public List<MonitorFolder> selectMonitoredFoldersByUser(User owner, SessionFactory sf) throws PersistenceException {
    List<MonitorFolder> monitorFolders = null;
    try (Session s = sf.openSession()) {
        String hql = " from MonitorFolder mf join fetch User u on u.userId = :insertedUserId";
        Query <MonitorFolder> q  = s.createQuery(hql);
        q.setParameter("insertedUserId", owner.getUserId());
        monitorFolders = q.getResultList();
    }
    return monitorFolders;
}


但我收到以下错误:

 javax.xml.ws.WebServiceException: javax.xml.bind.MarshalException


- with linked exception:
[com.sun.istack.SAXException2: javax.xml.bind.JAXBException: class [Ljava.lang.Object; nor any of its super class is known to this context.
javax.xml.bind.JAXBException: class [Ljava.lang.Object; nor any of its super class is known to this context.]
    at com.sun.xml.ws.message.jaxb.JAXBMessage.writePayloadTo(JAXBMessage.java:403)
    at com.sun.xml.ws.message.AbstractMessageImpl.writeTo(AbstractMessageImpl.java:154)
    at com.sun.xml.ws.api.message.MessageWrapper.writeTo(MessageWrapper.java:199)
    at com.sun.xml.ws.encoding.StreamSOAPCodec.encode(StreamSOAPCodec.java:134)
    at com.sun.xml.ws.encoding.SOAPBindingCodec.encode(SOAPBindingCodec.java:242)
    at com.sun.xml.ws.transport.http.HttpAdapter.encodePacket(HttpAdapter.java:432)
    at com.sun.xml.ws.transport.http.HttpAdapter.access$100(HttpAdapter.java:100)
    at com.sun.xml.ws.transport.http.HttpAdapter$1.onCompletion(HttpAdapter.java:534)
    at com.sun.xml.ws.server.WSEndpointImpl$1.onCompletion(WSEndpointImpl.java:326)
    at com.sun.xml.ws.api.pipe.Fiber.completionCheck(Fiber.java:867)
    at com.sun.xml.ws.api.pipe.Fiber.run(Fiber.java:774)
    at com.sun.xml.ws.api.pipe.Fiber.start(Fiber.java:425)
    at com.sun.xml.ws.server.WSEndpointImpl.processAsync(WSEndpointImpl.java:349)
    at com.sun.xml.ws.server.WSEndpointImpl.process(WSEndpointImpl.java:359)
    at com.sun.xml.ws.transport.http.HttpAdapter.invokeAsync(HttpAdapter.java:530)
    at com.sun.xml.ws.transport.http.servlet.ServletAdapter.invokeAsync(ServletAdapter.java:206)
    at com.sun.xml.ws.transport.http.servlet.WSServletDelegate.doGet(WSServletDelegate.java:159)
    at com.sun.xml.ws.transport.http.servlet.WSServletDelegate.doPost(WSServletDelegate.java:194)
    at com.sun.xml.ws.transport.http.servlet.WSServlet.doPost(WSServlet.java:80)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:661)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:742)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
    at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:198)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:478)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:140)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:80)
    at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:650)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:342)
    at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:799)
    at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
    at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:868)
    at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1457)
    at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
    at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1128)
    at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:628)
    at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
    at java.base/java.lang.Thread.run(Thread.java:835)
Caused by: javax.xml.bind.MarshalException
 - with linked exception:
[com.sun.istack.SAXException2: javax.xml.bind.JAXBException: class [Ljava.lang.Object; nor any of its super class is known to this context.
javax.xml.bind.JAXBException: class [Ljava.lang.Object; nor any of its super class is known to this context.]
    at com.sun.xml.bind.v2.runtime.MarshallerImpl.write(MarshallerImpl.java:276)
    at com.sun.xml.bind.v2.runtime.BridgeImpl.marshal(BridgeImpl.java:104)
    at com.sun.xml.bind.api.Bridge.marshal(Bridge.java:145)
    at com.sun.xml.ws.db.glassfish.BridgeWrapper.marshal(BridgeWrapper.java:170)
    at com.sun.xml.ws.message.jaxb.JAXBMessage.writePayloadTo(JAXBMessage.java:394)
    ... 42 more
Caused by: com.sun.istack.SAXException2: javax.xml.bind.JAXBException: class [Ljava.lang.Object; nor any of its super class is known to this context.
javax.xml.bind.JAXBException: class [Ljava.lang.Object; nor any of its super class is known to this context.
    at com.sun.xml.bind.v2.runtime.XMLSerializer.reportError(XMLSerializer.java:247)
    at com.sun.xml.bind.v2.runtime.XMLSerializer.reportError(XMLSerializer.java:262)
    at com.sun.xml.bind.v2.runtime.XMLSerializer.childAsXsiType(XMLSerializer.java:653)
    at com.sun.xml.bind.v2.runtime.property.ArrayElementProperty.serializeListBody(ArrayElementProperty.java:169)
    at com.sun.xml.bind.v2.runtime.property.ArrayERProperty.serializeBody(ArrayERProperty.java:159)
    at com.sun.xml.bind.v2.runtime.ClassBeanInfoImpl.serializeBody(ClassBeanInfoImpl.java:361)
    at com.sun.xml.bind.v2.runtime.XMLSerializer.childAsXsiType(XMLSerializer.java:696)
    at com.sun.xml.bind.v2.runtime.MarshallerImpl.write(MarshallerImpl.java:271)
    ... 46 more
Caused by: javax.xml.bind.JAXBException: class [Ljava.lang.Object; nor any of its super class is known to this context.
    at com.sun.xml.bind.v2.runtime.JAXBContextImpl.getBeanInfo(JAXBContextImpl.java:593)
    at com.sun.xml.bind.v2.runtime.XMLSerializer.childAsXsiType(XMLSerializer.java:648)
    ... 51 more


是否与我返回的MonitorXolder类型的泛型列表(JAXB无法编组)有关?

最佳答案

问题是hql,它没有明确说明它将返回的对象类型。
我变了:

from MonitorFolder mf join fetch User u on u.userId = :insertedUserId


至:

select mf from MonitorFolder mf join fetch User u on u.userId = :insertedUserId

07-26 05:17