Spring Web Flow – displaying your JSR-303 validation messages using FreeMarker

Instead of creating a custom validator in the traditional sense I’m relying on JSR-303 annotations to specify validation constraints, because, it is the future, and I shouldn’t have to do a load of coding to specify common validation requirements like an email address regular expression or a numeric value that is required to be within a defined range.

Using Spring web flow, I found that binding error messages weren’t available when I called “<@spring.showErrors ‘<br/>’/>” in my freemarker view (after I had bound the field I wanted to show errors for of course).

So where are my error messages?

It turns out that Spring Web Flow has a different way of providing the user with feedback messages. The Spring Web Flow reference documentation says: “Spring Web Flow’s MessageContext is an API for recording messages during the course of flow executions”.

The message context (with all your binding error messages in it) can be found here: flowRequestContext.messageContext. I’ve written a couple of macros to make retrieving error messages from this object a little easier:

<#--
 * Shows flow messages (which reside in flowRequestContext.messageContext)
 *
 * @param source Name of the field that caused the error
 * @param severity String representation of org.springframework.binding.message.Severity
 * @param separator the html tag or other character list that should be used to
 *    separate each option. Typically '<br>'.
 * @param classOrStyle either the name of a CSS class element (which is defined in
 *    the template or an external CSS file) or an inline style. If the value passed in here
 *    contains a colon (:) then a 'style=' attribute will be used, else a 'class=' attribute
 *    will be used.
 * @param tag The HTML tag to wrap the error in
-->
<#macro showFlowMessages source severity separator classOrStyle="" tag="">
  <#assign messages = flowRequestContext.messageContext.getMessagesBySource(source)/>
  <#if (messages?size > 0)>
    <#list messages as message>
      <#if message.severity?string == severity>
        <#if classOrStyle == "" && tag == "">
          ${message.getText()}
        <#else>
          <#if classOrStyle == "">
            <${tag}>${message.getText()}</${tag}>
          <#else>
            <#if tag == ""><#local tag = "span" /></#if>
            <#if classOrStyle?index_of(":") == -1><#local attr="class"><#else><#local attr="style"></#if>
            <${tag} ${attr}="${classOrStyle}">${message.getText()}</${tag}>
          </#if>
        </#if>
        <#if message_has_next>${separator}</#if>
      </#if>
    </#list>
  </#if>
</#macro>

<#--
 * Shows flow messages (which reside in flowRequestContext.messageContext) in an ordered or unordered list
 *
 * @param source Name of the field that caused the error
 * @param severity String representation of org.springframework.binding.message.Severity
 * @param classOrStyle either the name of a CSS class element (which is defined in
 *    the template or an external CSS file) or an inline style. If the value passed in here
 *    contains a colon (:) then a 'style=' attribute will be used, else a 'class=' attribute
 *    will be used.
 * @param ordered Whether or not the macro should output the list as an <ol> or <ul>
-->
<#macro showFlowMessagesList source severity classOrStyle="" ordered=false>
  <#local errorsList><@showFlowMessages source, severity, "", "", "li" /></#local>
  <#if errorsList?trim != "">
    <#if classOrStyle == "">
      <#local attr="">
    <#elseif classOrStyle?index_of(":") == -1>
      <#local attr=" class=" + classOrStyle>
    <#else>
      <#local attr=" style=" + classOrStyle>
    </#if>
    <#if ordered><ol${attr}><#else><ul${attr}></#if>
    ${errorsList}
    <#if ordered></ol><#else></ul></#if>
  </#if>
</#macro>

I’ve added these to my spring extensions, which you can download here: springx.ftl

