JavaWeb学习笔记(一)------基本概念,Tomcat

JavaWeb学习笔记(一)------基本概念,Tomcat

基本概念

架构

  • B/S:浏览器和服务器
  • C/S:客户端和服务器

web开发

  • web,网页的意思,www.baidu.com

  • 静态web

    • html,css
    • 提供给所有人看的数据始终不会发生变化
  • 动态web

    • 每个人在不同时间,不同地点,看到的信息各不相同!
    • 例如:淘宝。几乎所有的网站都是动态的
    • 技术栈:Servlet/JSP,ASP,PHP
  • 在Java中,动态web资源开发的技术,统称为JavaWeb

web应用程序

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

  • 例如:a.html、b.html…多个web资源,这些web资源可以被外界访问,对外界提供服务

  • 可以访问到的任何一个页面或者资源,都存在于这个世界某一个角落的计算机上。

  • URL

  • 这些统一的web资源会被放在同一个文件夹下,就是一个web应用程序—>依赖于Tomcat:服务器

  • 一个web应用由多部分组成(静态web,动态web)

    • html,css,js
    • jsp,servlet
    • java程序
    • jar包
    • 配置文件(properties)

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

静态web

  • 例如:*.htm, *.html,这些都是网页的后缀,如果服务器上一直存在这些东西,我们就可以直接进行读取。通过网络

在这里插入图片描述

静态web存在的缺点
  • Web页面无法动态更新,所有用户看到的都是同一个页面。
    • 轮播图,点击特效:伪动态
    • 让静态页面能动起来的两种技术:JavaScript【用的较多】,VBScript
    • 无法和数据库交互(数据无法持久化,用户无法交互)

动态web

  • 页面会动态展示:Web页面的展示效果因人而异

在这里插入图片描述

动态web存在的缺点
  • 假如服务器的动态web资源出现了错误,我们需要重新编写我们的后台程序。例如:停机维护
动态web存在的优点
  • Web可以动态更新,所有用户看到的都不是同一个页面
  • 可以与数据库交互(数据持久化:注册,商品信息,用户信息…)

web服务器

技术讲解

ASP
  • 微软:国内最早流行的就是ASP;

  • 在HTML中嵌入了VB的脚本,ASP+COM;

  • 在ASP开发中,基本一个页面都有几千行的业务逻辑代码,页面及其混乱

  • 维护成本高

  • 主要使用C#

  • IIS开发

PHP
  • PHP开发速度很快,功能很强大,而且跨平台,代码很简单(70%的平台都是中小型,WP)
  • 无法承载大访问量的情况(局限性)
  • 停留在中小型开发
JSP/Servlet
  • SUN公司主推的B/S架构
  • 基于Java语言的(所有的大公司或一些开源组件,都是用Java写)
  • 可以承载高并发,高可用,高性能带来的影响
  • 语法和ASP非常相似,加强市场强度

Web服务器

  • 服务器是一种被动的操作,用来处理用户的一些请求和给用户一些相应信息
IIS
  • 用于运行微软的一些东西,ASP…Windows中自带的
Tomcat
  • 面向百度编程
  • Tomcat是Apache软件基金会 (Apache Software Foundation)的Jakarta项目中的一个核心项目,最新的
    Servlet和SP规范总是能在Tomcat中得到体现,因为Tomcat技术先进、性能稳定,而且免费,因而深受Java爱好者的喜爱并得到了部分软件开发商的认可,成为目前比较流行的Web 应用服务器。
    Tomcat服务器是一个免费的开放源代码的Web应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试ISP程序的首选。对于一个ava初学web的人来说,它是最佳的选择
    Tomcat实际上运行ISP页面和Servlet。Tomcat最新版本为9.0。
  • 工作3-5年后,可以尝试手写Tomcat服务器
下载Tomcat
  • 安装or解压
  • 了解配置文件及目录结构
  • 了解这个东西的作用

Tomcat

安装Tomcat

  • Tomcat官网
  • 解压下载后得到的安装包

Tomcat启动和配置

  • 文件夹信息
    在这里插入图片描述

  • 启动,关闭Tomcat
    在这里插入图片描述

  • 启动成功(Java环境配置好,不需要单独配置Tomcat文件)
    在这里插入图片描述

