javaweb阶段总结

一、 Mysql

1.索引

1.1 什么是索引

索引是在数据库表的字段上添加的,是为了提高查询效率存在的一种机制。

一张表的一个字段可以添加一个索引,当然也可以联合起来添加,索引就相当于一本书的目录,是为了缩小扫描范围而存在的一种机制。

如果没有添加索引的话,mysql会把所有字段都扫描一遍,这样效率比较低。

索引需要排序,只有排序后才有区间查找这一说(缩小扫描范围其实就是扫描某个区间),并且索引的排序和TreeSet数据给够相同。TreeSet底层是一个自平衡的二叉树,在MySQL中索引是一个B-Tree数据结构。

遵循左小右大的原则

1.2 索引的实现原理

  • 在任何数据库中主键上都会自动添加索引,在MySQL中一个字段上有unique约束的话,也会自动创建索引

  • 在任何数据库中,任何一张表的任何一条记录在硬盘存储上都有一个硬盘的物理编号。

  • mysql中,索引是一个单独对象,不同的存储引擎以不同的形式存在,在MySQL

1.3 什么情况下会添加索引

  1. 数据量庞大

  2. 这个字段经常出现在where后面,以条件形式存在,该字段总是被扫描

  3. 该字段很少的DML操作,因为DML之后索引需要重新排序,

建议不要随意添加索引,因为索引也是需要维护的,太多的话反而会降低系统的性能。建议通过主键查询,通过unique约束查询,效率会高一些。

1.4 添加索引

添加索引:

ceate index emp_ename_index on emp(ename);

删除索引:

drop index emp_ename_index on emp;

mysql> create index emp_ename_index on emp(ename);
Query OK, 0 rows affected (0.01 sec)
Records: 0  Duplicates: 0  Warnings: 0
​
mysql> drop index emp_ename_index on emp(ename);
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '(ename)' at line 1
mysql> drop index emp_ename_index on emp;
Query OK, 0 rows affected (0.01 sec)
Records: 0  Duplicates: 0  Warnings: 0

1.5 怎么查看一个SQL语句是否用了索引检索

explain select * from emp where ename = 'KING';

mysql> explain  select * from emp where ename = 'KING';
+----+-------------+-------+------+---------------+------+---------+------+------+-------------+
| id | select_type | table | type | possible_keys | key  | key_len | ref  | rows | Extra       |
+----+-------------+-------+------+---------------+------+---------+------+------+-------------+
|  1 | SIMPLE      | emp   | ALL  | NULL          | NULL | NULL    | NULL |   14 | Using where |
+----+-------------+-------+------+---------------+------+---------+------+------+-------------+
1 row in set (0.00 sec)

1.6 索引有失效的时候

19.6.1 失效的第一种情况

select * from emp where ename like '%T';

模糊匹配中,使用“%”开头,所以不会走索引

19.6.2 失效的第二种情况

使用or的时候会失效,如果使用or那么要求or两遍字段都要有索引,才会走索引,如果一遍没有那么另一个也不能用,少用or

19.6.3失效的第三种情况

使用复合索引,没有使用左侧的列去查找,索引就会失效。

19.6.4 失效的第四种情况

在where条件中,索引列参加的运算,或者,索引列使用了函数,索引失效

二、javaweb

Servlet

概念:运行在服务端的小程序

  1. Servlet就是一个接口,定义了Java类被浏览器访问到(tomcat识别)的规则

  2. 将来我们定义一个类,实现Servlet接口,复写方法

快速入门:

  1. 创建一个Javaee项目

  2. 定义一个类,实现Servlet接口

  3. 实现接口中的抽象方法

  4. 配置Servlet

在web.xml文件中配置Servlet

<!--    配置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-pattr>标签体内容。

  3. 如果有,则在找到对应的<servlet-class>全类名

  4. Tomcat会将字节码文件加载进内存,并且创建其对象

  5. 调用方法

Servlet生命周期

  1. 被创建:执行init方法,只执行一次。

Servlet默认在第一次被访问的时候,Servlet被创建

可以配置指定Servlet的创建时间,使用<load-on-startup>标签

<load-on-startup>0或正整数</load-on-startup>

在第一次访问时被创建

<load-on-startup>负数</load-on-startup>

在服务器启动的时候被创建

Servlet的init方法,只执行一次,说明一个Servlet在内存中只存在一个对象,Servlet是单例的

多个用户同时访问时,可能存在线程安全问题

解决:尽量不要在Servlet中定义成员变量。即使定义了成员变量,也不要对值进行修改。

  1. 提供服务:执行Servlet方法,执行多次

每次访问都会执行一次,方法调用一次

  1. 被销毁:执行destroy方法,只能执行一次。

Servlet被销毁时执行,关闭服务器时,Servlet被销毁

只有服务器正常关闭时才能执行destroy方法

这个方法在Servlet被销毁之前执行,一般用于释放资源

idea与Tomcat的相关配置

idea会为每一个Tomcat不熟的项目单独建立一份配置文件

工作空间项目和Tomcat部署的web项目

  1. Tomcat真正访问的是“Tomcat部署的web项目”,“Tomcat部署的web项目”对应着“工作空间项目”的web目录下的所有资源

  2. web-inf下的资源不能被浏览器直接访问

