将Java对象从JSP传递给Servlet

时间:2016-10-26 10:20:48

标签: java jsp servlets

我有一个Java Web应用程序。 我的User_Objects类在下面给出

public class User_Objects {
    public String firstName;
    public String middleName;

    public String getFirstName() {
        return firstName;
    }

    public void setFirstName(String firstName) {
        this.firstName = firstName;
    }

    public String getMiddleName() {
        return middleName;
    }

    public void setMiddleName(String middleName) {
        this.middleName = middleName;
    }
}

我使用以下代码

将我的Java User_Objects请求转发给JSP
    User_Objects fillObj = fillData(request);
    request.setAttribute("reqObj", fillObj);
    RequestDispatcher view = request.getRequestDispatcher("/organization.jsp");
    view.forward(request, response);

public User_Objects fillData(HttpServletRequest request) {
    User_Objects fillObj = new User_Objects();

    try {
        fillObj.setFirstName(request.getParameter("txtFirstname"));
    } catch (Exception e) {
    }

    try {
        fillObj.setMiddleName(request.getParameter("txtMiddlename"));
    } catch (Exception e) {
    }

    return fillObj;
}

我成功地将此Object接收到我的JSP表单中。但我想再次将此Object发送到Servlet,当我单击JSP表单上的Submit按钮并尝试使用下面的代码将此Object放入我的Servlet中

User_Objects obj = (User_Objects) request.getAttribute("reqObj");

request.getAttribute("reqObj")给我null

我的JSP表单代码如下所示

<%@ page import="otn.aitc.io.User_Objects" %>
<%@ page language="java" contentType="text/html; charset=ISO-8859-1" pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Organization</title>
<link rel="stylesheet" href="css/jquery-ui.css">
<script src="js/jquery-1.12.4.js"></script>
<script src="js/jquery-ui.js"></script>
<script>
    $(function() {
        var reqObj = '${reqObj}';
        var reqStatus = '${orgStatus}';
        var orgJson = '${reqOrgJson}';
        orgJson = orgJson.replace("/", "'");

        if(reqStatus != "" || orgJson != "") {
            if(reqStatus == "false") {
                document.getElementById("lblError").style.display = '';
            }
            else {
                document.getElementById("lblError").style.display = 'none';
            }

            var availableTutorials = [];
            if(orgJson != "") {
                var parsed = JSON.parse(orgJson);
                for(var x in orgJson) {
                    if(parsed[x] != undefined) {
                        availableTutorials.push(parsed[x]);
                    }
                }
            }

            $("#txtOrgName").autocomplete({source: availableTutorials});
        }
        else {
            window.location.href = "index.jsp";
        }
    });

    function validateOrg() {
        var orgName = document.getElementById("txtOrgName");
        if (orgName.value.trim().length == 0) {
            alert("Enter Org Name");
            return false;
        }
    }
</script>
</head>
<body>
    <form name="orgname" action="org_name" method="post">
        <table align="center">
            <tr align="center">
                <td colspan="4"><img src="images/logo.jpg" /></td>
            </tr>
            <tr>
                <td>Organization :</td>
                <td><input type="text" id="txtOrgName" name="txtOrgName" /><label style="color: red;">*</label></td>
            </tr>
            <tr>
                <td align="center" colspan=2><br/><input type="submit" name="btnOrgName" id="btnOrgName"
                    value="Validate" onclick="return validateOrg();" /></td>
            </tr>
        </table>
        <p align="center"><label id="lblError" style="color: red;">Error Message.</label></p>
    </form>
</body>
</html>

我在Eclipse中使用Java。

1 个答案:

答案 0 :(得分:1)

不要混用和匹配不同的执行范围。

serlvet和JSP页面在服务器端执行(实际上JSP页面也被编译为servlet)。 HTTP请求完成后,将丢弃所有基于请求的对象,包括请求属性。 最后,它是一个生成HTML文本的模板引擎。

此HTML文本(带有嵌入式JavaScript)由客户端的浏览器执行。此执行范围与您的服务器请求范围完全不同,后者已创建此HTML页面。因此,在您的JavaScript代码中,用于在服务器端创建该页面的所有Java对象都是未知且无法访问的。

所以你有两种选择。

  1. 创建HTML时包含足够的信息来重新创建服务器端对象。例如。如果您有一个具有名称和年龄属性的Person对象,则可以将名称和年龄包括为隐藏表单字段。提交表单后,您可以使用隐藏字段值作为请求参数重新创建Person对象。 Pro:易于实施。 Con:仅适用于小数据。数据暴露给客户端并且可以被操纵。

  2. 将对象存储在会话内的服务器端 Pro:数据不会暴露给客户端。 Con:实现更复杂,因为可能会同时访问会话变量(浏览器可以同时对同一会话执行多个请求)。