handleURI для http://AAA.BBB.CCC.DDD:8080/myapp/ uri: '' возвращает неоднозначный результат (Ваадин 6)

В моем приложении Vaadin 6 я иногда получаю следующую ошибку:

SEVERE: Terminal error:
java.lang.RuntimeException: handleURI for http://AAA.BBB.CCC.DDD:8080/myapp/ uri: '' returns ambigious result.
at com.vaadin.ui.Window.handleURI(Window.java:432)
at com.vaadin.terminal.gwt.server.AbstractCommunicationManager.handleURI(AbstractCommunicationManager.java:2291)
at com.vaadin.terminal.gwt.server.CommunicationManager.handleURI(CommunicationManager.java:370)
at com.vaadin.terminal.gwt.server.AbstractApplicationServlet.handleURI(AbstractApplicationServlet.java:1099)
at com.vaadin.terminal.gwt.server.AbstractApplicationServlet.service(AbstractApplicationServlet.java:535)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:728)

По словам Ваадина, это происходит по следующей методике:

public DownloadStream handleURI(URL context, String relativeUri) {

    DownloadStream result = null;
    if (uriHandlerList != null) {
        Object[] handlers;
        synchronized (uriHandlerList) {
            handlers = uriHandlerList.toArray();
        }
        for (int i = 0; i < handlers.length; i++) {
            final DownloadStream ds = ((URIHandler) handlers[i]).handleURI(
                    context, relativeUri);
            if (ds != null) {
                if (result != null) {
                    throw new RuntimeException("handleURI for " + context
                            + " uri: '" + relativeUri
                            + "' returns ambigious result.");
                }
                result = ds;
            }
        }
    }
    return result;
}

Я на самом деле создать DownloadStream в генераторе столбцов (для отображения изображений в таблице):

public class ImageColumnGenerator implements Table.ColumnGenerator {
    private static final Logger LOGGER = LoggerFactory.getLogger(ImageColumnGenerator.class);

    public final static String IMAGE_FIELD = "image";

    public Object generateCell(final Table aTable, final Object aItemId, final Object aColumnId) {
        if (!IMAGE_FIELD.equals(aColumnId)) {
            return null;
        }
        final BeanItem<UserProductImageBean> beanItem = (BeanItem<UserProductImageBean>)
                aTable.getItem(aItemId);

        final StreamResource streamResource = new StreamResource(new StreamResource.StreamSource() {
            public InputStream getStream() {
                return new ByteArrayInputStream(beanItem.getBean().getImageData());
            }
        },
                beanItem.getBean().getFileName(),
                MyApplication.getInstance());

        LOGGER.debug("imageResource: " + streamResource);
        final Embedded embedded = new Embedded("", streamResource);


        return embedded;
    }
}

beanItem.getBean().getImageData() это байтовый массив (byte[]) с данными изображения, которые я получаю от веб-службы.

MyApplication.getInstance() определяется следующим образом:

public class MyApplication extends Application implements ApplicationContext.TransactionListener
{
    private static ThreadLocal<MyApplication> currentApplication =
            new ThreadLocal<MyApplication> ();

    public static MyApplication getInstance()
    {
        return currentApplication.get ();
    }
}

Что я могу сделать, чтобы исправить вышеупомянутую (серьезную) ошибку?

1 ответ

Как только никто не ответит. Я совершенно не разбираюсь в том, что это за чертовщина, но - попытайтесь выяснить, по каким URL-адресам возникает эта ошибка, и что-то с ними сделать, прежде чем кормить их в DownloadStream.

Другие вопросы по тегам