Java从坚持到精通-Javaweb

目录

1.关于系统架构

2.C/S架构是什么?

3.B/S架构是什么?

4.Web服务器与应用服务器

5.tomcat中startup.bat的执行流程

6.前端访问路径的简写形式

7.Servlet对象的生命周期

8.ServletConfig接口详解

9.ServletContext接口详解

10.HttpServlet的继承结构

11.Get请求和Post请求的区别?

12.HttpServlet源码解析

13.如何设置欢迎页面(不加资源名的默认页面)

14.关于WEB-INF目录

15.HttpServletRequest接口详解

16.request对象

17.请求域中怎么共享数据

18.获取前端的请求体乱码问题

19.如何获取应用根路径?

20.资源绑定器的用法

21.请求转发和重定向的区别

22.Servlet的注解式开发

23.JSP本质

24.JSP响应乱码的问题

25.JSP基本语法

26.session机制

27.session的实现原理

28.为什么关闭浏览器,session会话会结束?

29.session对象的销毁

30.Cookie禁用了,session还能找到吗?

31.Cookie理论基础

32.cookie的有效时间

33.什么情况下,cookie会被携带发送?

34.jsp中page指令的一些属性

35.EL表达式

36.Filter过滤器

37.Listener监听器


1.关于系统架构

系统架构包括C/S架构和B/S架构

2.C/S架构是什么?

C/S全称是Client/Server,也就是客户端/服务器。

C/S架构的软件有QQ、英雄联盟等。

特点:需要安装特定的客户端软件。

优点:
速度快、体验好、界面酷炫、服务器压力小、安全等

缺点:
升级维护比较麻烦

3.B/S架构是什么?

B/S全称是Browser/Server,也就是浏览器/服务器。

实际上B/S结构的系统还是一个C/S,只不过这个C比较特殊,这个Client是一个固定不变的浏览器软件。

优点:
升级维护方便、不需安装软件即可操作

缺点:
速度慢、体验差、不安全

4.Web服务器与应用服务器

Web服务器有:Tomcat、jetty

应用服务器:JBOSS、WebLogic、WebSphere

web服务器与应用服务器之间的区别?

应用服务器实现了JavaEE的所有规范(JavaEE有13个不同的规范)

Web服务器只实现了JavaEE钟大哥Servlet + JSP两个核心规范

5.tomcat中startup.bat的执行流程

执行startup.bat,实际上是指向执行了catalina.bat文件,catalina.bat里面又使用了JAVA_HOME,再找到MAlNCLASS=org.apache.catalina.startup.Bootstrap,也就是main方法,启动服务器。

6.前端访问路径的简写形式

正常的地址访问形式如href="http://127.0.0.1:8080/oa/login.html",可以简化掉协议、IP地址以及端口号,直接href="/oa/login.html"即可,注意开头有个斜杠。

7.Servlet对象的生命周期

默认情况下,服务器在启动的时候,Servlet对象并不会被实例化(因为构造方法未执行)。

如果想要让Servlet对象在服务器启动时就创建,需要在web.xml中的<servlet>标签中添加<load-on-startup>子标签,中间填写整数即可,数字越小,优先级越高,如写0。

用户在发送第一次请求的时候, 先执行构造方法,然后执行init方法,且都只执行一次。然后执行service方法,每次请求执行一次service方法。

所以,Servlet对象是单例的(单实例的,但是,Servlet对象是单实例的,Servlet类并不符合单例模式,我们称之为假单例。之所以单例是因为Servlet对象的创建我们程序员管不着,这个对象的创建只能是Tomcat来说了算,Tomcat只创建了一个,所以导致了单例,但是属于假单例。真单例模式,构造方法是私有化的。)

服务器关闭前,destroy会被调用。

8.ServletConfig接口详解

一个Servlet对象对应一个ServletConfig对象。(一对一关系)

ServletConfig里面包装了web.xml中<servlet>标签中的内容。

可以获取初始化参数的key和value,通过getInitParameter(String)和getInitParameterNames()方法

9.ServletContext接口详解

对于一个webapp来说,ServletContext对象只有一个。

常用方法:

public string getInitParameter(string name); //通过初始化参数的name获取value
public Enumeration<string> getInitParameterNames(); // 获取所有的初始化参数

// 以上两个方法是ServletContext对象的方法,获取的是如下配置在web.xml中的信息:

<context-param>
    <param-name>pageSize</param-name>
    <param-value>10</param-value>
