Tomcatエラーメッセージ(変数編) JSP
Duplicate local variable 変数名
「Duplicate local variable 変数名」は同じ名前の変数を重複して宣言しているために起きるエラーです。
サンプル
<%@ page contentType="text/html; charset=Windows-31J"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html> <head> <title>JSPサンプル</title> <meta http-equiv="content-type" content="text/html; charset=Windows-31J"> </head> <body> <p> <% int i = 10; int i = 20; //エラー発生 %> <%=i%> </p> </body> </html>
上記のjspファイルを実行すると下記のエラーが表示されます。
org.apache.jasper.JasperException: JSPのクラスをコンパイルできません JSPファイル: /Test1.jsp の中の11行目でエラーが発生しました 生成されたサーブレットのエラーです: Duplicate local variable i
12行目で変数iを宣言したのに、13行目でも同じ名前iで宣言しているため起きたエラーです。
javaでは同じ名前の変数を複数宣言することはできません。
※「11行目でエラーが発生しました」とあるが実際にエラーが起きているのは13行目です。
JSPの場合、エラーが含まれる<% %>開始タグの行番号が表示されるので注意が必要です。
対処法1
<%@ page contentType="text/html; charset=Windows-31J"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html> <head> <title>JSPサンプル</title> <meta http-equiv="content-type" content="text/html; charset=Windows-31J"> </head> <body> <p> <% int i = 10; i = 20; //12行目で宣言されたiを使う %> <%=i%> </p> </body> </html>
対処法1の表示結果
20
対処法2
<%@ page contentType="text/html; charset=Windows-31J"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html> <head> <title>JSPサンプル</title> <meta http-equiv="content-type" content="text/html; charset=Windows-31J"> </head> <body> <p> <% int i = 10; int j = 20; //iは12行目で宣言されてるので別名jで変数を宣言した %> <%=i%> </p> </body> </html>
対処法2の表示結果
10
変数名 cannot be resolved
「変数名 cannot be resolved」は宣言されていない変数を使用したために起きるエラーです。
サンプル
<%@ page contentType="text/html; charset=Windows-31J"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html> <head> <title>JSPサンプル</title> <meta http-equiv="content-type" content="text/html; charset=Windows-31J"> </head> <body> <p> <% int i = 10; %> <%=j%> </p> </body> </html>
上記のjspファイルを実行すると下記のエラーが表示されます。
org.apache.jasper.JasperException: JSPのクラスをコンパイルできません JSPファイル: /Test2.jsp の中の14行目でエラーが発生しました 生成されたサーブレットのエラーです: j cannot be resolved
14行目で宣言されていない変数jを表示しようとしたため起きたエラーです。
対処法
<%@ page contentType="text/html; charset=Windows-31J"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html> <head> <title>JSPサンプル</title> <meta http-equiv="content-type" content="text/html; charset=Windows-31J"> </head> <body> <p> <% int i = 10; int j = 20; //変数jを使う前に宣言・初期化する %> <%=j%> </p> </body> </html>
表示結果
20
The local variable 変数名 may not have been initialized
「The local variable 変数名 may not have been initialized」は初期化されていない変数を使用したために起きるエラーです。
サンプル
<%@ page contentType="text/html; charset=Windows-31J"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html> <head> <title>JSPサンプル</title> <meta http-equiv="content-type" content="text/html; charset=Windows-31J"> </head> <body> <p> <% int j; %> <%=j%> </p> </body> </html>
上記のjspファイルを実行すると下記のエラーが表示されます。
org.apache.jasper.JasperException: JSPのクラスをコンパイルできません JSPファイル: /Test1.jsp の中の14行目でエラーが発生しました 生成されたサーブレットのエラーです: The local variable j may not have been initialized
14行目で初期化されていない変数jを表示しようとしたため起きたエラーです。
対処法
<%@ page contentType="text/html; charset=Windows-31J"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html> <head> <title>JSPサンプル</title> <meta http-equiv="content-type" content="text/html; charset=Windows-31J"> </head> <body> <p> <% int j = 20; //変数jに値をいれて初期化する %> <%=j%> </p> </body> </html>
表示結果
20