GenericServlet:将Servlet接口中其他方法都做了默认空实现,只讲service方法作为抽象

HTTPServlet:对http协议的一种封装,简化操作

HTTP

http

http是一种传输协议,定义了,客户端和服务器端通信时,发送数据的格式

特点:

  1. 基于tcp/ip的高级协议

  2. 默认端口号:80

  3. 基于请求/响应模型:一次请求对应一次响应

  4. 无状态的:每次请求之间都是相互独立,不能交互数据

请求消息的数据格式:

  1. 请求行

    请求方式 请求url 请求协议/版本

    GET /login.html HTTP/1.1

    1. get :

      1. 请求参数在请求行中,url之后。

      2. 请求的url长度有限制

      3. 不太安全(相对的)

      post:

      1. 请求参数在请求体中

      2. 请求的url长度没有限制

      3. 相对安全

  2. 请求头

    请求头的名称:请求头的值

    1. User-Agent:浏览器告诉服务器,我访问你使用的浏览器版本信息

    User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/92.0.4515.131 Safari/537.36 SLBrowser/8.0.0.2242 SLBChan/30

    1. Referer:地址

      告诉服务器当前请求从哪里来

      作用:

      1. 放盗链

      2. 统计工作

  3. 请求空行 空行(用于分隔post请求头和请求体)

  4. 请求体(正文)

    封装post请求消息的请求参数

Request

Request对象和Request对象原理

  1. request和response对象是由服务器创建的。我们来使用他们

  2. request对象用来获取请求消息,response对象用来设置响应消息

  1. request对象继承体系结构

ServletRequest——接口

| 继承

HTTpServletRequest——接口

| 实现

request:功能

  1. 获取请求消息数据

    1. 获取请求行数据

    2. 获取请求头数据

    3. 获取请求体数据

  2. 其他功能

获取请求行的数据

  1. 获取请求方式

    String getMethod();

  2. 获取虚拟目录(重点掌握)

    String getContextpath();

  3. 获取Servlet路径 String getServletPath();

  4. 获取get方式请求参数

    String getQueryString();

  5. 获取请求url(重点掌握)

    String getRequestURL();

    StringBuffer getRequertURL();

  6. 获取协议及版本

    String getProtocal();

  7. 获取客户机的IP地址

    String getRemoteAddr();

获取请求头的数据

  1. String getHeader(String name):通过请求头的名称获取请求头的值(很重要

  2. Enumeration<String> getHeaderNames():获取所有的请求头名称

获取请求体的数据

  1. BufferedReader getReader();:获取字符输入留,只能操作字符数据。

  2. ServletInputStream getInputStream();:获取字节流输入流,可以操作所有类型数据。

request其他功能

获取请求参数的通用方法

  1. String getParameter(String name):根据参数名称获取参数值

  2. Sting[] getParameterValues(String name):根据参数名称获取参数值的数组

  3. Enumeration<String> getParameterNames():获取所有请求的参数名称

  4. Map<String,String[]> getParameterMap():获取所有参数的map集合

请求转发

一种在服务器内部的资源跳转方式

步骤:

  1. 通过request对象获取请求转发器对象:RequestDispatcher getRequestDiapatcher(String path)

  2. 使用RequestDispatcher对象来进行转发:forward(ServletRequest request,ServletResponse response)

好处:

  1. 浏览器地址栏路径没有发生变化

  2. 只能访问当前服务器内部资源中

  3. 转发是一次请求

共享数据

  • 域对象:一个有作用范围的对象,可以在范围内共享数据

  • request域:代表一次请求的范围,一般用于请求转发的多个资源中共享数据

  • 用SetAttribute(String name,Object obj):存储数据

  • getAttritude(String name):通过建获取值

  • removeAtrribute(String name):通过键移除值

获取ServletContext

get方式:tomcat会将中文乱码问题解决

Response

响应行,响应头,响应空行,响应体

请求体就是页面内容

响应行

  1. 协议版本 响应状态码 响应描述

  2. 响应状态码:服务器告诉客户端浏览器本次请求和响应的一个状态

    1. 状态码都是三位数

    2. 分类:

      1. 1**:服务器接受客户端消息,但是没有接受完成,等待一段时间后,发送1~~

      2. 2**:成功

      3. 3**:重定向。302(重定向),304(访问缓存)

      4. 4**:客户端错误。404(请求路径没有对应资源),405(请求方式没有对应的do方法)

      5. 5**:服务端错误。500(服务器内部出现异常)

响应头

  1. 格式:头名称:值

  2. Context-Type:服务器告诉客户端本次响应数据格式以及编码格式

  3. Content-disposition:服务器告诉客户端以什么格式打开响应体格式

功能

设置响应头:setHeader(String sc)

设置响应体:

  1. 获取输出流

    1. 字符输出流:PrintWriter()

    2. 字节输出流:ServletOutputStream getOutputStream()

  2. 使用输出流,将数据输出到客户端的浏览器

重定向和转发比较

重定向:

  1. 地址栏发生变化

  2. 重定向可以访问其他站点的资源

  3. 重定向是两次请求,不可以使用request对象来共享数据

转发:

  1. 转发地址栏不发生变化

  2. 转发只能访问当前服务器下的资源

  3. 转发是一次请求,可以使用request对象来共享数据

路径

绝对路径:以/开头的路径

  1. 给客服端浏览器使用:需要加虚拟牡蛎

  2. 给服务器使用:不需要加虚拟目录

相对路径:通过相对路径不可以确定唯一资源

  1. 规则:找到当前资源和目标资源之间的相对位置关系

package selver;
​
import javax.servlet.*;
import javax.servlet.http.*;
import javax.servlet.annotation.*;
import java.io.IOException;
import java.io.PrintWriter;
​
@WebServlet(name = "response3", value = "/response3")
public class response3 extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        this.doPost(request,response);
​
    }
