JavaWeb


1、基本概念

1.1 web开发

  • web,网页的意思,www.baidu.com
  • 静态web
    • html,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
    • 它无法和数据库交互(数据无法持久化,用户无法交互)

1.4 动态web

页面会动态展示:“Web的页面展示的效果因人而异”;
在这里插入图片描述
缺点

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

优点
- Web页面可以动态更新,所有用户看到的不是同一个页面
- 它可以和数据库交互(数据持久化:注、商品信息、用户信息)

在这里插入图片描述

2、web服务器

2.1技术讲解

ASP

  • 微软:国内最早流行的就是ASP;
  • 在HTML中嵌入了VB的脚本,ASP + COM
  • 在ASP开发中,基本一个页面
  • c#
    <h1>
    	<h1><h1>
    		<h1>
    		<h1>
    		<%
    			system.out.println("hello")
    		%>
    <h1>
    

PHP:

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

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

  • sun公司主推的B/S架构
  • 基于java语言的(所有的大公司,或者一些开源的组件,都是用Java写的)
  • 语法像ASP,ASP---->JSP,加强市场的强度;

2.2、web服务器

服务器是一种被动的操作,用来处理用户的一些请求和给用户一些响应信息;
IIS
互联网信息服务(英语:Internet Information Services,简称IIS),是由微软公司提供的基于运行Microsoft Windows的互联网基本服务。最初是WindowsNT版本的可选包,随后自带在Windows2000、Windows XP Professional和Windows Server 2003一起发布,但在普遍使用的Windows XP Home版本上并没有IIS。

Tomcat
Tomcat是Apache 软件基金会(Apache Software Foundation)的Jakarta 项目中的一个核心项目,最新的Servlet 和JSP 规范总是能在Tomcat 中得到体现,Tomcat 5支持最新的Servlet 2.4 和JSP 2.0 规范。因为Tomcat 技术先进、性能稳定,而且免费,因而深受Java 爱好者的喜爱并得到了部分软件开发商的认可,成为比较流行的Web 应用服务器。
Tomcat 服务器是一个免费的开放源代码的Web 应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试JSP 程序的首选。对于一个初学者来说,是最佳的选择。
Tomcat 实际上运行JSP 页面和Servlet。另外,Tomcat和IIS等Web服务器一样,具有处理HTML页面的功能,另外它还是一个Servlet和JSP容器,Tomcat最新版本为10.0.5。

3.Tomcat

3.1 安装tomcat

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

在这里插入图片描述
在这里插入图片描述

3.2 tomcat的启动和配置

文件夹作用:

在这里插入图片描述在这里插入图片描述
访问测试:http://localhost:8080/
可能遇到的问题:

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

可以修改 conf/logging.properties 中的 java.util.logging.ConsoleHandler.encoding = GBK 解决乱码问题

3.3 配置

在这里插入图片描述
可以配置启动的端口号

  • 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">
    

3.4 高难度面试题:请你谈谈网站是如何进行访问的!

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

       127.0.0.1 www.qinjiang.com
      
    2. 没有:去DNS服务器找,找到的话就返回,找不到就返回找不到;
      在这里插入图片描述

3.5 、发布一个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
         -.....

HTTP协议:面试
Maven:构建工具

  • Maven安装包

Servlet入门

  • HelloWorld!
  • Servlet配置 ·原理

4.Http

4.1、什么是HTTP

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

文本:html,字符串,…
超文本:图片,音乐,视频,定位,地图.……
端口:80
Https:安全的

4.2、两个时代

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

4.3、Http请求

  • 客户端–发请求(Request)–服务器
  • 请求行、请求头、请求体(其中请求行和请求体之间有空格来区分),如:
    Post /from/login?xxx HTTP1.1
    Host:www.baidu.com Connection:keep-alive
    name = swz & age =37

