JavaWeb

1. 基本概念

1.1 前言

web 开发:

  • web,网页的意思:www.baidu.com
  • 静态web
  • html,css
  • 提供给所有人看的数据,始终不会发生变化

  • 动态web
  • 提供给所有人看的数据始终会发生变化,每个人在不同的事件、不同的地点看到的信息各不相同。
  • 淘宝、几乎所有的网站都是动态的
  • 技术栈:servlet/JSP

在Java中,动态web资源开发的技术统称为JavaWeb;

1.2 web应用程序

web应用程序:可以提供浏览器访问的程序;

  • 可以访问到的任何一个页面或者资源,都存在于这个世界的某一个角落的计算机
  • URL:统一资源定位符
  • 这个统一的web资源会被放在同一个文件夹下:web应用程序->Tomcat服务器
  • 一个web应用由多部份组成(静态web和动态web)
  • html,css,js
  • jsp,servlet
  • java程序
  • jar
  • 配置文件(properties)

web应用程序编写完毕后,若想提供给外界访问:需要一个服务器统一管理

1.3 静态web

  • *.html,网页的后缀,如果服务器上一直存在这些东西,我们就可以直接读取

java 制作动画 javaweb动画_tomcat

缺点

  • web页面无法动态更新,所有用户看到的都是同一个界面
  • 轮播图:点击特效是伪动态
  • javascript:实际开发中用的zui多
  • 它无法和数据库交互,数据无法持久化,用户无法交互

1.4 动态web

页面会随着用户的不同而展示不同的页面;

java 制作动画 javaweb动画_maven_02

缺点:

  • 假如服务器的动态web资源出现了错误,我们需要重新编写后台程序
  • 停机维护

优点:

  • 可以动态更新,所有用户看到的都不是同一个页面
  • 它可以与数据库交互,可以做数据持久化

2. web服务器

2.1 技术讲解

ASP:

  • 微软:国内最早流行的
  • 在html中嵌入了VB的脚本,ASP+COM
  • 在ASP开发中,基本一个页面都有几千行的业务代码,页面极其混乱
  • 维护成本高

php:

  • 开发速度很快,功能很强大,跨平台,代码很简单
  • 无法承载大访问量的情况

JSP/servlet:

B/S:浏览器和服务器

C/S:客户端和服务器

  • sun公司主推的B/S架构
  • 基于java语言的(所有的大公司,或者一些开源组件都是用java)
  • 可以承载三高问题带来的影响。(高并发、高可用、高性能)
  • 语法像ASP,方便让ASP人员转JSP,加强市场强度

2.2 web服务器

服务器是一种被动的操作,用来处理用户的一些请求和给用户一些响应信息

IIS

微软的:ASP…windows中自带的

Tomcat

是Apache软件基金会的Jakarta项目中的一个核心项目

工作3-5年之后,可以尝试手写Tomcat服务器,

下载Tomcat:

  1. 安装or解压
  2. 了解配置文件及目录结构
  3. 这个东西的作用

3. Tomcat

3.1 安装Tomcat

官网:https://tomcat.apache.org/

java 制作动画 javaweb动画_tomcat_03


java 制作动画 javaweb动画_java_04

3.2 Tomcat启动和配置

文件夹作用:

java 制作动画 javaweb动画_idea_05

启动、关闭Tomcat

java 制作动画 javaweb动画_idea_06

访问测试:http://localhost:8080/

可能遇到的问题:

  1. Java环境变量没有配置
  2. 闪退问题:需要配置兼容性
  3. 乱码问题:需要配置文件

3.3 配置

java 制作动画 javaweb动画_maven_07

可以配置启动的端口号

  • tomcat的默认端口号为:8080
  • MySQL:3306
  • http:80
  • https:443
<Connector port="8081" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />

可以配置主机的名称

  • 默认的主机名为:localhost->127.0.0.1
  • 默认网站应用存放的位置为:webapps
<Host name="www.qinjiang.com"  appBase="webapps"
            unpackWARs="true" autoDeploy="true">

高难度面试题