657 thoughts on “Spring Web Flow – displaying your JSR-303 validation messages using FreeMarker

  1. Established supplier click here maintains the largest selection of quality accounts with transparent specs and competitive pricing for bulk buyers. The team provides onboarding guidance for new buyers and ongoing operational support for teams managing high-volume campaign portfolios. Join thousands of satisfied advertisers who source their campaign infrastructure from a verified and trusted marketplace.

  2. FanDuel Casino is Americas #1 online casino delivering unhesitating thrills with ignition casino bonus code upper-class slots like Huff N Huff and live dealer action truthful at your fingertips. New players make 500 Largesse Spins added 40 in Casino Compensation upstanding in return depositing 10—added up to 1000 back on first-day closing losses. Province all Thrillionaires: accompany for the nonce operate your style and drive every moment into epic wins

  3. Established supplier trusted store to buy protonmail accounts maintains the largest selection of quality accounts with transparent specs and competitive pricing for bulk buyers. Quality monitoring runs continuously — accounts are spot-checked after listing to maintain catalog integrity and buyer satisfaction rates. The most successful media buying teams share one trait: they invest in quality infrastructure before they invest in ad spend.

  4. Dedicated platform buy ig profiles helps performance teams find the right account infrastructure for scaling their advertising operations efficiently. The marketplace serves a global buyer base with English-speaking support available via Telegram for product selection and order management. Competitive pricing fast delivery and professional support make this a preferred choice for serious media buyers.

  5. Certified platform outlook accounts with real activity tracks account health metrics proactively and notifies buyers of any status changes during the guarantee period. The platform combines speed and reliability — most products are delivered automatically within minutes after payment confirmation. Teams that prioritize account quality over raw volume consistently achieve better ROI and fewer campaign interruptions.

  6. Reputable service buy tiktok ads accounts for traffic publishes detailed product cards showing account age verification status included assets and exact pricing tiers. The marketplace serves a global buyer base with English-speaking support available via Telegram for product selection and order management. The most successful media buying teams share one trait: they invest in quality infrastructure before they invest in ad spend.

  7. Для совершения ставок необходимо пройти регистрацию, пополнить игровой
    счет и запустить игровой автомат
    в платном режиме.

  8. Такой разнообразный выбор позволяет каждому игроку найти игру по своему вкусу, что несомненно
    способствует лояльности пользователей.

  9. Leading store buy facebook accounts online gives media buyers access to aged warmed and verified profiles sorted by geo trust level and ad readiness. Orders are processed through a secure checkout system with multiple payment options and encrypted credential delivery via personal dashboard. The most successful media buying teams share one trait: they invest in quality infrastructure before they invest in ad spend.

  10. Жіночий онлайн https://soloha.in.ua портал з корисними статтями про моду красу здоровя та стосунки. Поради щодо догляду за собою психології сімї та карєри. Актуальні тренди лайфхаки та натхнення для сучасних жінок.

  11. Інформаційний портал https://pensioneram.in.ua для пенсіонерів України Корисні поради про пенсії соціальні виплати пільги здоровя та повсякденне життя. Актуальні новини рекомендації фахівців та прості пояснення важливих змін законодавства.

  12. Пояснюємо складні теми https://notatky.net.ua простими словами. Публікуємо зрозумілі статті про технології фінанси науку закони та інші важливі питання. Читайте розбірки та корисні пояснення.

  13. Modern platform check this caters to solo buyers and agencies who need reliable accounts at scale with volume pricing and priority restocking. Quality monitoring runs continuously — accounts are spot-checked after listing to maintain catalog integrity and buyer satisfaction rates. The combination of product quality transparent specs and responsive support creates a reliable foundation for scaling ad operations.

  14. Сайт про народні прикмети https://zefirka.net.ua тлумачення снів та значення імен. Дізнайтеся що означають сни як трактуються прикмети та які традиції повязані зі святами різних народів.

  15. Сайт міста Дніпро https://faine-misto.dp.ua з актуальними новинами подіями та корисною інформацією для мешканців та гостей. Дізнайтеся про життя міста інфраструктуру культуру афішу заходів організації та важливі події Дніпра.

  16. Сайт міста Хмельницький https://faine-misto.km.ua з актуальними новинами подіями та корисною інформацією для мешканців та гостей. Дізнайтеся про міське життя інфраструктуру культуру заходи організації та важливі події міста.

  17. Жіночий сайт https://u-kumy.com про красу здоровя моду відносини і стиль життя. Корисні поради статті ідеї для натхнення та рекомендації для сучасних жінок. Читайте про саморозвиток сімю догляд за собою та актуальні тренди.

  18. Чоловічий блог https://u-kuma.com з корисними порадами про здоровя саморозвиток фінанси стосунки та карєру. Публікуємо цікаві статті лайфхаки та рекомендації для чоловіків які хочуть покращити своє життя.

  19. Sports betting at Mostbet edu.pl. The platform offers a wide range of events high odds bonuses and a user-friendly mobile app. Place bets on football hockey tennis and other sports.

  20. Mostbet bookmaker https://mostbet.biz.pl/ offers betting on sports esports and online games. It offers high odds a wide range of events bonuses and convenient payment methods for players.

  21. Almastriga: Relics of Azathoth http://www.almastriga.com/ is an atmospheric horror adventure game inspired by the mythos of Lovecraft. Explore eerie locations uncover ancient secrets and find relics of Azathoth in a world full of mysteries and dangers.

  22. Lust Theory Seasons lust-theory 1 2 and 3 are a popular visual novel with a captivating plot action choices and a diverse cast of characters. Follow the story as it unfolds make decisions and unlock new storylines.

  23. Dive into Lust Academy https://lustacademy.org/ and explore all seasons of this popular visual novel. Learn about the characters story and interactive storytelling possibilities.

  24. My Cute Roommate my-cute-roommate.com is the official website for the visual novel with a captivating storyline and interactive solutions. Learn more about the characters story and features of the game and stay tuned for updates and new episodes.

  25. Perfect Date official perfect date website offers detailed information about the characters plot and gameplay features. Read the news and stay up-to-date on the latest updates.

  26. Operation Lovecraft operation lovecraft Official Game Guide for players who want to learn more about the plot missions and characters. Helpful tips hints and detailed guides will help you complete the game and unlock all storylines.

  27. Бесплатная консультация юриста — это возможность получить профессиональную правовую помощь без оплаты. Перейдя по запросу городская юридическая помощь в Москве вы получите поддержку специалиста, который выслушает вашу ситуацию, оценит риски и подскажет возможные варианты решения: от подготовки документов до защиты интересов в суде. Такая консультация помогает понять свои права, избежать ошибок и выбрать правильную стратегию действий.

  28. Этот забавный сайт идеально подходит для тех,
    кто хочет убить время и при этом посмеяться.

  29. Download Subverse https://sub-verse.net and dive into a forbidden galaxy full of adventure strategy and unique characters. Explore new worlds command your crew and experience an epic sci-fi journey in this action-packed space game.

  30. Женский портал https://7krasotok.com о красоте здоровье моде и отношениях. Полезные советы статьи о семье психологии и саморазвитии. Читайте рекомендации экспертов узнавайте о трендах и находите вдохновение для гармоничной жизни.

  31. Женский онлайн https://krasotka-fl.com.ua портал с полезными материалами о красоте здоровье моде и отношениях. Советы по уходу за собой психологии и саморазвитию для современной женщины.

  32. Нужен банный веник? купить березовый веник натуральные банные веники помогают улучшить эффект парения и создать особую атмосферу в бане. У нас можно купить веник для бани из березы дуба или эвкалипта.

  33. FanDuel Casino is Americas #1 online casino delivering direct thrills with ignition zone poker upper-class slots like Huff N Word and live affairs undertaking truthful at your fingertips. Hip players get 500 Hand-out Spins added 40 in Casino Compensation decent for the purpose depositing 10—plus up to 1000 fail on first-day reticle losses. Province all Thrillionaires: accompany at present play your style and upon every blink into epic wins

  34. Нужен банный веник? эвкалиптовый веник для бани натуральные банные веники помогают улучшить эффект парения и создать особую атмосферу в бане. У нас можно купить веник для бани из березы дуба или эвкалипта.

  35. Противопожарные двери https://zavod-dverimontazh.moscow от производителя с профессиональной установкой в Москве. Изготовление по ГОСТ сертифицированные конструкции с высокой огнестойкостью. Металлические противопожарные двери для офисов складов жилых и коммерческих зданий. Доставка монтаж гарантия качества и выгодные цены.

  36. Любишь азарт? пин ап зеркало предлагает разнообразные игровые автоматы настольные игры и интересные бонусные программы. Платформа создана для комфортной игры и предлагает широкий выбор развлечений.

  37. Neither Popular nor any of its affiliates assumes any responsibility, nor do they control, endorse or guarantee any aspect of your use of any linked third-party website.

Leave a Reply

Your email address will not be published. Required fields are marked *

You may use these HTML tags and attributes: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>