如何找到java ClassCastException发生的位置

时间:2013-05-31 10:36:34

标签: java debugging exception wsdl wsimport

只是想知道是否有人可以从下面的代码中看到为什么我得到异常“java.lang.ClassCastException”。

RISService,RisPortType是我从WSDL文件中获取的lib,然后使用wsimport生成.java文件

我知道异常意味着什么,但我不确定如何追踪它。

    // Instantiate the wsimport generated SXML API Service client --
    RISService risportService = new RISService();
    RisPortType risportPort = risportService.getRisPort();

    // Set the URL, user, and password on the JAX-WS client
    String hostUrl = "https://10.1.1.1:8443/realtimeservice2/services/RISService";
    ((BindingProvider) risportPort).getRequestContext().put(BindingProvider.ENDPOINT_ADDRESS_PROPERTY, hostUrl);
    ((BindingProvider) risportPort).getRequestContext().put(BindingProvider.USERNAME_PROPERTY, cucmDetails.getAxlUsername());
    ((BindingProvider) risportPort).getRequestContext().put(BindingProvider.PASSWORD_PROPERTY, cucmDetails.getAxlPassword());

    // create and populate the selectCmDevice request
    SelectCmDevice sxmlParams = new SelectCmDevice();
    CmSelectionCriteria criteria = new CmSelectionCriteria();
    long maxNum = 200;
    long modelNum = 255;
    ArrayOfSelectItem items = new ArrayOfSelectItem();

    //create a select item criteria to retrieve devices with names matching "SEP123412341234"
    SelectItem item = new SelectItem();
    item.setItem("SEP123412341234");
    items.getItem().add(item);

    //Search on all nodes
    criteria.setNodeName("Any");
    //get back max 200 phones. 9+ can get upto 1000
    criteria.setMaxReturnedDevices(maxNum);
    //get back phones only
    criteria.setDeviceClass("Phone");
    //255 means get back ALL phone models
    criteria.setModel(modelNum);
    //get back only Registered phones
    criteria.setStatus("Registered");
    //return results in order of name
    criteria.setSelectBy("Name");
    //array of phones to get results back for
    criteria.setSelectItems(items);
    sxmlParams.setCmSelectionCriteria(criteria);

    //make selectCmDevice request
    SelectCmDeviceReturn selectResponse = risportPort.selectCmDevice("",criteria); << This is where i get the exception outline below

线程“AWT-EventQueue-0”中的异常javax.xml.ws.WebServiceException:

java.lang.ClassCastException: [C cannot be cast to java.lang.String
at com.sun.xml.internal.ws.transport.http.client.HttpTransportPipe.process(Unknown Source)
at     com.sun.xml.internal.ws.transport.http.client.HttpTransportPipe.processRequest(Unknown Source)
at com.sun.xml.internal.ws.transport.DeferredTransportPipe.processRequest(Unknown Source)
at com.sun.xml.internal.ws.api.pipe.Fiber.__doRun(Unknown Source)
at com.sun.xml.internal.ws.api.pipe.Fiber._doRun(Unknown Source)
at com.sun.xml.internal.ws.api.pipe.Fiber.doRun(Unknown Source)
at com.sun.xml.internal.ws.api.pipe.Fiber.runSync(Unknown Source)
at com.sun.xml.internal.ws.client.Stub.process(Unknown Source)
at com.sun.xml.internal.ws.client.sei.SEIStub.doProcess(Unknown Source)
at com.sun.xml.internal.ws.client.sei.SyncMethodHandler.invoke(Unknown Source)
at com.sun.xml.internal.ws.client.sei.SyncMethodHandler.invoke(Unknown Source)
at com.sun.xml.internal.ws.client.sei.SEIStub.invoke(Unknown Source)
at com.sun.proxy.$Proxy40.selectCmDevice(Unknown Source)
at utils._9.APIRIS9.getPhoneIPadd(APIRIS9.java:66)

由于 亚历

2 个答案:

答案 0 :(得分:0)

我敢打赌你的密码是以char[]的形式返回的,jaxws期待一个字符串。

答案 1 :(得分:0)

在我的情况下

Object port = service.getPort(qname, c);
WSBindingProvider bp = (WSBindingProvider) port;
// Manually set connection timeouts as we seem to hit them during IT testing
Map<String, Object> requestContext = bp.getRequestContext();

requestContext.put(BindingProviderProperties.REQUEST_TIMEOUT, env.getProperty("timeout"));

requestContext.put(BindingProviderProperties.CONNECT_TIMEOUT, env.getProperty("timeout"));

你可以看到requestContext.put()接受一个String和一个对象,你认为把一个String超时工作,但是没有,java ws期待一个int .. 这是一个巨大的问题。