</context-param>
<context-param>
    <param-name>startIndex</param-name>
    <param-value>0</param-value>
</context-param>

常用方法:

getContextPath():获取应用上下文的根路径
getRealPath(String):获取文件的绝对路径,从web根目录下开始获取,可以写“/”或者不写。

ServletContext对象还有另一个名字:应用域(后面还有其他域,例如:请求域、会话域)

如果所有的用户共享一份数据,并且这个数据很少被修改且数据量很少,可以将这些数据放到ServletContext这个应用域中

10.HttpServlet的继承结构

HttpServlet继承GenericServlet,GenericServlet实现Servlet

11.Get请求和Post请求的区别?

get请求只能携带普通的字符串,且发送的长度有限制。

post请求可以发送任何类型的数据,包括字符串、视频、声音、图片等,理论上没有限制。

get请求支持缓存,get请求的响应结果会被缓存起来。实际上每次get请求,浏览器都先会在缓存中找,找不到才发送请求

post请求不支持缓存,缓存没有意义

如果不希望get走缓存,可以在地址栏后面加上系统毫秒数之类的必定会变化的参数

12.HttpServlet源码解析

其中的service()方法使用了模板方法的设计模式,具体的实现延迟到子类去完成。

其中的doGet()方法和doPost()方法都是抛出了405异常(访问方法不正确状态码),所以如果不希望在请求的时候抛出405异常,字类就一定要重写doGet()方法和doPost()。

13.如何设置欢迎页面(不加资源名的默认页面)

在web.xml文件中添加如下标签

<welcome-file-list>
    <welcome-file>login.html</welcome-file>
</welcome-file-list>

14.关于WEB-INF目录

注意,放在WEB-INF目录下的资源是受保护的,在浏览器上不能直接访问,所以像html、css、js、image等静态资源一定要放到WEB-INF目录外。

15.HttpServletRequest接口详解

HttpServletRequest是一个接口,最终的实现类是RequestFacade。

16.request对象

request对象又称为“请求域”对象,在一个请求内有效。

17.请求域中怎么共享数据

可以使用转发机制来实现。(一次请求中)

具体实现代码如下:

request.getRequestDispatcher("/b").forward(request, response);

注意,请求转发也可以转发到静态资源页。

18.获取前端的请求体乱码问题

tomcat10版本已经设置了utf-8,但是tomcat9以及9之前的版本,未设置字符集,可以使用request.setCharacterEncoding("UTF-8");设置字符集

19.如何获取应用根路径?

可以使用request.getContextPath()。

20.资源绑定器的用法

如果我们在src下有properties资源文件,可以使用资源绑定器。具体使用如下:

private static ResourceBundle bundle = ResourceBundle.getBundle("resources.jdbc");
private static String driver = bundle.getrString("driver");

21.请求转发和重定向的区别

请求转发,不管转发了多少次,都是一次请求,浏览器地址栏的地址不变。

重定向是多次请求,浏览器的地址栏会改变。(浏览器是自发地向服务器发送新的请求,路径上需要添加项目名),如:

response.sendRedirect(request.getContextPath() + "/b");

22.Servlet的注解式开发

可以在servlet类上添加@WebServlet来替代原来的web.xml中的servlet方法。

23.JSP本质

访问jsp文件会生成相应的.java文件,该文件中的类继承HttpJspBase,再继承HttpServlet。

24.JSP响应乱码的问题

使用<%@page contentType="text/html;charset=UTF-8"%>解决响应乱码问题。

25.JSP基本语法

<%%>中间书写java代码,存在于service()方法中。

<%! %>这里面的代码会被翻译到service()方法外。

<%=%>如果输出内容包含java代码,可以直接写在等号后面,最终是被翻译成out.print();,且里面不能加分号,因为翻译后已经包含了分号。

26.session机制

session指的是会话,会话指的是用户打开浏览器,进行操作后,关闭浏览器,是一次会话。会话对应服务器端的session对象。一个会话中包含多次请求。
request.getSession()可以获取到服务器的session对象。

为什么需要session对象来保持会话状态呢?

因为HTTP协议是一种无状态协议,也就是在请求时才建立B/S的连接,请求结束后就断开连接。

为什么HTTP要设置成无状态协议,可以减少服务器与客户端的压力。

服务器不知道浏览器的关闭状态。

