Хранение переменных сеанса в MVC между сервлетом и JSP (статус ошибки 500) - PullRequest
0 голосов
/ 21 октября 2018

Когда я запускаю свою динамическую веб-страницу, я получаю сообщение об ошибке «java.lang.NumberFormatException: null» в своей консоли, когда вижу, что я получаю страницу состояния 500.

Код должен просить пользователя угадать число от 0 до 1000.Если пользователь угадывает неправильно, он позволяет ему снова угадывать, используя те же переменные сеанса (целевое число и количество догадок сохраняются).Это продолжается до тех пор, пока пользователь не угадает правильно, что такое целевое число.Я также избегаю использования опции скрытого текста для хранения переменных.

Я уже посмотрел, что означает сообщение об ошибке, но я не мог понять, к чему оно относится, так как ошибка состояния очень расплывчатая.

Любая помощь приветствуется ...

Сообщение об ошибке из консоли:

Oct 20, 2018 11:59:12 PM org.apache.catalina.core.StandardWrapperValve invoke
SEVERE: Servlet.service() for servlet [controllers.GameServlet] in context with path [/GuessingGame_MVC_Version] threw exception
java.lang.NumberFormatException: null
    at java.lang.Integer.parseInt(Unknown Source)
    at java.lang.Integer.parseInt(Unknown Source)
    at controllers.GameServlet.doPost(GameServlet.java:47)
    at controllers.GameServlet.doGet(GameServlet.java:38)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:634)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
    at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:199)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:490)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:139)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92)
    at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:668)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:74)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:343)
    at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:408)
    at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
    at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:770)
    at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1415)
    at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
    at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
    at java.lang.Thread.run(Unknown Source)

index.jsp (первая страница):

<%@ page language="java" contentType="text/html; charset=US-ASCII"
    pageEncoding="US-ASCII"%>

<%@ page import="model.GameNumber" %>


<!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=US-ASCII">
<title>Guessing Game - MVC Version</title>
</head>
<body>
  <h1>Guessing Game - MVC Version</h1>

  <p>
     Welcome to our guessing game!
  </p>

  <p>
     Please guess a number between 0 and 1000.
  </p>

  <form name="guessForm" action="doGuess" method="get">
     <label>
        Guess 1: 
     </label>
     <input type="text" name="guess" /><br />
     <input type="submit" name="submit" value="Make Guess">

  </form>


</body>
</html>

GameServlet.java (сервлет):

package controllers;

import java.io.IOException;

import javax.servlet.RequestDispatcher;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.annotation.WebInitParam;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.util.*;

import model.GameNumber;

/**
 * Servlet implementation class GameServlet
 */
@WebServlet(
        description = "A servlet to control our simple guessing game", 
        urlPatterns = { 
                "/GameServlet", 
                "/doGuess"
        }, 
        initParams = { 
                @WebInitParam(name = "Guesses", value = "1"), 
                @WebInitParam(name = "Minimum", value = "0"),
                @WebInitParam(name = "Maximum", value = "1000")
        })
public class GameServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;

    Random rand = new Random();
    int target = rand.nextInt(1000);

    int guesses=1;

    /**
     * @see HttpServlet#HttpServlet()
     */
    public GameServlet() {
        super();
        // TODO Auto-generated constructor stub
    }

    /**
     * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
     */
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        this.doPost(request, response);
    }

    /**
     * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
     */
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {


        // get input - guess
        GameNumber guess = new GameNumber(Integer.parseInt(request.getParameter("guess")));

        // initialize output
        String msg = "";
        String url = "/guess.jsp";

        // compare the guess with the target
       if( guess.getValue() == target ){
           // winner
           msg = "Correct! You got it in " + guesses + " guesses.";
           url = "/correct.jsp";
       } else {
           // next guess
           guesses++;
           if ( guess.getValue() < target ) {
               //low
               msg = "Incorrect guess! Guess higher next time.";
           } else {
               // high
               msg = "Incorrect guess! Guess lower next time.";
           }
       }
       //store guesses and target as session attributes
       HttpSession session = request.getSession();
        session.setAttribute("target", target);
        session.setAttribute("guesses", guesses);

       // add values to request object to pass to the destination
       request.setAttribute("msg", msg);


       // send control to the next component
       RequestDispatcher dispatcher = request.getRequestDispatcher(url);
       dispatcher.forward(request, response);

       RequestDispatcher dispatcherr = getServletContext().getRequestDispatcher(url);
       dispatcherr.forward(request, response);
    }

}

