JSP的include指令

JSP的include指令在JSP中,可以使用include指令来包含其他jsp文件。例如,一个网站中,多个网页具有很大部分是相同元素时,可以使用include指令来完成。include的指令的语法如下:<%@inc

大家好,又见面了,我是你们的朋友全栈君。

  在JSP中,可以使用include指令来包含其他jsp文件。例如,一个网站中,多个网页具有很大部分是相同元素时,可以使用include指令来完成。include的指令的语法如下:

  <%@ include file=”文件路径”%>

  下面通过一个简单的实例来说明include指令实现的原理。使用Eclipse在web项目下新建一个jsp文件命名为header.jsp,具体代码如下

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>

<!DOCTYPE HTML>
<html>
  <head>
    
    <title>My JSP 'header.jsp' starting page</title>
   
  </head>
  
  <body>
   这是一个头文件
  </body>
</html>

然后新建一个jsp文件命名为include.jsp,具体代码如下:

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>

<!DOCTYPE HTML>
<html>
  <head>
    
    <title>My JSP '03.include.jsp' starting page</title>
   
  </head>
  
  <body>
       <%@ include file="header.jsp" %>
       这是一个主体部分
  </body>
</html>

使用include指令时,在file属性中指定要包含的jsp文件的路径,推荐使用相对路径。在eclipse中,按住Ctrl键,并点击file属性指定的路径能够打开相对应的jsp文件,说明路径正确。

将web项目部署到Tomcat服务器并启动服务器,到work目录中找到jsp文件翻译成的java文件。代码如下:

/*
 * Generated by the Jasper component of Apache Tomcat
 * Version: Apache Tomcat/7.0.81
 * Generated at: 2017-10-15 11:44:30 UTC
 * Note: The last modified time of this file was set to
 *       the last modified time of the source file after
 *       generation to assist with modification tracking.
 */
package org.apache.jsp;

import javax.servlet.*;
import javax.servlet.http.*;
import javax.servlet.jsp.*;
import java.util.*;
import java.util.*;

public final class _include_jsp extends org.apache.jasper.runtime.HttpJspBase
    implements org.apache.jasper.runtime.JspSourceDependent {

  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;

  static {
    _jspx_dependants = new java.util.HashMap<java.lang.String,java.lang.Long>(1);
    _jspx_dependants.put("/common/header.jsp", Long.valueOf(1508067769708L));
  }

  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 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 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("<!DOCTYPE HTML>\r\n");
      out.write("<html>\r\n");
      out.write("  <head>\r\n");
      out.write("    \r\n");
      out.write("    <title>My JSP '03.include.jsp' starting page</title>\r\n");
      out.write("   \r\n");
      out.write("  </head>\r\n");
      out.write("  \r\n");
      out.write("  <body>\r\n");
      out.write("   \t");
      out.write("\r\n");
      out.write("\r\n");
      out.write("<!DOCTYPE HTML>\r\n");
      out.write("<html>\r\n");
      out.write("  <head>\r\n");
      out.write("    \r\n");
      out.write("    <title>My JSP 'header.jsp' starting page</title>\r\n");
      out.write("   \r\n");
      out.write("  </head>\r\n");
      out.write("  \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");
      out.write("   \t这是一个主体部分\r\n");
      out.write("  </body>\r\n");
      out.write("</html>\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);
    }
  }
}

可以看出,只翻译成一个java文件,jsp引擎在处理include指令时,只是单纯的将被包含文件的内容copy到包含文件中。查看out.write()代码部分,发现两个其中有html标签有重复的。因此,我们可以在header.jsp中去掉部分重复的标签,这样include.jsp也能正常的翻译成servlet程序。

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/154403.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月30日 下午11:36
下一篇 2022年6月30日 下午11:36


相关推荐

  • 微信公众号开发者社区_订阅号怎么弄

    微信公众号开发者社区_订阅号怎么弄引言及内容概要已经有几位读者抱怨“柳峰只用到文本消息作为示例,从来不提图文消息,都不知道图文消息该如何使用”,好吧,我错了,原本以为把基础API封装完、框架搭建好,再给出一个文本消息的使用示例,大家就能够照猫画虎的,或许是因为我的绘画功底太差,画出的那只猫本来就不像猫吧……本篇主要介绍微信公众帐号开发中图文消息的使用,以及图文消息的几种表现形式。标题取名为“图文消息全攻略”,这绝对不是标题

    2026年4月18日
    4
  • C++的后端框架从头开发[通俗易懂]

    C++的后端框架从头开发[通俗易懂]基于C++的后端框架Ratel简介:从开发到现在已经半个月了,我会进行长期地开发、维护和优化,直到它变得完善。各种建议和错误读者都可以和我联系,从公众号中就可以找到我的联系方式~Ratel后端框架目前采用C++作为开发语言,理想的效果是实现一个通用的、灵活的、高效的后端开发框架,可以自由选择不同的I/O复用机制,可以自由选择采用多线程、多进程或协程方式实现,并且可以跨平台Linux和Window平台编译和运行。目前已有功能:Linux和Windows跨平台运行

    2022年6月9日
    139
  • 教你如何激活成功教程无线网络密码(无线网络密码激活成功教程)

    教你如何激活成功教程无线网络密码(无线网络密码激活成功教程)面对电脑搜索到的无线网络信号 你是否怦然心动 但看到一个个 启用安全的无线网络 你是否又感到有一丝遗憾 本人作为一个心动 遗憾的代表 充分发挥主观能动性 总算学有所成 终于能成功无线密码 这份成功的喜悦不敢独享 写下该篇教程 nbsp nbsp nbsp 注 nbsp nbsp nbsp 1 本文针对的无线激活成功教程是指 wep 的激活成功教程 wpa 激活成功教程现在仍是技术难题 不在本文讨论之列 如果你家无线路由需要加密 为保障安全也请采用 wpa 模式 如果

    2026年2月22日
    1
  • 个人的中小型项目前端架构浅谈

    个人的中小型项目前端架构浅谈前端架构浅谈 0 前注鉴于作者本人的能力有限 非常有限 并且依然在学习中 因此本文的高度和深度必然有所欠缺 欢迎 并且非常欢迎 大家来批评指正 如果能详细的说明问题在哪里 如何解决和改正 那么就太感谢了 我最喜欢听有理有据的批评了 本人 邮箱 com 期待你的交流 1 为什么要有一个好的架构首先明确一点 架构是为需求服务的 前端架构存在的目的 就我

    2026年3月17日
    1
  • pychram激活码(破解版激活)

    pychram激活码(破解版激活),https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月16日
    79
  • 谷歌浏览器报错 Active resource loading counts reached to a per-frame

    谷歌浏览器报错 Active resource loading counts reached to a per-frame

    2021年11月8日
    86

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号