计算器的Servlet和html表单

时间:2014-08-01 10:25:25

标签: html eclipse servlets

我想制作基本上加,减,乘和除两个数的计算器。为了实现这一点,我首先设计了一个HTML格式的表单,并希望在服务器上计算答案,所以我在servlet上编写了一个代码但是当我点击我的表单的提交按钮时它什么都不做。 注意:我正在工作eclipse,所以你被要求回答关于eclipse的问题。 Calculator.java:

package mypackage;

import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;

public class Calculator extends HttpServlet
{
    public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException
    {
        try
        {
        response.setContentType("text/html");
        PrintWriter out= response.getWriter();
        int a1= Integer.parseInt(request.getParameter("n1"));
        int a2= Integer.parseInt(request.getParameter("n2"));
        if(request.getParameter("r1")!=null)
        {
            out.println("<h1>Addition</h1>"+(a1+a2));
        }
        if(request.getParameter("r2")!=null)
        {
            out.println("<h1>Substraction</h1>"+(a1-a2));
        }
        if(request.getParameter("r3")!=null)
        {
            out.println("<h1>Multiplication</h1>"+(a1*a2));
        }if(request.getParameter("r1")!=null)
        {
            out.println("<h1>Division</h1>"+(a1/a2));
        }
        }
        catch(Exception e)
        {

        }
    }
}

的index.html

<!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>Calculator</title>
</head>
<body>
<h1 style="text_align=center">Calculator</h1>
<form method="get" action="/Servlet">
<label>first number:</label>
<input type="text" name="n1" />
<br />
<label>Second number : </label>
<input type="text" name="n2" />
<br />
 <div>
<label>
<input type="radio" name="r1" value="add" />addition
<br />
</label>
<input type="radio" name="r2" value="sub" />subtraction 
<br />
<input type="radio" name="r3" value="mul" />multiplication
<br />
<input type="radio" name="r4" value="div" />division
<br /> 
</div>
<input type="button" value="submit" />
</form>
</body>
</html>

的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" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" 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>Servlet</display-name>
  <servlet>
    <servlet-name>Servlet</servlet-name>
    <servlet-class>mypackage.Calculator</servlet-class>
  </servlet>
  <servlet-mapping>
    <servlet-name>Servlet</servlet-name>
    <url-pattern>/firstHomePage</url-pattern>
  </servlet-mapping>
  <welcome-file-list>
  <welcome-file>index.html</welcome-file>
  </welcome-file-list>
</web-app>

1 个答案:

答案 0 :(得分:1)

您已在web.xml中为servlet名称Calculator

编写了url-pattern'firstHomePage'
        <servlet-mapping>
         <servlet-name>Servlet</servlet-name>
         <url-pattern>/firstHomePage</url-pattern>
          </servlet-mapping>

这样你应该在表格行动中写下什么,即

      <form action="firstHomePage" method="get">

(你不写/表格行动)

无论你在内部编写什么内容,当找到匹配时,在所有servlet映射的url-pattern中检查相应的servlet名称并搜索相应的servlet类。这就是它的工作原理。

希望你得到答案:)

更新:写

      <input type="submit">

NOT BUTTON 否则您的表单将不会提交。 如果您使用button,则必须编写一些javascript。