打开浏览器,发送请求或者打开浏览器标签,都是共享同一个会话,只有右上角的浏览器关闭才是结束会话。

request.getSession(false);如果传参false,获取不到session时,不会新建session,会返回null。

27.session的实现原理

在web服务器中有一个session列表,类似于map集合,这个map集合的key存储的是sessionid,value存储的是对应的session对象

用户发送第一次请求的时候:服务器会创建一个新的session对象,同时给该对象生成一个id,也就是sessionid,然后发送给浏览器,浏览器保存该sessionid到缓存中。

用户发送第二次请求的时候,会自动将浏览器缓存中的sessionid自动发送给服务器,服务器获取到sessionid,然后从session列表中找到对应的session对象。

JSESSIONID=xxx,这个是以cookie的形式保存在浏览器内存中的

28.为什么关闭浏览器,session会话会结束?

因为关闭浏览器之后,浏览器中保存的sessionid消失了,下次重新打开浏览器之后,浏览器缓存没有对应的sessionid,就找不到服务器中的session对象。

29.session对象的销毁

session对象有两种销毁方式,一是超时自动销毁,二是用户手动销毁(安全退出的方式)。

session.invalidate();

30.Cookie禁用了,session还能找到吗?

cookie禁用:服务器正常发送JSESSIONID给浏览器,但是浏览器不要了,相当于缓存中没有sessionid。所以会找不到服务器的session。但是session机制还能实现吗?可以的。需要使用URL重写机制。在地址栏后面加上分号再加jsessionid=xxx。

31.Cookie理论基础

JSESSIONID=xxx,这样的键值对存在于cookie中,这个cookie制备保存在浏览器的“运行内存”中的,只要浏览器不关闭,用户再次发送请求的时候,会自动将运行内存中的cookie发送给服务器。

cookie的创建:Cookie cookie = new Cookie(String, String);

使用时,需要使用response.add(cookie);

32.cookie的有效时间

设置有效时间:cookie.setMaxAge(int);参数是秒

如果没有设置有效时间,默认保存在浏览器的运行内存中,浏览器关闭则cookie消失。

设置cookie的MaxAge>0时,计时生效
设置cookie的MaxAge=0时,删除同名cookie
设置cookie的MaxAge<0时,不会被存储到硬盘文件中,放在浏览器运行内存中,与不写是一样的,浏览器关闭则cookie失效

33.什么情况下,cookie会被携带发送?

默认情况下:在设置cookie的时候,请求的路径的父路径以及这个父路径的子路径再次请求时,会携带这个cookie。

手动设置cookie的path:cookie.setPath("/servlet");表示只要是这个servlet项目的请求路径,都会提交cookie给服务器。

34.jsp中page指令的一些属性

<%page errorPage="/error.jsp"%>:当前页面出现异常后,跳转到error.jsp页面

<%page isErrorPage="true"%>:表示启用JSP九大内置对象之一:exception,默认值是false

35.EL表达式

格式:${表达式}

作用:
1.从某个域中取数据
2.将取出的数据转换成字符串
3.将字符串输出到浏览器

36.Filter过滤器

Filter是过滤器,可以在Servlet目标程序执行之前添加代码,也可以在目标程序执行之后添加代码,之前之后都可以添加过滤规则。

一般情况下,过滤器中编写的都是公共代码。

filter对象中的方法说明:
init():在filter对象第一次被创建后调用,并且只调用一次
doFilter():只要用户发送一次请求,则执行一次。发送N次请求执行N次。这里执行过滤规则。
destroy():在filter对象被释放/销毁之前调用,并且只执行一次。

目标servlet是否执行,取决于两个条件:
1.在过滤器中是否编写了:chain.doFilter(request, response);代码
2.用户发送的请求路径是否和servlet请求路径一致或匹配

chain.doFilter(request, response);的作用:
执行下一个过滤器,如果下面没有过滤器了,则执行最终的servlet

注意:filter的优先级,天生就比servlet高。

关于filter的匹配路径:
1:/a.do,/b.do 精确匹配
2:/* 匹配所有路径
3:*.do 后缀匹配,注意不要以/开始
4:/dept/* 前缀匹配

通过注解的方式添加的过滤器,通过类名按照顺序先后执行。

37.Listener监听器

什么是监听器?监听器是Servlet规范的一员,就像Filter一样。是一个特殊时机。

所有的监听器都是不需要我们去调用的,在某个特殊的事件发生后,由服务器自动调用。

  • 24
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值