请你谈谈网站是如何进行访问的!

  1. 输入一个域名,回车
  2. 检查本机的C:\Windows\System32\drivers\etc\hosts配置文件下有没有这个域名映射;
  1. 有:直接返回对应的IP地址,这个地址中,有我们需要访问的web程序,我们可以直接访问
  2. 没有:去DNS服务器中找,找到的话就返回,找不到就返回找不到

java 制作动画 javaweb动画_java 制作动画_08

  1. 可以配置一下环境变量(可选性)

3.4 发布一个web网站

不会就先模仿

  • 将自己写的网站,放到服务器(Tomcat)中指定的web应用的文件夹下,就可以访问了

网站应该有的结构

--webapps:Tomcat服务器的web目录
    -ROOT
    -wong:网站的目录名
        - web-INF
        	-classes:java程序
            -lib:web应用所以来的jar包
        	-web.xml
        -index.html 默认的首页
        -static
            -css
                -style.css
            -js
            -img
        -......

4. HTTP

4.1 什么是HTTP

HTTP:超文本传输协议,是一个简单的请求-响应协议,它通常运行在TCP之上

  • 文本:html、字符串…
  • 超文本:图片、音乐、视频、音频、定位、地图
  • 默认端口:80

HTTPS:安全的

  • 默认端口:443

4.2 两个时代

  • http1.0
  • HTTP 1.0:客户端可以与web服务器连接,只能获得一个web资源,之后断开连接
  • http2.0
  • HTTP 1.1:客户端可以与web服务器连接后,可以获得多个web资源

4.3 HTTP请求

  • 客户端–发请求(request)—服务器

百度:

Request URL: https://www.baidu.com/   请求地址
Request Method: GET	请求方法
Status Code: 200 OK	状态码
Remote Address: 182.61.200.6:443	远程地址
1. 请求行
  • 请求行中的请求方式:GET
  • 请求方式:GET,POST,HEAD,DELETE,PUT,TRACT…
  • get:请求能够携带的参数比较少,大小有限制,会在浏览器的URL地址栏显示数据内容,不安全,但是高效
  • post:请求能够携带的参数没有限制,大小没有限制,不会在浏览器的URL地址栏显示数据内容,安全,但是不高效
2. 消息头
Accept:text/html  告诉浏览器,它所支持的数据类型
Accept-Encoding: gzip, deflate, br 支持哪种编码格式
Accept-Language: zh-CN,zh;q=0.9 告诉浏览器它的语言环境
Cache-Control: max-age=0 缓存控制
Connection: keep-alive 告诉浏览器,请求完成是断开还是保持连接
Host:表示主机

4.4 HTTP响应

  • 服务器–响应–客户端

百度:

Cache-Control: private  缓存控制
Connection: keep-alive	连接,保持连接状态
Content-Encoding: gzip  编码:gzip
Content-Type: text/html;charset=utf-8  类型
1. 响应体
Accept:text/html  告诉浏览器,它所支持的数据类型
Accept-Encoding: gzip, deflate, br 支持哪种编码格式
Accept-Language: zh-CN,zh;q=0.9 告诉浏览器它的语言环境
Cache-Control: max-age=0 缓存控制
Connection: keep-alive 告诉浏览器,请求完成是断开还是保持连接
Host:表示主机
Refresh:告诉客户端,多久刷新一次
Location:让网页重新定位
2. 响应状态码

200:请求响应成功 200

3xx:请求重定向

  • 重定向:你重新到我给你的新位置去

4xx:找不到资源 404

  • 资源不存在

5xx:服务器代码错误 500 502:网关错误

常见面试题:

当你的浏览器地址栏输入地址并回车的一瞬间到页面能够展示回来,经历了什么?

5. Maven

我为什么要学习这个技术

  1. 在javaweb开发中,需要使用大量导入的jar包,我们手动去导入会浪费大量的时间
  2. 如何能够让一个东西自动帮助我们导入和配置这个jar包
    由此,Maven诞生

5.1 Maven项目架构管理工具

我们目前使用Maven来导入jar包