可能遇到的问题
  • Java环境变量没有配置(会闪退)

  • 闪退问题:需要配置兼容性

  • 乱码问题:配置文件中的设置(一般情况下不去改bat文件),可以把编码方式改成BAT
    在这里插入图片描述

配置文件中可以配置启动的端口号
<Connector port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />
  • tomcat的默认端口号为:8080
  • mysql默认端口号:3306
  • http默认端口号:80
  • https默认端口号:443
配置文件中可以配置主机的名称
 <Host name="localhost"  appBase="webapps"
            unpackWARs="true" autoDeploy="true">
  • 默认的主机名为:localhost = 127.0.0.1
  • 默认的网站应用存放的位置为:webapps
高难度面试题
  • 请你谈谈网站是如何进行访问的?(三次握手)
  • 第一步:输入域名,点击回车
  • 第二步:检查本机的配置文件下{C:\Windows\System32\drivers\etc\hosts},有没有这个域名的映射;
    • 如果有:直接返回对应ip地址,这个地址中,有我们需要访问的web程序,可以直接访问
    • 如果没有:去DNS服务器找,找到就返回,找不到就返回网页走丢了
    • DNS:全世界的域名都在这里管理

发布一个web网站

  • 可以访问localhost:8080\examples,仿照其中的例子进行学习

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

  • 网站应该有的结构

--webapps:Tomcat服务器的web目录
    -ROOT
    -网站目录名
    	- WEB-INF
    		- classes:java程序
            - lib:web应用所依赖的jar包
    		- web.xml:网站配置文件
    	- index.html:默认的首页 
    	- static
                - css
                	-style.css
                - js
                - img

HTTP协议

什么是HTTP

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

  • 文本:html,字符串,…
  • 超文本:图片,音乐,视频,定位,地图,…

Https:安全的

两个时代

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

Http请求

  • 客户端-----发请求(Request)-----服务器
  • 百度的请求
请求 URL: https://www.baidu.com/
请求方法: GET          (get/post)
状态代码: 200 OK
远程地址: 112.80.248.75:443
  • 请求标头(request heading)
Accept: text/html
Accept-Encoding: gzip, deflate, br  类型编码
Accept-Language: zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6      语言
Cache-Control: max-age=0
Connection: keep-alive
请求行
  • 请求行中的请求方式:GET
  • 请求方式:GET/POST,HEAD,DELETE,PUT,TRACT…
    • GET:一次请求能够携带的参数比较少,大小有限制,会在浏览器的URL地址栏显示数据内容,不安全但更高效
    • POST:一次请求能够携带的参数没有限制,大小没有限制,不会再浏览器的URL地址栏显示数据内容,安全但不高效
消息标头
Accept:告诉浏览器,它所支持的数据类型
Accept-Encoding:支持哪种编码格式 GBK  UTF-8 GB2312 ISO8859-1
Accept-Language:告诉浏览器,它的语言环境
Cache-Control:缓存控制
Connection:告诉浏览器,请求完成是断开还是保持连接
HOST:主机

Http响应

  • 服务器-----响应-----客户端

  • 百度的响应

Cache-Control: private                 缓存控制
Connection: keep-alive                 连接:保持连接
Content-Encoding: gzip                 编码
Content-Type: text/html;charset=utf-8  类型
响应体
Accept:告诉浏览器,它所支持的数据类型
Accept-Encoding:支持哪种编码格式 GBK  UTF-8 GB2312 ISO8859-1
Accept-Language:告诉浏览器,它的语言环境
Cache-Control:缓存控制
Connection:告诉浏览器,请求完成是断开还是保持连接
HOST:主机
Refresh:告诉客户端,多久刷新一次
Location:让网页重新定位
响应状态码(重点)
  • 200:请求响应成功

  • 3xx:请求重定向

    • 重定向:重新到给定的新位置去
  • 4xx:找不到资源 404

    • 资源不存在
  • 5xx:服务器代码错误 500

    • 502:网关错误
常见面试题
  • 当你的浏览器中地址栏输入地址并回车的一瞬间,到页面能够展示回来,经历了什么?
    1. 域名解析
    2. 发起TCP的三次握手
    3. 建立起TCP连接后发起http请求
    4. 服务器响应http请求,浏览器得到html代码
    5. 浏览器解析html代码,并请求html代码中的资源(css JavaScript 图片)
    6. 浏览器对页面进行渲染呈现
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值