English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

Servlet ページ自動リフレッシュ

例えば、ライブゲームのスコアや株価市場の状況、為替レートを表示するページがあると仮定します。これらのページのすべてに対して、ページを定期的にリフレッシュする必要があります。

Java Servletは、ページが指定された時間間隔で自動的にリフレッシュされるメカニズムを提供します。

ページをリフレッシュする最も簡単な方法は、レスポンスオブジェクトのメソッドを使用することです。 setIntHeader()以下は、このメソッドの定義です:

public void setIntHeader(String header, int headerValue)

このメソッドは、"Refresh"ヘッダー情報と時間間隔を表す整数値(秒単位)をブラウザに送信します。

自動リフレッシュページサンプル

このサンプルでは、Servletがどうやって自動リフレッシュページを使用するかを示しています。 setIntHeader() メソッドで設定 Refresh ヘッダー情報を送信することで、ページの自動リフレッシュを実現します。

package com.w;3codebox.test;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.Calendar;
import java.util.GregorianCalendar;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
 * Servlet 実装クラス Refresh
 */
@WebServlet("/Refresh")
public class Refresh extends HttpServlet {
    private static final long serialVersionUID = 1L;
   
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // 自動リフレッシュのイベント間隔を設定 5 秒
        response.setIntHeader("Refresh", 5);
     
        // 設定する応答内容タイプ
        response.setContentType("text/html;charset=UTF-8");
     
        // 現在の時間を取得
        Calendar calendar = new GregorianCalendar();
        String am_pm;
        int hour = calendar.get(Calendar.HOUR);
        int minute = calendar.get(Calendar.MINUTE);
        int second = calendar.get(Calendar.SECOND);
        if(calendar.get(Calendar.AM_PM) == 0)
            am_pm = "AM";
        else
            am_pm = "PM";
     
        String CT = hour+":"+ minute +":"+ second +" "+ am_pm;
        
        PrintWriter out = response.getWriter();
        String title = "使用 Servlet 自動リフレッシュページ";
        String docType = "<!DOCTYPE html> \n";
        out.println(docType) +
            "<html>\n" +
            "<head><title>" + タイトル + "</タイトル></head>\n"+
            "<body bgcolor=\"#f0f0f0\">\n" +
            "<h1 align=\"center\">" + タイトル + "</h1>\n" +
            "<p>現在の時間は:" + CT + "</p>\n");
    }
}

今、上記の Servlet をコンパイルし、web.xml ファイルに以下のエントリを作成します:

<?xml version="1.0" encoding="UTF-8"?>
<ウェブ-app>
  <スレルブ>
    <スレルブ-名前>Refresh</スレルブ-名前>
    <スレルブ-クラス>com.w3codebox.test.Refresh</スレルブ-クラス>
  </スレルブ>
  <スレルブ-マッピング>
    <スレルブ-名前>Refresh</スレルブ-名前>
    <URL-パターン>/TomcatTest/Refresh</URL-パターン>
  </スレルブ-マッピング>
</web-app>

現在、以下の URL でアクセスします://localhost:8080/TomcatTest/Refresh をクリックしてこの Servlet を呼び出します。それにより、以下のように隔 5 秒単位で現在のシステム時間を表示します。この Servlet を実行し、結果を確認するために待ちます:

Servlet を使用してページを自動的にリフレッシュする

現在の時間は:9:44:50 PM