02.Jsp筆記

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文件中聲明的對象名

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章