Как отобразить сообщение об ошибке нулевого значения при поиске данных в JSP с помощью Spring MVC? - PullRequest
0 голосов
/ 27 апреля 2011

У меня есть таблица с именами учетных записей, в которой я ищу данные по имени учетной записи, поиск работает отлично. Предположим, что если я пытаюсь найти объект, которого нет в моей базе данных, он показывает ошибку, поэтому я хочу обработать исключение, отображая сообщение о том, что в таблице отсутствуют данные. Как я могу расставить все точки? Я использую Spring MVC и Hibernate 3 с задней частью MySQL.

Вот мой код.

Это мой спящий дао:

@SuppressWarnings("unchecked")
@Transactional(readOnly=true)
public List<Accounts> searchAccounts(String account){
    System.out.println("Executing Search Accounts Query:::::::::::::::::::::::::::::::::::::::::::::::");

    List<Accounts> accounts = getHibernateTemplate().find("from Accounts a here a.accountName = ?", account);
    if (accounts != null)
    {
        return accounts;
    }
    return null;
}

Это мой поисковый контроллер:

@Override
protected ModelAndView handleRequestInternal(HttpServletRequest request, HttpServletResponse response)
    throws Exception{

    String accountName = ServletRequestUtils.getStringParameter(request, "accountName");
    List<Accounts> accounts = accountsDao.searchAccounts(accountName);  
        if (accounts == null || accounts.isEmpty()){            
        ModelAndView mav = new ModelAndView("forward:searchaccounts.htm");
        System.out.println("searching data");
        return mav.addObject("message", "message.form.searchaccounts");         
    } else {
        ModelAndView mav = new ModelAndView();
        return mav.addObject(accounts);
    }       
}

Это мои поисковые аккаунты jsp:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"   "http://www.w3.org/TR/html4/loose.dtd">  
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
<%@ taglib prefix="spring" uri="http://www.springframework.org/tags"%>

<html xmlns="http://www.w3.org/1999/xhtml">
<head>

    <div class="boxed">
            <div class="title">Account Search</div>
            <div class="content">
                <form id="form4" method="get" action="#">
                    <fieldset>
                    <legend>Search</legend>
                    <input id="inputtext3" type="text" name="inputtext3" value="" class="textfield" />
                    <input id="inputsubmit2" type="submit" name="inputsubmit2" value="Search" class="button" />
                    <p class="tiny"><a href="#">Advanced Search</a></p>
                    </fieldset>
                </form>
            </div>
    </div>


</div>  

<div id="col-form">
    <div class="boxed">
        <div class="title">Group Account</div>
        <div class="content">
        <table border="1" width=100% >          
        <tr>
        <td bgcolor="#BBDDFF" >Account Id</td>
        <td bgcolor="#BBDDFF" >Account Group</td>
        <td bgcolor="#BBDDFF" >Closing Balance</td>
        <td bgcolor="#BBDDFF" >Account Type</td>
        <td bgcolor="#BBDDFF" >Remarks</td>
        </tr>                   
        <c:forEach var="accounts" items="${accountsList}">
        <tr bgcolor="#FFFFFF">      
        <td>${accounts.accountId}</td>                 
        <td><a href="accountsledger.htm?accountId=${accounts.accountId}">${accounts.accountGroup}</a></td>
        <td>${accounts.closingBalance}</td>
        <td>${accounts.closingType}</td>
        <td>${accounts.remarks}</td>
        </tr>
        </c:forEach>        
        </table>    
        </div> <!-- content -->
    </div>  <!-- boxed -->

</body>     

</html>

1 Ответ

0 голосов
/ 27 апреля 2011

Ваш accountsDao.searchAccounts может выдать индивидуальное исключение.

например,

throw new AccountException("Account not Found") вместо возврата null;

перехватывает это исключение в контроллере и устанавливает это сообщение об ошибке в объект ModelAndView.

protected ModelAndView handleRequestInternal(HttpServletRequest request, HttpServletResponse response)
    throws Exception{
            String accountName = ServletRequestUtils.getStringParameter(request, "accountName");
            ModelAndView mav = new ModelAndView("forward:searchaccounts.htm");
            List<Accounts> accounts = null;
            try{
                accounts = accountsDao.searchAccounts(accountName); 
            }catch(AccountException ex){
                mav.addObject("errorMsg",ex.getMessage());
            }

            mav.addObject("accountsList",accounts);
            return mav;   
        }
    }

в jsp

<font color='red'>${errorMsg}</font>

Или вы можете попробовать другой подход.

Оценить, если список пуст JSTL

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...