0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

【Java】pageディレクティブ(JSPページの表示に関する設定)

Posted at

pageディレクティブ

【説明】

pageディレクティブ内へは、主にページの表示に関する設定を記述します。

【使用場面】

JSPファイルの一番上に記述する。

//【START】ディレクティブ =============
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
//【 END 】ディレクティブ =============


<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>

【基本構文】

構文は次の通りです。

<%@ page
   [ language="java" ]
   [ extends="package.class" ]
   [ import="{package.class | package.*}, ..." ]
   [ session="true|false" ]
   [ buffer="none|8kb|sizekb" ]
   [ autoFlush="true|false" ]
   [ isThreadSafe="true|false" ]
   [ info="text" ]
   [ errorPage="relativeURL" ]
   [ contentType="mimeType [ ; charset=characterSet ]" |
      "text/html ; charset=ISO-8859-1" ]
   [ isErrorPage="true|false" ]
   [ pageEncoding="characterSet | ISO-8859-1" ]
   [ isELIgnored="true|false"]
%>

この中で設定したい項目だけを取り出してpageディレクティブに設定します。例えば次の通りです。

<%@ page buffer="5kb" autoFlush="false" %>

【項目の詳細】

language(JSPページで使用する言語を指定)

  • デフォルト値:「java」
  • 現状ではJavaしか指定できないため設定する必要はありません。

extends

  • JSPページを他のクラスのサブクラスにする場合に、スーパークラスを指定
  • この項目の詳細は不明

import(JSPページでクラスをimportする)

  • Javaにおける「import」文と同じ役割
  • JSPではデフォルトで次のクラスをimportしているため改めてimportしなくても利用することが可能

session (セッションを有効にするかどうかを指定)

  • 「true」又は「false」を記述
  • デフォルトは「true」

buffer (JSPページから出力されるデータをバッファしてからクライアントに返すかどうかを指定)

  • デフォルトは「8kb」
  • 「none」を指定
    • バッファされずにクライアントに出力データが送られる
  • 「8kb」のようにキロバイト単位で容量を指定した場合は
    • 出力データがバッファがいっぱいになるまで待ってからクライアントにまとめて送信される為、効率よく送信が行える。

autoFlush (バッファを超える出力データが合った場合の処理について指定)

  • バッファを使用する場合に使用
  • 「true」又は「false」を記述
  • 「true」の場合
    • バッファがいっぱいになった場合には自動的にクライアントにデータを送信します。
  • 「false」の場合
    • バッファがいっぱいになると例外が発生
    • 「buffer」に「none」を指定した場合以外は「autoFlash」に「false」は設定しないほうがいい

isThreadSafe (スレッドセーフで実行するかどうかを指定)

  • 「true」又は「false」を記述
  • デフォルトは「true」
  • 「true」の場合
    • 複数のリクエストが合った場合に同時に実行されることを許可
    • 「false」に設定した場合はリクエストの到着順に1つずつ処理

info (JSPページに関する任意の情報を記述)

  • 製作者や作成年月日など

errorPage (エラーが発生した場合に表示するページへのパスを記述)

  • 指定しない場合: デフォルトのエラーページが表示

isErrorPage (JSPページがエラー表示用のページかどうかを指定)

  • 「true」又は「false」を記述
  • デフォルトは「false」
  • 「errorPage」でエラー表示先を指定した場合には「errorPage」を「true」に設定する
  • 「true」の場合は「exception」オブジェクトが利用可能になるため、このオブジェクトを使ってエラーに関する情報を取得することが出来る

contentType (JSPページのデータ型と必要であれば文字コードをMIMEタイプを使って記述)

  • JPEG画像を表すページであれば「image/jpeg」
  • テキストファイルであれば「text/plain」を記述
  • デフォルトで設定されているのはHTMLファイルで「text/html;charset=ISO-8859-1」
  • 文字コードを指定する場合はセミコロン(;)の後に「charset=文字コード」の書式で続けて記述する

文字コードはデフォルトで「ISO-8859-1」(通称Latin-1)が指定されています。日本語を使う場合にはデフォルトのままでは文字化けしますので、必ず日本語の文字コードを指定して下さい。Windwos環境であれば「text/html;charset=Shift_Jis」又は「text/html;charset=Windows-31J」などでいいかと思います。

今までのサンプルでも次のように記述していました。

pageEncoding (JSPページの文字コードを指定)

  • デフォルトは「ISO-8859-1」
  • デフォルトの値は「contentType」で指定した文字コード
  • 指定は不要

isElIgnored(EL式を適用するかどうかを指定)

  • trueの場合は適用しない
  • falseを設定すると適用
  • デフォルトは「false」
0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?