Maven的核心思想:约定大于配置

  • 有约束:不要去违反

Maven会规定好你该如何去编写我们的java代码,必须按照这个规范来

5.2下载安装Maven

地址:https://maven.apache.org/download.cgi

Binary zip archive

apache-maven-3.8.1-bin.zip

java 制作动画 javaweb动画_java 制作动画_09

下载完成后解压即可

5.3 配置环境变量

在我们的系统环境变量中,进行如下配置:

  • M2_HOME:maven目录下的bin目录
  • MAVEN_HOME:maven的目录
  • 在系统的path中,添加%MAVEN_HOME%\bin

java 制作动画 javaweb动画_java 制作动画_10

5.4 修改配置文件

  • 镜像:mirrors
  • 作用:加速我们的下载
镜像:
         <!--配置阿里云-->
    <mirror>
        <id>alimaven</id>
        <name>aliyun maven</name>
        <url>https://maven.aliyun.com/repository/public</url>
        <mirrorOf>central</mirrorOf>
    </mirror>
    <mirror>
        <id>alimaven-central</id>
        <name>aliyun maven central</name>
        <url>https://maven.aliyun.com/repository/central</url>
        <mirrorOf>central</mirrorOf>
    </mirror>
    <mirror>
        <id>alimaven-spring</id>
        <name>aliyun maven-spring</name>
        <url>https://maven.aliyun.com/repository/spring</url>
        <mirrorOf>central</mirrorOf>
    </mirror>
    <mirror>
        <id>central</id>
        <name>Maven Repository Switchboard</name>
        <url>https://repo1.maven.org/maven2/</url>
        <mirrorOf>central</mirrorOf>
    </mirror>
    <mirror>
        <id>jboss-public-repository-group</id>
        <mirrorOf>central</mirrorOf>
        <name>JBoss Public Repository Group</name>
        <url>http://repository.jboss.org/nexus/content/groups/public</url>
    </mirror>
    <mirror>
        <id>spring-snapshots</id>
        <mirrorOf>central</mirrorOf>
        <name>Spring Snapshots</name>
        <url>https://repo.spring.io/snapshot</url>
    </mirror>
    <mirror>
        <id>spring-milestones</id>
        <mirrorOf>central</mirrorOf>
        <name>Spring Milestones</name>
        <url>https://repo.spring.io/milestone</url>
    </mirror>

5.5 建立本地仓库

在本地的仓库,远程仓库;

建立一个本地仓库

<localRepository>E:\Environment\apache-maven-3.8.1\maven-repo</localRepository>

5.6 在IDEA中使用Maven

  1. 启动IDEA,新建Maven项目选择

java 制作动画 javaweb动画_maven_11

  1. 配置GAV

java 制作动画 javaweb动画_java 制作动画_12


java 制作动画 javaweb动画_tomcat_13

  1. 等待项目导入初始化完毕
  2. 观察maven仓库中多了哪些东西
  3. IDEA中的maven设置

java 制作动画 javaweb动画_java_14

多关注一下这个内容,多一个心眼

  • maven主路径:E:/Environment/apache-maven-3.8.1
  • maven用户设置文件:E:\Environment\apache-maven-3.8.1\conf\settings.xml
  • 本地存储库:E:\Environment\apache-maven-3.8.1\maven-repo
  1. 到这里,Maven在IDEA中的配置和使用就OK了

5.7 创建一个普通的Maven项目

初始的maven

java 制作动画 javaweb动画_maven_15

5.8 标记文件夹功能

java 制作动画 javaweb动画_tomcat_16

java 制作动画 javaweb动画_tomcat_17

5.9 在IDEA中配置tomcat

java 制作动画 javaweb动画_java_18

java 制作动画 javaweb动画_java_19

解决警告问题

为什么会有这个问题:我们访问一个网站,需要指定一个文件夹名字

java 制作动画 javaweb动画_java_20

java 制作动画 javaweb动画_idea_21

上面这个图的位置可以改也可以不改

可以启动了

java 制作动画 javaweb动画_java 制作动画_22