​
    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //在获取流对象前要先设置流的默认编码:ISO-8859-1为:GBK
        response.setCharacterEncoding("GBK");
        //告诉浏览器,服务器发送的消息体数据的编码。建议浏览器使用改编码解码
        response.setHeader("content-type","text/html;charset=utf-8");//不仅可以设置文件的编码,还可以设置浏览器的编码
​
        //简单形式
        response.setContentType("text/html;charset=utf-8");
​
        //1.获取字符输出流
        PrintWriter printWriter = response.getWriter();
        //2.输出数据
        printWriter.write("<h1 style = 'color:red;'>一个人的夜,我的心应该放在哪里</h1>");
​
    }
}

ServletContext

代表整个web应用,可以和程序的容器(服务器)来通信

功能

  1. 获取MIME类型

    MIME类型:在互联网那个通信过程中定义的一种文件数据类型

    格式:大类型/小类型 text/html

  2. 域对象:共享数据

    1. setAttribute(String name,String value)

    2. getAttribute(String name)

    3. removeAttribute(String name)

  3. 获取文件的真实(服务器)路径

方法:getRealPath();

获取

request.getServletContext();

this.getServletConte();

会话技术

一次回话中包含多次请求和响应

一次回话:浏览器第一次给服务器资源发送请求,回话建立,知道有一缸断开为止。

在一次回家的范围内的多次请求间,共享数据

功能:共享数据

方式:

  1. 客户端回话技术:Cookie

  2. 服务器端回话技术:Session

Cookie

步骤:

  1. 创建cookie对象,绑定数据

    new Cookie(String name , String value)

  2. 发送cookie对象

    response.addCookie(Cookie cookie)

  3. 获取cookie,拿到数据

    Cookie[] request. getCookies()

关于Cookie的一些细节

  1. 一次可不可以发送多个Cookie

    可以一次创建多个cookie,用response调用多次

  2. Cookie在浏览器中保存多长时间

    默认情况下,当浏览器关闭之后,cookie被销毁

    设置cookie的存储信息,持久化存储

    setMaxAge(int second)

    1. 正数:将cookie数据写到硬盘文件中,持久化存储。cookie存活间

    2. 负数:默认值

    3. 0:代表删除cookie信息

  3. cookie能不能存储中文

    在Tomcat 8之前,不能存储中文,在Tomcat 8之后能访问

  4. cookie获取范围多大

    在一个Tomcat服务器中,部署了多个web项目,默认情况下,在这些web项目中cookie不能共享。

Cookie的特点

  1. cookie的存储数据在客户端浏览器

  2. 浏览器对于当cookie的大小有限制(4kb)以及对用一个域名下的总cookie数量也有显示(20个)

作用

  1. cookie一般用于存储少量的不太敏感的数据

  2. 在不登录的情况下,完成服务器对客户端的身份识别

Session

服务器端回话技术,在一次回话的多次请求间共享数据,将数据保存在服务器端的对象中。HTTPSession

Object getAttribute(String name)

void setAttirbute(String name,Object value)

void removeAttirbute(String name)

步骤:

  1. 获取session对象

  2. 使用session对象

注意事项:

  1. 在两个demo中,获取了两个session,这两个session是同一个session,第一次获取session的时候没有cookie,会在内存中创建一个新的session

  2. session是依赖cookie的

细节:

  1. 当客户端关闭后,服务器不关闭,两次获取的session是不是同一个

    默认情况下不是

    如何两次获取同一个session,可以创建一个cookie

    Cookie c = new Cookie("JSESSION",session.getId())

  2. 客服端不关闭,服务器关闭之后,两次获取的session不是同一个

    不是同一个,但是如果要保证数据不丢失

  • session的钝化:

    在服务器正常关闭前,将session对象系列化到硬盘上

  • session的活化:

    在服务器启动后,将session文件转化为内存中的session对象即可

  1. session什么时候被销毁

  2. 服务器关闭

  3. session对象调用invalidate()

  4. session默认失效时间是30分钟

Session的特点

  1. session可以用于存储一次回话的多次请求的数据,存在服务器端

  2. session可以存储任意类型,任意大小的数据

session和cookie的区别

  1. session存储数据在服务器端,cookie在客户端

  2. session没有数据大小限制,cookie有

  3. session数据安全,cookie相对于不安全

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值