guess.jsp:

<%@ page language="java" contentType="text/html; charset=US-ASCII"
    pageEncoding="US-ASCII"%>

<%@ page import="model.GameNumber" %>

<%
  // get the inputs from the request and session attributes

  String msg = (String) request.getAttribute("msg");

  Integer targett = (Integer) session.getAttribute("target");
  int target = targett.intValue();

  Integer guessess = (Integer) session.getAttribute("guesses");
  int guesses = guessess.intValue();
  // output the form to the client
%>

<!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=US-ASCII">
<title>Guessing Game - MVC Version</title>
</head>
<body>
  <h1>Guessing Game - MVC Version</h1>

  <p>
     <%= msg %>
  </p>

  <form name="guessForm" action="doGuess" method="get">
     <label>
        Guess <%= guesses %>: 
     </label>
     <input type="text" name="guess" /><br />
     <input type="submit" name="submit" value="Make Guess">
  </form>
</body>
</html>

correct.jsp:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>

<%
  String msg = (String) request.getAttribute("msg");
%>
<!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=UTF-8">
<title>Guessing Game - MVC Version</title>
</head>
<body>
<H1>Guessing Game - MVC Version</h1>

<%= msg %>

<p>
<a href=index.jsp>
  Play Again
</a>
</p>
</body>
</html>

GameNumber (модель):

package model;

import java.util.Random;

public class GameNumber {

    private int value;

    /**
     * 
     */
    public GameNumber() {
        value = 0;
    }

    /**
     * @param value
     */
    public GameNumber(int value) {
        if (value < 0) {
            this.value = 0;
        } else {
           this.value = value;
        }
    }

    /**
     * @return the value
     */
    public int getValue() {
        return value;
    }

    /**
     * @param value the value to set
     */
    public void setValue(int value) {
        if (value < 0) {
            this.value = 0;
        } else {
           this.value = value;
        }
    }

    /**
     * 
     * A simple method that sets value to a random integer between minimum and maximum
     * @param minimum the minimum value in the range
     * @param maximum the maximum value in the range
     */
    public void setRandom(int minimum, int maximum){
        Random random = new Random();
        this.value = random.nextInt(maximum - minimum) + minimum;
    }

    /**
     * a simple method to adjust the value up 1 unit
     */
    public void increment(){
        this.value++;
    }


}

Попробуйте поймать на догадку(Выдает такую ​​же ошибку):

GameNumber guess = null;
        try {
        guess = new GameNumber(Integer.parseInt(request.getParameter("guess")));
        } catch (NumberFormatException e) {
            System.out.println("Number format Excdption!");
        }

Ответы [ 2 ]

0 голосов
/ 21 октября 2018

Ваш код выглядит нормально, и согласно вашим комментариям кажется, что вы не передаете правильные значения сервлету.

Вы правы, когда говорите, что значения передаются сервлету как строки.Давайте попробуем понять, что такое NumberFormatException.Из документов:

Брошенный, чтобы указать, что приложение попыталось преобразовать строку в один из числовых типов, но строка не имеет соответствующего формата.

Приведенный ниже код будет работать, так как строка «10» может быть преобразована в целое число.

    String str = "10";
    int i = Integer.parseInt(str);

Но это приведет к NumberFormatException

    String str = "hi";
    int i = Integer.parseInt(str);

В вашем случае выпередают String , который не может быть преобразован в int , следовательно, он терпит неудачу.

0 голосов
/ 21 октября 2018

Когда я развернул ваше приложение с упомянутыми jsp и servlet, оно будет работать нормально, но я заметил, что в консоли tomcat на вашем GameServlet есть некоторая ошибка, так как вы переадресовываете запрос дважды, что уже было сделано

т.е. java.lang.IllegalStateException: невозможно переслать после подтверждения ответа

Следовательно, в вашем Java GameServlet в разделе doPost

прокомментируйте последнюю строку (упомянутую ниже)

  RequestDispatcher dispatcherr = getServletContext().getRequestDispatcher(url);
   dispatcherr.forward(request, response);

и добавьте

return; // not a must but helps in certain situations

к сообщению об ошибке, которое вы упомянули. Это произойдет, только если вы передадите строковое сообщение в текстовом поле. Дополнительная проверка можетприменяться для того же во время выполнения.

...