动态页面技术的发展与应用

jsp

  • 静态页面:web诞生后的html文档,不论多少次访问都是同一份html文档或者是其他的什么文档,所以说是"静态"的。
    • 虽然js能让页面产生互动,但是不论什么人访问,看到的都是放在服务器的那一份写死的文件/文档
    • activex
    • applet
    • flash
  • 动态页面:服务器软件动态编辑html文件,现场照着模板编辑一份给你
  • 模板引擎:
    • 不知道为啥不算动态页面。
    • python从来没有发展出动态页面技术,但是有模板引擎

web相关概念回顾

  1. 软件架构

    1. C/S:客户端/服务器端
    2. B/S:浏览器/服务器端
  2. 资源分类

    1. 静态资源:所有用户访问后,得到的结果都是一样的,称为静态资源.静态资源可以直接被浏览器解析
      • 如: html,css,JavaScript
    2. 动态资源:每个用户访问相同资源后,得到的结果可能不一样。称为动态资源。动态资源被访问后,需要先转换为静态资源,在返回给浏览器
      • 如:servlet/jsp,php,asp...

web服务器软件:

  • 服务器:安装了服务器软件的计算机硬件
  • 服务器软件:接收用户的请求,处理请求,做出响应的进程 比如将tomcat和我们写的代码打成一个jar包,在有一段口号运行;
  • web服务器软件:接收用户浏览器的http请求,处理请求,做出响应(通常是返回html文档)。
    • 在web服务器软件中,可以部署web项目,让用户通过浏览器来访问这些项目
    • 如nginx, Apache,微软IIS,还有Tomcat的部分功能
  • Java Servlet容器:
    • 相关概念起源于JavaEE中EJB(企业级javaBean)的容器。

    • 单独的servlet文件需要结合servlet-api相关的JavaEE的jar包,将其初始化后放在容器中管理,才有用

    • Tomcat就是这么一个Servlet容器,顺便还有web服务器功能

      • 常见的java相关的web服务器软件:

        • webLogic:oracle公司,大型的JavaEE服务器,支持所有的JavaEE规范,收费的。
        • webSphere:IBM公司,大型的JavaEE服务器,支持所有的JavaEE规范,收费的。
        • JBOSS:JBOSS公司的,大型的JavaEE服务器,支持所有的JavaEE规范,收费的。
        • Tomcat:Apache基金组织,中小型的JavaEE服务器,仅仅支持少量的JavaEE规范servlet/jsp。开源的,免费的。
      • JavaEE:Java语言在企业级开发中使用的技术规范的总和,一共规定了13项大的规范

      • Tomcat

        1. 下载:http://tomcat.apache.org/
        2. 安装:解压压缩包即可。
          • 注意:安装目录建议不要有中文和空格
        3. 卸载:删除目录就行了
        4. 启动:
          • bin/startup.bat ,双击运行该文件即可

          • 访问:浏览器输入:http://localhost:8080 回车访问自己

            http://别人的ip:8080 访问别人

          • 可能遇到的问题:

            1. 黑窗口一闪而过:

              • 原因: 没有正确配置JAVA_HOME环境变量
              • 解决方案:正确配置JAVA_HOME环境变量
            2. 启动报错:

              1. 暴力:找到占用的端口号,并且找到对应的进程,杀死该进程
                • netstat -ano
              2. 温柔:修改自身的端口号
                • conf/server.xml
                • 一般会将tomcat的默认端口号修改为80。80端口号是http协议的默认端口号。
                  • 好处:在访问时,就不用输入端口号
        5. 关闭:
          1. 正常关闭:
            • bin/shutdown.bat
            • ctrl+c
          2. 强制关闭:
            • 点击启动窗口的×
        6. 配置:
          • 部署项目的方式:

            1. 直接将项目放到webapps目录下即可。

              • /hello:项目的访问路径-->虚拟目录
              • 简化部署:将项目打成一个war包,再将war包放置到webapps目录下。
                • war包会自动解压缩
            2. 配置conf/server.xml文件

              在标签体中配置

              • docBase:项目存放的路径
              • path:虚拟目录
            3. 在conf\Catalina\localhost创建任意名称的xml文件。在文件中编写

              • 虚拟目录:xml文件的名称
          • 静态项目和动态项目:

            • 目录结构
              • java动态项目的目录结构:
                -- 项目的根目录
                -- WEB-INF目录:
                -- web.xml:web项目的核心配置文件
                -- classes目录:放置字节码文件的目录
                -- lib目录:放置依赖的jar包
          • 将Tomcat集成到IDEA中,并且创建JavaEE的项目,部署项目。

Servlet: server applet

  • 概念:运行在服务器端的小程序
    • Servlet就是一个接口,定义了Java类被浏览器访问的规则。
    • 将来我们自定义一个类,实现Servlet接口,复写方法。