4.4、Http响应

  • 服务器–响应…….客户端
  • 响应行、响应头、响应体(响应行和响应体之间有空格),如:
    200 OK HTTP1.1
    Data:xxxx Content-length:360
    < h1 > hello,world!< h1 >

4.5 Http1.0和Http1.1的区别

1、前者是短连接,后者是长连接
当请求一次连接的时候,如果是短连接的话,对于页面中的其他资源,如:js、image都会建立一次新的连接,而长连接可以共用一个。
2、后者增加了很多新的状态码,如206:部分请求
3、后者对于网络资源的处理更加优化,如允许部分请求
4、后者在请求头中增加了Host字段,之前认为是一台主机一个IP,而因为虚拟机等的出现,多个主机公用一个ip

4.6 http常见的状态码

100:Continue
200:OK、206:部分请求
301:永久重定向、302:临时重定向
永久:代表访问某个a,会自动跳转到b,url为b;临时:访问a,url不变,但是内容渲染的是b
400:客户端语法错误、403:服务器拒绝提供服务(不为请求提供服务,或您没有连接到此站点的权限时)、404:页面没有找到
500:服务器内部执行错误,无法完成请求、503:服务器正在维护

原文链接:https://blog.csdn.net/qq_37534947/article/details/120399336

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目录,不然会报错
MAVEN_HOME : maven的目录
在系统的path中配置:%MAVEN_HOME%\bin

在这里插入图片描述
测试Maven是否安装成功,保证必须配置完毕!
在这里插入图片描述

5.4阿里云镜像

  • 镜像:mirrors

  • 作用:加速我们的下载

  • 国内建议使用阿里云的镜像

    <mirror>
        <id>nexus-aliyun</id>  
        <mirrorOf>*,!jeecg,!jeecg-snapshots</mirrorOf>  
        <name>Nexus aliyun</name>  
        <url>http://maven.aliyun.com/nexus/content/groups/public</url> 
    </mirror>
    

    位置:D:\apache-maven-3.3.3-bin\apache-maven-3.3.3\conf\settings.xml
    在这里插入图片描述

5.5 本地仓库

在本地的仓库,远程仓库; 建立一个本地仓库:localRepository

<localRepository>D:\ttRepository</localRepository>

在这里插入图片描述

在这里插入图片描述

5.6 在IDEA中使用maven

1. 启动IDEA

2 .创建一个maven项目

在这里插入图片描述在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3.等项目初始化完毕:等右下角跑完,再点击enable auth-import

在这里插入图片描述
在这里插入图片描述

4 . 观察maven仓库多了些什么东西?

5. IDEA中的Maven设置

在这里插入图片描述
在这里插入图片描述

6.到这里,Maven在IDEA中的配置和使用就ok了

5.7 创建一个普通的maven项目

在这里插入图片描述

在这里插入图片描述
注:我们要在5.6的项目中创建java、resource等文件夹。
在这里插入图片描述

5.8 标记文件夹功能

1.第一种

在这里插入图片描述
在这里插入图片描述

2.第二种

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

5.9 在idea中配置tomcat

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 解决警告问题?
  • 为什么会有这个问题,我们访问一个网站,需要指定一个文件夹名字。
    在这里插入图片描述在这里插入图片描述在这里插入图片描述
    在这里插入图片描述

5.10 pom文件

  • pom.xml是Maven的核心配置文件
    在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

5.11之后遇到的问题

  • maven由于他的约定大于配置,我们之后可能遇到我们写的配置文件,无法导出或者生效的问题,解决方案:
    在这里插入图片描述

5.12 idea操作

在这里插入图片描述
在这里插入图片描述

5.13 maven仓库导入包

地址:https://mvnrepository.com/
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
作用域一般可以删掉
在这里插入图片描述


#待更新++++

总结

提示:这里对文章进行总结:
例如:以上就是今天要讲的内容,本文仅仅简单介绍了pandas的使用,而pandas提供了大量能使我们快速便捷地处理数据的函数和方法。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Studying_swz

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值