我将相同的Java scriptlet复制并粘贴到多个.jsp文件中。
我想用易于维护且可读性更好的解决方案代替它

    <%
    if (!MediaUtil.validateAuthorization()) {
        out.println("Unauthorized");
    } else {
        String srcquery = request.getQueryString();
        if (srcquery == null) {
            srcquery = "";
        }
        User currentUser = UserService.findCurrentUser();

        if (currentUser == null) {
            out.println(User.MESSAGE_NO_USER);
        } else {
    %>

    <html>
    <head>



编辑:FrenchFigaro的答案后,我已经使用JSTL重写了代码。感兴趣的人的最终代码如下:

<c:choose>
    <c:when test="${!MediaUtil.validateOrganization()}">
        <c:out value="Unauthorized"/>
    </c:when>
    <c:otherwise>
        <c:set var="srcquery" value="<%=request.getQueryString()%>"/>
        <c:choose>
            <c:when test="${srcquery == null}">
                <c:set var="srcquery" value=""/>
            </c:when>
        </c:choose>
        <c:set var="currentUser" value="<%=UserService.findCurrentUser()%>"/>
        <c:choose>
            <c:when test="${currentUser == null}">
                <c:out value="<%=User.MESSAGE_NO_USER%>"/>
            </c:when>
            <c:otherwise>
                <html>

                (...)

                </html>
            </c:otherwise>
        </c:choose>
    </c:otherwise>
</c:choose>


最佳答案

要替换if / else部分,可以使用<c:if><c:choose>

第一个提供一个选择,没有其他选择(但是条件相反的两个标签可以解决问题)。

最好在您的情况下使用<c:choose>

<c:choose>
    <c:when test="${condition}">...</c:when>
    <c:otherwise>...</c:otherwise>
</c:choose>


至于其余的,您将需要使用Bean在servlet和JSP之间传输数据。

10-08 07:03
查看更多