javaweb

2 篇文章 0 订阅
1 篇文章 0 订阅

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(微软)
    • 无法与数据库交互(数据无法持久化,用户无法交互)

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/

安装tomcat

下载解压即可使用

3.2、tomcat启动配置

tomcat包内容

启动、关闭Tomcat

启动关闭Tomcat

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

可能遇到的问题

  1. java环境变量没有配置好
  2. 闪退问题:需要配置兼容性
  3. 乱码问题:配置文件中设置(一般不会改这个)

3.3、配置

tomcat配置

可以配置启动的端口号

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

高难度面试题

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

  1. 输入一个域名:回车

  2. 检查本机的C:\windows\System32\drivers\etc\hosts配置文件下有没有这个域名映射;

    1. 有:直接返回对应的ip地址,这个地址中,有我们需要访问的web程序,可以直接访问

      127.0.0.1   www.chance.com
      
    2. 没有:去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
  • 请求方式:GETPost、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

为什么要学这个技术?

  1. 在Javaweb开发中,需要使用大量的jar包,我们手动去导入很麻烦

  2. 如何能够让一个东西自动帮我导入和配置这个jar包。

    由此,Maven诞生了!

5.1 Maven 项目架构管理工具

目前用来方便导入jar包的!

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

  • 有约束,不要去违反

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

5.2下载安装Maven

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

常见面试题:

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

5、Maven

为什么要学这个技术?

  1. 在Javaweb开发中,需要使用大量的jar包,我们手动去导入很麻烦

  2. 如何能够让一个东西自动帮我导入和配置这个jar包。

    由此,Maven诞生了!

5.1 Maven 项目架构管理工具

目前用来方便导入jar包的!

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

  • 有约束,不要去违反

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

5.2下载安装Maven

官网:https://maven.apache.org/
Maven下载官网

下载完成后,解压即可:

小狂神友情建议:电脑上的所有环境都放在一个文件夹下,方便管理:

5.3 配置环境变量

在我们的系统环境变量中

配置如下配置:

  • M2_HOME maven目录下的bin目录
  • MAVEN_HOME maven的目录
  • 在系统的Path中配置%MAVEN_HOME%\bin

在这里插入图片描述

测试maven是否安装成功:mvn -v回车或者mvn -version,保证必须配置完毕

5.4 阿里云镜像

maven设置

  • 镜像: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)

创建maven项目

在这里插入图片描述

3.点击finish,在网络条件好的地方进行下载包,一般不会出错,如果有出错可能是阿里云镜像出错或者网络问题

在这里插入图片描述

当出现build success时就是创建成功了

4.观察maven仓库中多了什么(多了常用的jar包)

5.IDEA中的maven的设置

​ 注意:IDEA项目创建成功后,看一眼maven的配置防止出现问题

在这里插入图片描述

在这里插入图片描述

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

5.7 创建一个普通的maven项目

在这里插入图片描述

在这里插入图片描述

这个只有在web应用中才会有的

Mavenweb项目

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 解决遇到的问题

  1. Tomcat闪退
  2. IDEA中每次都要重复配置Maven
  3. Maven项目中Tomcat无法配置
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值