Java Servlet 在遵循Java Servlet 规范(http://java.sun.com/product/servlet/2.2)定义的标准容器环境中运行,容器环境在 HTTP 通信和 We 服务器平台之间实现了一个抽象层。容器环境负责把请求传递给 Servlet,并把结果返回给客户。容器环境也提供了配置Java Servlet 应用的简单方法并且也提供了以声明性的方式使用特殊的基于 Web 应用XML布置描述符对 Java Servlet 应用进行各种管理服务。Java Servlet API中包括了ServletContext 接口,实现与容器环境的交互。

* 快速入门:
	1. 创建JavaEE项目
	2. 定义一个类,实现Servlet接口
		* public class ServletDemo1 implements Servlet
	3. 实现接口中的抽象方法
	4. 配置Servlet
		 在web.xml中配置:
	    <!--配置Servlet -->
	    <servlet>
	        <servlet-name>demo1</servlet-name>
	        <servlet-class>cn.itcast.web.servlet.ServletDemo1</servlet-class>
	    </servlet>
	
	    <servlet-mapping>
	        <servlet-name>demo1</servlet-name>
	        <url-pattern>/demo1</url-pattern>
	    </servlet-mapping>

* 执行原理:
	1. 当服务器接受到客户端浏览器的请求后,会解析请求URL路径,获取访问的Servlet的资源路径
	2. 查找web.xml文件,是否有对应的<url-pattern>标签体内容。
	3. 如果有,则在找到对应的<servlet-class>全类名
	4. tomcat会将字节码文件加载进内存,并且创建其对象
	5. 调用其方法

  • Servlet中的生命周期方法:

    1. 被创建:执行init方法,只执行一次
      • Servlet什么时候被创建?
        • 默认情况下,第一次被访问时,Servlet被创建

        • 可以配置执行Servlet的创建时机。

          • 在标签下配置
            1. 第一次被访问时,创建
              • 的值为负数
            2. 在服务器启动时,创建
              • 的值为0或正整数
              • Servlet的init方法,只执行一次,说明一个Servlet在内存中只存在一个对象,Servlet是单例的
                • 多个用户同时访问时,可能存在线程安全问题。
                • 解决:尽量不要在Servlet中定义成员变量。即使定义了成员变量,也不要对修改值
          1. 提供服务:执行service方法,执行多次
            • 每次访问Servlet时,Service方法都会被调用一次。
          2. 被销毁:执行destroy方法,只执行一次
          • Servlet被销毁时执行。服务器关闭时,Servlet被销毁
          • 只有服务器正常关闭时,才会执行destroy方法。
          • destroy方法在Servlet被销毁之前执行,一般用于释放资源
    • Servlet3.0:
      • 好处:

        • 支持注解配置。可以不需要web.xml了。
      • 步骤:

        1. 创建JavaEE项目,选择Servlet的版本3.0以上,可以不创建web.xml
        2. 定义一个类,实现Servlet接口
        3. 复写方法
        4. 在类上使用@WebServlet注解,进行配置
          • @WebServlet("资源路径")
java 复制代码
			@Target({ElementType.TYPE})
			@Retention(RetentionPolicy.RUNTIME)
			@Documented
			public @interface WebServlet {
			    String name() default "";//相当于<Servlet-name>
			
			    String[] value() default {};//代表urlPatterns()属性配置
			
			    String[] urlPatterns() default {};//相当于<url-pattern>
			
			    int loadOnStartup() default -1;//相当于<load-on-startup>
			
			    WebInitParam[] initParams() default {};
			
			    boolean asyncSupported() default false;
			
			    String smallIcon() default "";
			
			    String largeIcon() default "";
			
			    String description() default "";
			
			    String displayName() default "";
			}

IDEA与tomcat的相关配置

1. IDEA会为每一个tomcat部署的项目单独建立一份配置文件
	* 查看控制台的log:Using CATALINA_BASE:   "C:\Users\fqy\.IntelliJIdea2018.1\system\tomcat\_itcast"

2. 工作空间项目    和     tomcat部署的web项目
	* tomcat真正访问的是"tomcat部署的web项目","tomcat部署的web项目"对应着"工作空间项目" 的web目录下的所有资源
	* WEB-INF目录下的资源不能被浏览器直接访问。
3. 断点调试:使用"小虫子"启动 dubug 启动
相关推荐
知孤云出岫3 小时前
web 渗透学习指南——初学者防入狱篇
前端·网络安全·渗透·web
细心的莽夫1 天前
JavaWeb学习笔记
java·开发语言·笔记·学习·java-ee·web
kali-Myon2 天前
NewStarCTF2024-Week5-Web&Misc-WP
前端·python·学习·mysql·web安全·php·web
觅_2 天前
HTML 鼠标滑动 页面的header背景从透明色变为黑色
前端·html·web
清风絮柳2 天前
25.停车场管理系统(基于web的Java项目)
毕业设计·j2ee·java项目·jsp·停车场管理系统
知孤云出岫2 天前
web安全测试渗透案例知识点总结(下)——小白入狱
网络·网络安全·web
Dangks4 天前
[前端] 为网站侧边栏添加搜索引擎模块
前端·javascript·搜索引擎·html·web·seo·博客技巧
扛枪的书生5 天前
Web 靶场笔记-bWAPP
渗透·web·kali
会思想的苇草i5 天前
CSS秘籍-高效样式技巧
前端·css·html·css3·web·flex
满分观测网友z6 天前
ExpandingCard扩展卡片
web·js