我有一个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。
答案 0 :(得分:1)
不要混用和匹配不同的执行范围。
serlvet和JSP页面在服务器端执行(实际上JSP页面也被编译为servlet)。 HTTP请求完成后,将丢弃所有基于请求的对象,包括请求属性。 最后,它是一个生成HTML文本的模板引擎。
此HTML文本(带有嵌入式JavaScript)由客户端的浏览器执行。此执行范围与您的服务器请求范围完全不同,后者已创建此HTML页面。因此,在您的JavaScript代码中,用于在服务器端创建该页面的所有Java对象都是未知且无法访问的。
所以你有两种选择。
创建HTML时包含足够的信息来重新创建服务器端对象。例如。如果您有一个具有名称和年龄属性的Person
对象,则可以将名称和年龄包括为隐藏表单字段。提交表单后,您可以使用隐藏字段值作为请求参数重新创建Person
对象。
Pro:易于实施。
Con:仅适用于小数据。数据暴露给客户端并且可以被操纵。
将对象存储在会话内的服务器端 Pro:数据不会暴露给客户端。 Con:实现更复杂,因为可能会同时访问会话变量(浏览器可以同时对同一会话执行多个请求)。