Модераторы: LSD, AntonSaburov
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Порядок ExceptionResolver'ов в Spring 
:(
    Опции темы
lamao
Дата 29.4.2013, 12:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 73
Регистрация: 23.4.2008

Репутация: нет
Всего: нет



Есть приложение где посредством SimpleMappingExceptionResolver некоторые исключения мапятся на свои страницы ошибок. И вот понадобилось перехватить ситуацию, когда у нас параметр integer, а в запросе пришло скажем 1000000000000. Спринг трактует это как org.springframework.beans.TypeMismatchException, которое обрабатывается org.springframework.web.servlet.mvc.support.DefaultHandlerExceptionResolver, который по порядку просмотра идет перед нашим обработчиком. Сделал такой конфиг (PrettyLogExceptionResolver - это наследник SimpleMappingExceptionResolver )

Код

    <bean class="org.jtalks.jcommune.web.exception.PrettyLogExceptionResolver">
        <property name="order" value="1"/>
        <property name="exceptionMappings">
            <props>
                <prop key="org.jtalks.jcommune.service.exceptions.NotFoundException">/errors/404</prop>
                <prop key="org.springframework.security.access.AccessDeniedException">/errors/accessDenied</prop>
                <prop key="org.springframework.beans.TypeMismatchException">/errors/400</prop>
            </props>
        </property>
        <property name="warnLogCategory" value="org.jtalks.jcommune"/>
        <property name="defaultErrorView" value="/errors/500"/>
    </bean>
    <bean class="org.springframework.web.servlet.mvc.support.DefaultHandlerExceptionResolver">
        <property name="order" value="2"/>
    </bean> 


Все работает, но теперь, как я увидел в дебагере, в цепочке после PrettyLogExceptionResolver почему-то 2 DefaultHandlerExceptionResolver.
Вопрос - почему и как можно исправить? Оно то вроде не мешает, но все же криво как то смотрится.
PM MAIL WWW   Вверх
MisterCleric
Дата 29.4.2013, 12:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1043
Регистрация: 16.2.2006
Где: Харьков, Украина

Репутация: 33
Всего: 38



Привет.
Рекомендую посметреть в дебаге, что происходит здесь:
Код

DispatcherServlet#initHandlerExceptionResolvers

Я бы сказал, что у тебя у конфиге где-то еще хакрался DefaultHandlerExceptionResolver с другим order


--------------------
ПРИШЕЛ, УВИДЕЛ - ПЕРЕПИСАЛ...
PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Java"
LSD   AntonSaburov
powerOn   tux
  • Прежде, чем задать вопрос, прочтите это!
  • Книги по Java собираются здесь.
  • Документация и ресурсы по Java находятся здесь.
  • Используйте теги [code=java][/code] для подсветки кода. Используйтe чекбокс "транслит", если у Вас нет русских шрифтов.
  • Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
  • Действия модераторов можно обсудить здесь.
  • FAQ раздела лежит здесь.

Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, tux.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Java EE (J2EE) и Spring | Следующая тема »


 




[ Время генерации скрипта: 0.0723 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.