- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我不熟悉在 Servlet 中使用 Java Bean,并且在从 HttpServletRequest 对象访问 bean 时遇到问题。当我使用 getAttribute() 时,它返回 null。这是我的代码:
Station.jsp - JSP:
<!--
@author - Dylan Stout
7/19/2016
Description: Station Screen -- Takes scanner input to three fields: fromStation, toStation, toLoad
Javascript is used to handle cursor position,incrementing fields, and button-press for load releasing.
PickProcess java bean holds the session information necessary to verify and send/recieve messages to wrxj
back-end.
Each input field is it's own form so no handling for carriage returns is needed (symbol guns usually
send carriage return after scan)
-->
<%@ 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">
<jsp:useBean id="pickProcess" class="com.wynright.scanui.model.PickProcess" scope="session"/>
<jsp:useBean id="fromStation" class="com.wynright.scanui.model.FromStation" scope="request"/>
<jsp:useBean id="toStation" class="com.wynright.scanui.model.ToStation" scope="request"/>
<jsp:useBean id="toLoad" class="com.wynright.scanui.model.ToLoad" scope="request"/>
<html>
<head>
<meta name="viewport" content="width=240, height=320, user-scalable=no,
initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0" />
<link type="text/css" rel="stylesheet" href="css/scanui.css">
<script type="text/javascript" src="scripts/jquery-3.1.0.min.js"></script>
<script type="text/javascript" src="scripts/formController.js"></script>
<script type="text/javascript" src="scripts/station.js"></script>
<noscript>JavaScript is off. Please enable to use ScanUI.</noscript>
<title>Station Pick - Scan UI</title>
</head>
<%
if(fromStation.hasErrors()){
%>
<body OnLoad="onBodyLoad();focusFromStation();">
<%
}else if(toStation.hasErrors()) {
%>
<body OnLoad="onBodyLoad();focusToStation();">
<%
}else if(toLoad.hasErrors()){
%>
<body OnLoad="onBodyLoad();focusToLoad();">
<%
}else{
%>
<body OnLoad="onBodyLoad();focusNext();">
<%
}
%>
<table cellpadding=4 cellspacing=2>
<th bgcolor="#CCCCFF" colspan=2><font size=2>Station Pick</font></th>
<tr bgcolor="#c8d8f8">
<td valign=top><form name="fromStation" action="ValidateFromStation" method=post>
From Station: <input type="text" name="value"
value='<%=pickProcess.getFromStation()%>' size=5 maxlength=5 tabindex="1">
<br>
<font size=2 color=red><%=fromStation.getErrorMsg("fromStation")%></font>
</form></td>
<td valign=top><form name="toStation" action="validateToStation.jsp" method=post>
To Station: <input type="text" name="value"
value='<%=pickProcess.getToStation()%>' size=5 maxlength=5 tabindex="2">
<br>
<font size=2 color=red><%=toStation.getErrorMsg("toStation")%></font>
</form></td>
</tr>
<tr bgcolor="#c8d8f8">
<td valign=top colspan="2"><form name="toLoad" action="validateToLoad.jsp" method=post>
To Load: <input type="text" name="value"
value='<%=pickProcess.getToLoad()%>' size=34 maxlength=30 tabindex="3">
<br>
<font size=2 color=red><%=toLoad.getErrorMsg("toLoad")%></font>
</form></td>
</tr>
</table>
</body>
</html>
ValidateFromStation - Servlet:
/**
*
*/
package com.wynright.scanui.action;
import java.io.IOException;
import javax.servlet.RequestDispatcher;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.log4j.Logger;
import com.scanui.model.FromStation;
/**
* @author dystout
* Date: Jul 21, 2016
*
* Description: TODO
*/
public class ValidateFromStation extends HttpServlet{
/**
*
*/
private static final long serialVersionUID = 6201980136409592032L;
protected static Logger logger = Logger.getLogger(ValidateFromStation.class);
protected FromStation fromStation = null;
@Override
public void doPost(HttpServletRequest request, HttpServletResponse response) throws IOException,ServletException{
fromStation = (FromStation)request.getSession(false).getAttribute("fromStation");
fromStation.setValue(request.getParameter("value"));
if(fromStation.validate()){
logger.debug("From Station Validated: " + fromStation.getValue());
RequestDispatcher rd = request.getRequestDispatcher("Station.jsp");
rd.include(request, response);
}else{
logger.debug("From Station INVALID, not validated: " + fromStation.getValue());
RequestDispatcher rd = request.getRequestDispatcher("Station.jsp");
rd.include(request,response);
}
}
}
FromStation Java Bean:
package com.wynright.scanui.model;
import java.util.Hashtable;
import com.daifukuamerica.wrxj.application.Application;
import com.daifukuamerica.wrxj.application.PropertiesStack;
import com.daifukuamerica.wrxj.custom.piolax.dataserver.PiolaxPickServer;
import com.daifukuamerica.wrxj.jdbc.DBCommException;
import com.daifukuamerica.wrxj.jdbc.DBException;
import com.daifukuamerica.wrxj.jdbc.DBResultSet;
import com.wynright.scanui.connectionFactory.DBConnection;
public class FromStation extends ScanField{
@Override
public boolean validate(){
if(value.equals("")){
errors.put("fromStationNumber", "Please scan/enter valid station");
}
String sql = "SELECT SDESTINATIONSTATION FROM ORDERHEADER WHERE SDESTINATIONSTATION = '" + getValue() + "'";
DBResultSet results = null;
if(DBConnection.getWrxjConnection().isConnectionActive()){
try {
results= DBConnection.getWrxjConnection().execute(sql, null);
} catch (DBCommException | DBException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if(results != null && results.getRowCount()!=0){
isValidated = true;
}
//TODO -- Add WRXJ server validate (JSON)
return isValidated;
}
}
Tomcat 7 Web.xml:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
<display-name>RFUI</display-name>
<listener>
<listener-class>com.wynright.scanui.connectionFactory.DBConnectionService</listener-class>
</listener>
<servlet>
<servlet-name>ValidateFromStation</servlet-name>
<servlet-class>com.wynright.scanui.action.ValidateFromStation
</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>ValidateFromStation</servlet-name>
<url-pattern>/ValidateFromStation/*</url-pattern>
</servlet-mapping>
<servlet>
<servlet-name>ValidateLogin</servlet-name>
<servlet-class>com.wynright.scanui.action.ValidateLogin
</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>ValidateLogin</servlet-name>
<url-pattern>/ValidateLogin/*</url-pattern>
</servlet-mapping>
<servlet>
<servlet-name>ValidatePickingFromStation</servlet-name>
<servlet-class>com.wynright.scanui.action.ValidatePickingFromStation
</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>ValidatePickingFromStation</servlet-name>
<url-pattern>/ValidatePickingFromStation/*</url-pattern>
</servlet-mapping>
<servlet>
<servlet-name>ValidatePickingToStation</servlet-name>
<servlet-class>com.wynright.scanui.action.ValidatePickingToStation
</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>ValidatePickingToStation</servlet-name>
<url-pattern>/ValidatePickingToStation/*</url-pattern>
</servlet-mapping>
<servlet>
<servlet-name>ValidateSerialNumber</servlet-name>
<servlet-class>com.wynright.scanui.action.ValidateSerialNumber
</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>ValidateSerialNumber</servlet-name>
<url-pattern>/ValidateSerialNumber/*</url-pattern>
</servlet-mapping>
<servlet>
<servlet-name>ValidateToLoad</servlet-name>
<servlet-class>com.wynright.scanui.action.ValidateToLoad
</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>ValidateToLoad</servlet-name>
<url-pattern>/ValidateToLoad/*</url-pattern>
</servlet-mapping>
<servlet>
<servlet-name>ValidateToStation</servlet-name>
<servlet-class>com.wynright.scanui.action.ValidateToStation
</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>ValidateToStation</servlet-name>
<url-pattern>/ValidateToStation/*</url-pattern>
</servlet-mapping>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
<welcome-file>index.htm</welcome-file>
<welcome-file>index.jsp</welcome-file>
<welcome-file>default.html</welcome-file>
<welcome-file>default.htm</welcome-file>
<welcome-file>default.jsp</welcome-file>
</welcome-file-list>
</web-app>
最佳答案
我想我已经解决了这个问题。我相信我没有正确使用整个 bean。仍然有可能我使用 HttpSession 和 HttpServletRequest 和 HttpServletResponse 的全部目的是错误的,所以如果我是某人请指教。
我的问题是我正尝试使用 jsp 标记来加载我的 bean,如下所示:
<jsp:useBean id="fromStation" class="com.wynright.scanui.model.FromStation" scope="request"/>
它将我的 bean 设置为“请求”的范围,但该请求实际上将在下一次页面加载时被清除,从而导致空值。我重组了我的代码以允许 session 处理我在页面之间传递的对象。我不确定这是否是好的做法,因为我经常听说 session 只应在绝对必要时保留对象。我在别处读到你也可以使用 cookie 来保存这些信息,但 session 似乎更清晰。
这是我修改后的代码,供其他人引用:
在之前的 servlet - ValidateLogin 中,我使用 PickProcess 对象设置 session 属性,该对象包含我的 FromStation(以及所有其他扫描字段)对象:
/**
*
*/
package com.wynright.scanui.action;
import java.io.IOException;
import java.net.InetAddress;
import java.net.UnknownHostException;
import javax.servlet.RequestDispatcher;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import org.apache.log4j.Logger;
import com.daifukuamerica.wrxj.dataserver.standard.StandardUserServer;
import com.daifukuamerica.wrxj.jdbc.DBException;
import com.wynright.scanui.core.UserSession;
import com.wynright.scanui.model.PickProcess;
/**
* @author dystout
* Date: Jul 21, 2016
*
* Description: TODO
*/
public class ValidateLogin extends HttpServlet{
/**
*
*/
private static final long serialVersionUID = 1L;
protected static Logger logger = Logger.getLogger(ValidateLogin.class);
protected UserSession user = new UserSession();
protected int loginCode = -1;
protected StandardUserServer userServer = null;
private PickProcess pickProcess = null;
@Override
public void doPost(HttpServletRequest request, HttpServletResponse response) throws IOException,ServletException{
pickProcess = new PickProcess();
HttpSession session = request.getSession();
user.setSessionId(session.getId());
user.setUserName(request.getParameter("userName"));
user.setPassword(request.getParameter("password"));
if(validateLogin("'" + user.getUserName().toString() + "'", user.getPassword().toString() , user.getSessionId())){
//validate login - redirect (add pickPrcess to session)
logger.debug("Login Successful for: " + user.getUserName() + " Session ID: " + user.getSessionId());
RequestDispatcher rd = request.getRequestDispatcher("station.jsp");
pickProcess.setUserName(user.getUserName());
session.setAttribute("pickProcess", pickProcess);
session.setAttribute("user", user);
rd.include(request, response);
}else{
// retry login with error code
logger.debug("Login Unsuccessful for: " + user.getUserName());
RequestDispatcher rd = request.getRequestDispatcher("login.jsp");
request.setAttribute("user", user);
rd.include(request,response);
}
}
public boolean validateLogin(String username, String password, String sessionId){
InetAddress ip = null;
String machineName = "";
try {
ip = InetAddress.getLocalHost();
machineName = ip.getHostName();
} catch (UnknownHostException e) {
logger.error("*** Could not determine host IP Address during login validation ***");
logger.error(e.getMessage());
}
if(ip!=null){
user.setIpAddress(ip.getHostAddress());
user.setMachineName(machineName);
}else{
logger.error("Unable to retrieve IP Address");
}
try {
logger.debug("Attempting to login user: " + username);
loginCode = userServer.validateLogin(username, password, "'" + machineName + "'", "'" + user.getIpAddress() + "'");
} catch (DBException e) {
logger.error("Error validating login, Database problem exists.");
e.printStackTrace();
}
if(loginCode == userServer.LOGIN_OKAY){
user.setValidated(true);
}else{
switch(loginCode){
case -1:
user.setLoginError("Login Invalid");
break;
case -2:
user.setLoginError("Login has Expired");
break;
case -3:
user.setLoginError("Login is in use");
break;
}
}
// return user.isValidated();
//TODO DEBUG
return true;
}
public ValidateLogin(){
userServer = new StandardUserServer("OracleDB");
}
public StandardUserServer getUserServer() {
return userServer;
}
public void setUserServer(StandardUserServer userServer) {
this.userServer = userServer;
}
}
然后在我的 JSP station.jsp 中,我可以使用表达式语言使用 ${bean.beanvalue} 的标签访问 bean directyle(有关更多信息:Which variables can be accessed with the ${...} syntax in a Struts tag in a JSP page? ) 这是我在 station.jsp 中用来访问值的代码:
<!--
@author - Dylan Stout
7/19/2016
Description: Station Screen -- Takes scanner input to three fields: fromStation, toStation, toLoad
Javascript is used to handle cursor position,incrementing fields, and button-press for load releasing.
PickProcess java bean holds the session information necessary to verify and send/recieve messages to wrxj
back-end.
Each input field is it's own form so no handling for carriage returns is needed (symbol guns usually
send carriage return after scan)
-->
<%@ 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 name="viewport" content="width=240, height=320, user-scalable=no,
initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0" />
<link type="text/css" rel="stylesheet" href="css/scanui.css">
<script type="text/javascript" src="scripts/jquery-3.1.0.min.js"></script>
<script type="text/javascript" src="scripts/formController.js"></script>
<script type="text/javascript" src="scripts/station.js"></script>
<noscript>JavaScript is off. Please enable to use ScanUI.</noscript>
<title>Station Pick - Scan UI</title>
</head>
<body onload="onBodyLoad()">
<table cellpadding=4 cellspacing=2 id="stationTable">
<th bgcolor="#CCCCFF" colspan=2><font size=2>Station Pick : ${pickProcess.userName}</font></th>
<tr bgcolor="#c8d8f8">
<td valign=top>
<form name="fromStation" action="${pageContext.request.contextPath}/ValidateFromStation" method=post id="fromStationForm">
From Station: <input type="text" name="value" id="fromStation" value='${pickProcess.fromStation}' size=5 maxlength=5 tabindex="1">
<font size=2 color=red><br> ${fromStation.error}</font>
</form>
</td>
<td valign=top>
<form name="toStation" action="${pageContext.request.contextPath}/ValidateToStation" method=post id="toStation">
To Station: <input type="text" name="value" value='${pickProcess.toStation}' size=5 maxlength=5 tabindex="2">
<font size=2 color=red><br> ${toStation.error}</font>
</form>
</td>
</tr>
<tr bgcolor="#c8d8f8">
<td valign=top colspan="2"><form name="toLoad" action="${pageContext.request.contextPath}/ValidateToLoad" method=post id="toLoad">
To Load: <input type="text" name="value"
value='${pickProcess.toLoad}' size=34 maxlength=30 tabindex="3">
<font size=2 color=red><br> ${toLoad.error}</font>
</form></td>
</tr>
</table>
</body>
</html>
此时,由于我在 ValidateLogin servlet 中设置了属性:
session.setAttribute("pickProcess", pickProcess);
然后我可以在这个 session 存在的任何地方检索它:
PickProcess pickProcess = (PickProcess)session.getAttribute("pickProcess");
如果没有收到空值,我将无法检索 session 属性。
关于spring - 无法访问Servlet中的Java Bean,getAttribute()返回null,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38514897/
最近开始学习oracle和sql。 在学习的过程中,我遇到了几个问题,我的 friend 在接受采访时被问到这些问题。 SELECT * FROM Employees WHERE NULL IS N
这个问题在这里已经有了答案: Can we subtract NULL pointers? (4 个回答) 关闭 2 个月前。 是否定义了NULL - NULL? (char *)NULL - (ch
是否有推荐的方法(根据 .net Framework 指南)检查 null,例如: if (value == null) {//code1} else {//code2} 或 if (value !=
我正在尝试将值插入数据库,但出现这样的错误任何人都可以告诉我为什么该值为空,如下所示: An exception occurred while executing 'INSERT INTO perso
这个问题在这里已经有了答案: String concatenation with a null seems to nullify the entire string - is that desire
您好,我正在 Android 联系人搜索模块中工作。我正在查询下方运行。 cur = context.getContentResolver().query(ContactsContract.Data.
下面的 SQL 表定义说明了从我的 MYSQL 数据库创建表的语句之一,该数据库是由我公司的前开发人员开发的。 DROP TABLE IF EXISTS `classifieds`.`category
我主要有应用程序开发背景。在编程语言中 variable == null或 variable != null有效。 当涉及到 SQL 时,以下查询不会给出任何语法错误,但也不会返回正确的结果。 sel
我在尝试检查某些元素是否为 NULL 时遇到段错误或不。任何人都可以帮忙吗? void addEdge(int i, int j) { if (i >= 0 && j > 0)
在 SQL 服务器中考虑到以下事实:Col1 和 Col2 包含数值和 NULL 值 SELECT COALESCE(Col1,Col2) 返回一个错误:“COALESCE 的至少一个参数必须是一个不
在 SQL 服务器中考虑到以下事实:Col1 和 Col2 包含数值和 NULL 值 SELECT COALESCE(Col1,Col2) 返回一个错误:“COALESCE 的至少一个参数必须是一个不
下面查询的关系代数表达式是什么?我找不到“Is Null”的表达式。 SELECT reader.name FROM reader LEFT JOIN book_borrow ON reader.ca
我正在尝试使用三元运算符来检查值是否为 null 并返回一个表达式或另一个。将此合并到 LINQ 表达式时,我遇到的是 LINQ 表达式的 Transact-SQL 转换试图执行“column = n
我在给定的代码中看到了以下行: select(0, (fd_set *) NULL, (fd_set *) NULL, (fd_set *) NULL, &timeout); http://linux
var re = /null/g; re.test('null null'); //> true re.test('null null'); //> true re.test('null null')
这个问题在这里已经有了答案: 关闭 13 年前。 我今天避开了一场关于数据库中空值的激烈辩论。 我的观点是 null 是未指定值的极好指示符。团队中有意见的其他每个人都认为零和空字符串是可行的方法。
由于此错误,我无法在模拟器中运行我的应用: Error:null value in entry: streamOutputFolder=null 或 gradle - Error:null value
我正在尝试在 Android 应用程序中创建电影数据库,但它返回错误。知道这意味着什么吗? public Cursor returnData() { return db.query(TABLE
我一直在检查浏览器中的日期函数以及运行时间 new Date (null, null, null); 在开发工具控制台中,它给出了有效的日期 Chrome v 61 回归 Sun Dec 31 189
为什么 NA==NULL 会导致 logical (0) 而不是 FALSE? 为什么 NULL==NULL 会导致 logical(0) 而不是 TRUE? 最佳答案 NULL 是一个“零长度”对象
我是一名优秀的程序员,十分优秀!