1

アプレットで単純なユーザーの詳細(名前、電話番号、性別(オプションボックス))を取得し、JSPに詳細を表示しようとしています.3つの詳細すべてをHashMapに入れて、出力ストリームに送信します。アプレットコードは次のとおりです。

    try 
    {
        userUrl = "http://localhost:8080/AppletTest/display.jsp";

       /* In the web.xml file I have mapped display.jsp to the Servlet */

        testServlet = new URL(userUrl.toString());
        servletConnection = testServlet.openConnection();

        servletConnection.setDoOutput(true);
        servletConnection.setRequestProperty("Content-Type","application/octet-stream");

        ObjectOutputStream oos1 = new ObjectOutputStream(servletConnection.getOutputStream());

        /* DataMap is the HashMap Containing values */

        oos1.writeObject(dataMap);
        oos1.flush();
        oos1.close();

        //  Thread.currentThread().sleep(5000);

    }
    catch(Exception ie)
    {
        ie.printStackTrace();
    }

    // Finally call servlet by going to that page.

    getAppletContext().showDocument(userUrl, "_self");

サーブレットを使用しているときに、HashMapを取得し、それをjspページに転送して表示します。

    try
    {
        System.out.println("In Servlet");

        ObjectInputStream inputFromApplet = new ObjectInputStream(request.getInputStream());
        HashMap<String,String> receievedData = (HashMap<String,String>) inputFromApplet.readObject();

        request.setAttribute("dataMap",receievedData);
        request.getRequestDispatcher("display1.jsp").forward(request, response);

        inputFromApplet.close();
    }
    catch (ClassNotFoundException e)
    {
        e.printStackTrace();
    }

ここの質問のコメントで尋ねられたように、Sysout( "サーブレット内")が出力されます。しかし、例外がスローされます

In Servlet        
SEVERE: Servlet.service() for servlet jsp threw exception java.io.EOFException
at java.io.ObjectInputStream$PeekInputStream.readFully(ObjectInputStream.java:2280)
at java.io.ObjectInputStream$BlockDataInputStream.readShort(ObjectInputStream. java:2749)
at java.io.ObjectInputStream.readStreamHeader(ObjectInputStream.java:779)
at java.io.ObjectInputStream.<init>(ObjectInputStream.java:279)
at org.apache.jsp.display1_jsp._jspService(display1_jsp.java:71)
at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:377)
at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:313)
at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:260)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:298)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:852)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:588)
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)
at java.lang.Thread.run(Thread.java:662)

私は何を間違っているのですか。助けてください。

4

2 に答える 2

0

アプレットによって例外がスローされていると思われますが、Javaコンソールでまだ例外が検出されていません。

于 2011-08-09T00:19:49.770 に答える
0

私が正しく理解していればあなたは:

  1. サーブレットへのリクエストの送信
  2. その呼び出しのe入力ストリームからの読み取り
  3. その呼び出しへの応答としてjspを送信する
  4. ユーザーをアプレットから同じサーブレットにリダイレクトする
  5. これにより、シリアル化されていない2番目のリクエストが発生します
  6. サーブレットはこの2番目のリクエストで失敗します

残念ながら、これは機能しません。2つのリクエストを処理するには、2つのサーブレット(またはオプションのパラメーターを持つ同じサーブレット)を使用する必要があります。1つは入力ストリームから読み取り、セッションに書き込み、もう1つはセッションから取得してjspに表示します。

于 2011-08-09T00:28:08.147 に答える