java 制作动画 javaweb动画_java 制作动画_23

java 制作动画 javaweb动画_idea_24

5.10 pom文件

pom.xml是maven的核心配置文件

<?xml version="1.0" encoding="UTF-8"?>
<!--maven版本和头文件-->
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>
<!--这里就是我们刚才配置的gav-->
  <groupId>com.wong</groupId>
  <artifactId>javaweb_maven_01</artifactId>
  <version>1.0-SNAPSHOT</version>
<!--  package:项目打包的方式
  jar:java应用
  war:JavaWeb应用
-->
  <packaging>war</packaging>

  <name>javaweb_maven_01 Maven Webapp</name>
  <!-- FIXME change it to the project's website -->
  <url>http://www.example.com</url>
<!--配置-->
  <properties>
<!--    项目的默认构建编码-->
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<!--    编译版本-->
    <maven.compiler.source>1.8</maven.compiler.source>
    <maven.compiler.target>1.8</maven.compiler.target>
  </properties>

  <dependencies>
<!--    具体依赖的jar包配置文件-->
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.11</version>
      <scope>test</scope>
    </dependency>
  </dependencies>
<!--项目构建用的东西-->
  <build>
    <finalName>javaweb_maven_01</finalName>
    <pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) -->
      <plugins>
        <plugin>
          <artifactId>maven-clean-plugin</artifactId>
          <version>3.1.0</version>
        </plugin>
        <!-- see http://maven.apache.org/ref/current/maven-core/default-bindings.html#Plugin_bindings_for_war_packaging -->
        <plugin>
          <artifactId>maven-resources-plugin</artifactId>
          <version>3.0.2</version>
        </plugin>
        <plugin>
          <artifactId>maven-compiler-plugin</artifactId>
          <version>3.8.0</version>
        </plugin>
        <plugin>
          <artifactId>maven-surefire-plugin</artifactId>
          <version>2.22.1</version>
        </plugin>
        <plugin>
          <artifactId>maven-war-plugin</artifactId>
          <version>3.2.2</version>
        </plugin>
        <plugin>
          <artifactId>maven-install-plugin</artifactId>
          <version>2.5.2</version>
        </plugin>
        <plugin>
          <artifactId>maven-deploy-plugin</artifactId>
          <version>2.8.2</version>
        </plugin>
      </plugins>
    </pluginManagement>
  </build>
</project>

maven由于他的约定大于配置,我们之后可能遇到我们写的配置文件,无法被配置或者导出,下面是解决方案

java 制作动画 javaweb动画_tomcat_25

5.11 生成目录树

java 制作动画 javaweb动画_java 制作动画_26

java 制作动画 javaweb动画_tomcat_27

5.12 解决遇到的问题

  1. Maven 3.6.2
  • 解决方法:降版本为maven 3.6.1

Unable to import maven project: See logs for details

  1. Tomcat闪退
  2. IDEA中每次都要重复配置Maven
  3. Maven项目中Tomcat无法配置
  4. maven默认web项目中的web.xml版本问题
  5. 替换为webapp4.0版本和tomcat一致
  6. maven仓库的使用
<version>2.8.2</version>
        </plugin>
      </plugins>
    </pluginManagement>
  </build>
</project>

maven由于他的约定大于配置,我们之后可能遇到我们写的配置文件,无法被配置或者导出,下面是解决方案

[外链图片转存中…(img-4qOBNQbU-1626620685091)]

5.11 生成目录树

[外链图片转存中…(img-pWOdP5Dq-1626620685093)]

[外链图片转存中…(img-QFjIgvBt-1626620685094)]

5.12 解决遇到的问题

  1. Maven 3.6.2
  • 解决方法:降版本为maven 3.6.1

Unable to import maven project: See logs for details

  1. Tomcat闪退
  2. IDEA中每次都要重复配置Maven
  3. Maven项目中Tomcat无法配置
  4. maven默认web项目中的web.xml版本问题
  5. 替换为webapp4.0版本和tomcat一致
  6. maven仓库的使用
  • 地址:https://mvnrepository.com/