JSP代碼
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>$Title$</title>
</head>
<body>
hello world
</body>
</html>
底層Servlet
package org.apache.jsp;
import javax.servlet.*;
import javax.servlet.http.*;
import javax.servlet.jsp.*;
public final class index_jsp extends org.apache.jasper.runtime.HttpJspBase
implements org.apache.jasper.runtime.JspSourceDependent,
org.apache.jasper.runtime.JspSourceImports {
private static final javax.servlet.jsp.JspFactory _jspxFactory =
javax.servlet.jsp.JspFactory.getDefaultFactory();
private static java.util.Map<java.lang.String,java.lang.Long> _jspx_dependants;
private static final java.util.Set<java.lang.String> _jspx_imports_packages;
private static final java.util.Set<java.lang.String> _jspx_imports_classes;
static {
_jspx_imports_packages = new java.util.HashSet<>();
_jspx_imports_packages.add("javax.servlet");
_jspx_imports_packages.add("javax.servlet.http");
_jspx_imports_packages.add("javax.servlet.jsp");
_jspx_imports_classes = null;
}
private volatile javax.el.ExpressionFactory _el_expressionfactory;
private volatile org.apache.tomcat.InstanceManager _jsp_instancemanager;
public java.util.Map<java.lang.String,java.lang.Long> getDependants() {
return _jspx_dependants;
}
public java.util.Set<java.lang.String> getPackageImports() {
return _jspx_imports_packages;
}
public java.util.Set<java.lang.String> getClassImports() {
return _jspx_imports_classes;
}
public javax.el.ExpressionFactory _jsp_getExpressionFactory() {
if (_el_expressionfactory == null) {
synchronized (this) {
if (_el_expressionfactory == null) {
_el_expressionfactory = _jspxFactory.getJspApplicationContext(getServletConfig().getServletContext()).getExpressionFactory();
}
}
}
return _el_expressionfactory;
}
public org.apache.tomcat.InstanceManager _jsp_getInstanceManager() {
if (_jsp_instancemanager == null) {
synchronized (this) {
if (_jsp_instancemanager == null) {
_jsp_instancemanager = org.apache.jasper.runtime.InstanceManagerFactory.getInstanceManager(getServletConfig());
}
}
}
return _jsp_instancemanager;
}
public void _jspInit() {
}
public void _jspDestroy() {
}
public void _jspService(final javax.servlet.http.HttpServletRequest request, final javax.servlet.http.HttpServletResponse response)
throws java.io.IOException, javax.servlet.ServletException {
final java.lang.String _jspx_method = request.getMethod();
if (!"GET".equals(_jspx_method) && !"POST".equals(_jspx_method) && !"HEAD".equals(_jspx_method) && !javax.servlet.DispatcherType.ERROR.equals(request.getDispatcherType())) {
response.sendError(HttpServletResponse.SC_METHOD_NOT_ALLOWED, "JSPs only permit GET, POST or HEAD. Jasper also permits OPTIONS");
return;
}
final javax.servlet.jsp.PageContext pageContext;
javax.servlet.http.HttpSession session = null;
final javax.servlet.ServletContext application;
final javax.servlet.ServletConfig config;
javax.servlet.jsp.JspWriter out = null;
final java.lang.Object page = this;
javax.servlet.jsp.JspWriter _jspx_out = null;
javax.servlet.jsp.PageContext _jspx_page_context = null;
try {
response.setContentType("text/html;charset=UTF-8");
pageContext = _jspxFactory.getPageContext(this, request, response,
null, true, 8192, true);
_jspx_page_context = pageContext;
application = pageContext.getServletContext();
config = pageContext.getServletConfig();
session = pageContext.getSession();
out = pageContext.getOut();
_jspx_out = out;
out.write("\r\n");
out.write("\r\n");
out.write("<html>\r\n");
out.write("<head>\r\n");
out.write(" <title>$Title$</title>\r\n");
out.write("</head>\r\n");
out.write(" <body>\r\n");
out.write("\r\n");
out.write(" </body>\r\n");
out.write("</html>\r\n");
out.write("\r\n");
} catch (java.lang.Throwable t) {
if (!(t instanceof javax.servlet.jsp.SkipPageException)){
out = _jspx_out;
if (out != null && out.getBufferSize() != 0)
try {
if (response.isCommitted()) {
out.flush();
} else {
out.clearBuffer();
}
} catch (java.io.IOException e) {}
if (_jspx_page_context != null) _jspx_page_context.handlePageException(t);
else throw new ServletException(t);
}
} finally {
_jspxFactory.releasePageContext(_jspx_page_context);
}
}
}
Jsp的page指令
<%@ page language="java" %> <!-- 聲明轉譯的語言 -->
<%@ page import="java.util.Arrays" %> <!-- 導包 -->
<%@ page pageEncoding="utf-8" %> <!-- 設置jsp的數據保存的編碼格式 -->
<%@ page contentType="text/html;charset=UTF-8" %> <!-- 設置數據的響應編碼 -->
<!-- 設置session的狀態,默認爲true,也就轉譯的servlet文件中默認session是開啓的,使用false關閉-->
<%@ page session="false" %>
<%@ page isErrorPage="true" %> <!-- 默認爲false,開啓true表示開啓異常對象的使用 -->
<%@ page errorPage="login/error.jsp" %> <!-- 當jsp運行出現異常時跳轉到指定的頁面 -->
page指令的作用:設置jsp轉譯的時候的一些配置信息
jsp的局部代碼塊和全局代碼塊
<%
out.print("局部代碼塊");
%>
<%!
String str = "全局聲明代碼塊";
public static void test(){
System.out.println("全局代碼塊聲明");
}
%>
局部代碼塊可以運行程序,所聲明的變量會被默認轉譯到-jspService方法裏,相當於寫servlet service方法裏面的代碼
全局聲明代碼塊,只能聲明或定義全局變量,無法運行程序。所聲明的java代碼在被轉譯時會被轉譯成全局的代碼
JSP靜態引入和動態引入
問題:
不同的jsp頁面會使用相同的資源,如果將資源在每個jsp頁面都單獨聲明則會造成代碼沉餘量過高,不易於代碼的維護和升級
解決:
使用靜態引入和動態引入的方式
使用:
靜態引入
<%@include file="static.jsp"%> <!-- 要引入的資源的相對路徑 -->
特點:
被引入的jsp文件和原有的jsp文件被轉譯成一個java文件使用
動態引入
<jsp:include page="static.jsp"></jsp:include>
特點:
被引入的文件會被單獨轉譯,原有的jsp文件會調用被引入jsp文件。
注意:動態引入的相關jsp文件中可以聲明同名變量。
jsp的forword標籤學習
<!-- 跳轉其他jsp頁面 -->
<jsp:forward page="login/succed.jsp"></jsp:forward><!-- 要轉發的jsp路徑 -->
jsp之間的資源轉發:
問題:
不同的jsp在處理請求時,有可能會將當前的請求轉發給另外的jsp進行處理。
解決:
使用forward動作指令
特點:
從當前jsp跳轉到另一個jsp
forward代碼練習
<html>
<head>
</head>
<body>
<h3>forward轉發標籤學習</h3>
<hr />
<%
int a=1;
if(a>2){
%>
<b>歡迎訪問本網站</b>
<%
}else{
%>
<!--轉發其他jsp頁面 -->
<jsp:forward page="common.jsp">
<jsp:param value="zhangsan" name="uname"/>
</jsp:forward>
<%} %>
</body>
</html>
跳轉到
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title></title>
</head>
<%
request.setCharacterEncoding("utf-8");
String uname=request.getParameter("uname");
System.out.println(uname);
%>
<body>
<b>這位客官你的請求被屏蔽了,請及時續費</b>
</body>
</html>
jsp內置對象學習
內置對象:
jsp在轉譯成其對應的java文件(也就是Servlet)時,會默認在_jspService方法中聲明幾個對象。
特點:
我們可以在jsp頁面中聲明java局部代碼塊,直接使用內置對象
對象:
pageContext 頁面上下文對象,此對象封存了另外八個對象
request 封存了請求相關數據,由服務器創建
session 解決了同一個不同請求之間的數據共享問題
application ServletContext對象,解決了不同用戶之間的數據共享問題
out 響應數據的對象,交於response對象,out對象底層使用了緩衝區,out對象效率高於response
response 響應對象,設置編碼格式
page 代表當前被執行的jsp轉譯的java文件的對象
config ServletConfig對象,使用此對象完成資源的初始化
exception jsp頁面的異常對象,封存了異常信息。
注意:
對象名字必須是轉譯好的java文件中聲明的對象名