javaWeb
1、基本概念
1.1、前言
web开发:
- web,网页的意思:www.baidu.com
- 静态web
- html,js,css
- 提供给所有人看的数据始终不会变化!
- 动态web
- 提供给所有人的数据始终会发生变化,每个人在不同时间,不同地点看到的信息各不相同!
- 技术栈:servlet/jsp,Asp,PHP
在java中,动态web资源开发技术统称为javaweb
1.2、web应用程序
web应用程序、提供浏览器访问的程序:
-
a.html、b.html…多个web资源,这些web资源可以被外界访问,对外界提供服务;
-
访问的任何一个页面或者资源,都存在与这个世界的某一个角落的计算机上。
-
URL:统一资源定位符
-
这些web资源会统一放到一个文件夹下,web应用程序—>依赖于Tomcat:服务器
-
一个web应用由多部分组成(由静态web,动态web)
- html,css,js
- jsp.servlet
- java程序
- jar包
- 配置文件(properties)
web应用程序编写完毕后,若想提供给外界访问:需要一个服务器来统一管理
1.3、静态web
-
*.htm, *.html,这些都是网页的后缀,如果服务器上一直存在这些东西,我们就可以直接进行读取。
-
静态web存在的缺点
- web页面无法动态更新,所有用户都是同一个页面。
- 轮播图,点击特效:伪动态
- JavaScript[实际开发中,它用的最多]
- VBScript(微软)
- 无法与数据库交互(数据无法持久化,用户无法交互)
- web页面无法动态更新,所有用户都是同一个页面。
1.4、动态web
页面会动态展示:“web的页面展示的效果因人而异”
缺点:
- 假如服务器的动态web资源出现了错误,我们需要重新编写我们的后台程序,重新发布;
- 停机维护
优点:
- web页面可以动态更新,所有用户都不是同一个页面。
- 数据持久化,可以与用户交互
2、Web服务
2.1、技术讲解
ASP:
- 微软:国内最早留下的就师ASP
- 在Html中嵌入了VB的脚本,ASP+COM;
- 在ASP开发中,基本一个页面都有几千行页面代码,页面极其混乱
- 维护成本高
- C#
- IIS
<h1>
<table>
<%
//逻辑代码
System.out.println("hello")
%>
</table>
</h1>
PHP:
- PHP开发书店很快,功能很强大,跨平台,代码很简单(中国有70%使用)
- 无法承载大访问量的情况(有局限)
JSP/Servlet:
B/S 浏览器和服务器
C/S 客户端和服务器
- sun公司主推的B/S架构
- 基于Java语言的(所有的大公司,或者一些开源的组件,都是用Java写的
- 可以承载三高问题带来的影响(高并发,高可用,高性能)
- 语法像ASP
2.2、web服务器
服务器师一种被动的操作,用来处理用户的一些请求和给用户一些响应信息:
IIS
微软的:ASP,windows中自带的
Tomcat
Tomcat是Apache 软件基金会(Apache Software Foundation)的Jakarta 项目中的一个核心项目,由Apache、Sun 和其他一些公司及个人共同开发而成。由于有了Sun 的参与和支持,最新的Servlet 和JSP 规范总是能在Tomcat 中得到体现,Tomcat 5支持最新的Servlet 2.4 和JSP 2.0 规范。因为Tomcat 技术先进、性能稳定,而且免费,因而深受Java 爱好者的喜爱并得到了部分软件开发商的认可,成为目前比较流行的Web 应用服务器。
Tomcat 服务器是一个免费的开放源代码的Web 应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试JSP 程序的首选。对于一个Java初学web的人来说,它是最好的选择。
Tomcat是一个Servlet和JSP容器。
工作3-5年之后,可以尝试手写Tomcat服务器:
下载tomcat:
1.安装or解压
2.了解配置文件及目录结构
3.这个东西的作用
3、Tomcat
3.1、安装tomcat
tomcat官网:http://tomcat.apache.org/
下载解压即可使用
3.2、tomcat启动配置
启动、关闭Tomcat
访问测试:http://localhost:8080/
可能遇到的问题
- java环境变量没有配置好
- 闪退问题:需要配置兼容性
- 乱码问题:配置文件中设置(一般不会改这个)
3.3、配置
可以配置启动的端口号
- tomcat的默认端口号为:8080
- mysql的默认端口:3306
- http:80
- https:442
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
可以配置主机名称
- 默认的主机名为:localhost–>127.0.0.1
- 默认网站应用存放的位置为webapps
<Host name="localhost" appBase="webapps"
unpackWARs="true" autoDeploy="true">
高难度面试题
请你谈谈网站是如何进行访问的!
-
输入一个域名:回车
-
检查本机的C:\windows\System32\drivers\etc\hosts配置文件下有没有这个域名映射;
-
有:直接返回对应的ip地址,这个地址中,有我们需要访问的web程序,可以直接访问
127.0.0.1 www.chance.com
-
没有:去DNS服务器中去找,找到的话就返回,找不到就返回找不懂;
-
3.4、发布一个web网站
- 将自己写的网站,放到服务器(tomcat)中指定的web应用文件夹(webapps)下,就可以访问了网站应该有的结构
网站应该有的结构
--webapps:tomcat服务器的web目录
-ROOT
-kuangstudy:网站的目录名
-WEB-INF
-classes : java程序
-lib:web应用所以来的jar包
-web.xml:网站配置文件
-index.html 默认的首页
-static
-css
-style.css
-js
-img
-.........
***思考怎么配置host
4、HTTP
4.1、什么是HTTP
Http(超文本传输协议)是一个简单的请求-响应协议,它通常运行在TCP之上。
- 文本:html,字符串,……
- 超文本:图片,音乐,视频,定位,地图……
- 端口:80
Https:安全的
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 // 请求方法:get和post
Status Code: 200 OK // 状态码:200
Remote (远程的) Address: 14.215.177.39:443
Accept:text/html
Accept-Encoding: gzip, deflate, br
Accept-Language: en-US,en;q=0.9 语言
Cache-Control: max-age=0
Connection: keep-alive
1、请求头
- 请求行中的请求方式:GET
- 请求方式:GET、Post、HEAD、PUT、TERACT…
- get:请求能够携带的参数比较少,大小有限制,会在浏览器的URL地址显示数据内容,不安全,但高效
- post:请求能够携带的参数没有限制,大小没有限制,不会在浏览器的URL地址显示数据内容,安全,但不高效
2、消息头
Accept:告诉浏览器,它所支持的数据类型
Accept-Encoding: 支持那种编码格式:GBK UTF_8 GB2312 ISO8859-1
Accept-Language: 告诉浏览器,它的语言环境
Cache-Control: 缓存控制
Connection: 告诉浏览器,请求完成是端口还是保存连接
HOST:主机……
4.4、Http响应(Response)
-
服务器—响应----客户端
百度:
Cache-Control: private 缓存控制 Connection: keep-alive 连接 Content-Encoding: gzip 编码 Content-Type: text/html;charset=utf-8 类型
1、响应体
Accept:告诉浏览器,它所支持的数据类型 Accept-Encoding: 支持那种编码格式:GBK UTF_8 GB2312 ISO8859-1 Accept-Language: 告诉浏览器,它的语言环境 Cache-Control: 缓存控制 Connection: 告诉浏览器,请求完成是端口还是保存连接 HOST:主机…… ReFrush:告诉客户端,多久刷新一次 Location:让网页重新定位
2、响应状态码
200:请求响应成功
3XX:请求重定向
- 重定向:重新到指定的新地址去
404:找不到资源404
- 资源存在;
5XX: 服务器代码错误 500 502:网关错误
常见面试题:
当你的浏览器中地址输入地址并回车的一瞬间到页面能够展示回来,经历了什么?
5、Maven
为什么要学这个技术?
-
在Javaweb开发中,需要使用大量的jar包,我们手动去导入很麻烦
-
如何能够让一个东西自动帮我导入和配置这个jar包。
由此,Maven诞生了!
5.1 Maven 项目架构管理工具
目前用来方便导入jar包的!
Maven的核心思想:约定大于配置
- 有约束,不要去违反
Maven会规定好你该如何去编写我们的Java代码,必须要按照这个规定来;
5.2下载安装Maven
5XX: 服务器代码错误 500 502:网关错误
常见面试题:
当你的浏览器中地址输入地址并回车的一瞬间到页面能够展示回来,经历了什么?
5、Maven
为什么要学这个技术?
-
在Javaweb开发中,需要使用大量的jar包,我们手动去导入很麻烦
-
如何能够让一个东西自动帮我导入和配置这个jar包。
由此,Maven诞生了!
5.1 Maven 项目架构管理工具
目前用来方便导入jar包的!
Maven的核心思想:约定大于配置
- 有约束,不要去违反
Maven会规定好你该如何去编写我们的Java代码,必须要按照这个规定来;
5.2下载安装Maven
官网:https://maven.apache.org/
下载完成后,解压即可:
小狂神友情建议:电脑上的所有环境都放在一个文件夹下,方便管理:
5.3 配置环境变量
在我们的系统环境变量中
配置如下配置:
- M2_HOME maven目录下的bin目录
- MAVEN_HOME maven的目录
- 在系统的Path中配置%MAVEN_HOME%\bin
测试maven是否安装成功:mvn -v回车或者mvn -version,保证必须配置完毕
5.4 阿里云镜像
-
镜像:mirrors
- 作用:加速我们的下载速度
-
国内建议使用阿里云
<mirror> <id>alimaven</id> <mirrorOf>central</mirrorOf> <name>aliyun maven</name> <url>http://maven.aliyun.com/nexus/content/repositories/central/</url> </mirror>
5.5 本地仓库
建立一个本地仓库:localRepository
<localRepository>D:\Environment\apache-maven-3.6.3\maven_repo</localRepository>
5.6 在IDEA中使用Maven
1.启动IDEA
2.创建一个MavenWeb项目(普通项目不用勾选模板,直接next)
3.点击finish,在网络条件好的地方进行下载包,一般不会出错,如果有出错可能是阿里云镜像出错或者网络问题
当出现build success时就是创建成功了
4.观察maven仓库中多了什么(多了常用的jar包)
5.IDEA中的maven的设置
注意:IDEA项目创建成功后,看一眼maven的配置防止出现问题
6.到这里,maven在IDEA中的配置和使用就ok了!
5.7 创建一个普通的maven项目
这个只有在web应用中才会有的
5.8 标记文件夹功能
5.9 在IDEA中配置Tomcat
解决警告问题
必须要的为什么会有这个问题:我们访问一个网站,需要指定一个文件夹名字:
启动tomcat项目
5.10 pom文件
pom.xml 是maven的核心配置文件
<build>
<finalName>javaweb-01-maven</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>
maven由于他的约定大于配置,我们之后可能遇到我们写的配置文件,无法别被导出或者生效的问题,解决方案:
<build>
<!--在build 中配置resource,来防止我们资源导出失败的问题-->
<resources>
<resource>
<directory>src/main/resources</directory>
<excludes>
<exclude>**/*.properties</exclude>
<exclude>**/*.xml</exclude>
</excludes>
<filtering>false</filtering>
</resource>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>false</filtering>
</resource>
</resources>
</build>
5.13 解决遇到的问题
- Tomcat闪退
- IDEA中每次都要重复配置Maven
- Maven项目中Tomcat无法配置