IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> JavaWeb-IDEA利用Tomcat发布网站 -> 正文阅读

[Java知识库]JavaWeb-IDEA利用Tomcat发布网站

1、基本概念

1.1、Web和JavaWeb

Web是全球广域网,也称为万维网(www),能够通过浏览器访问的网站。在我们日常的生活中,经常会使用浏览器去访问百度京东等网站,这些网站统称为Web网站。
我们知道了什么是Web,那么JavaWeb又是什么呢?顾名思义JavaWeb就是用Java技术来解决相关web互联网领域的技术栈。

1.2、 B/S架构

什么是B/S架构?
B/S 架构:Browser/Server,浏览器/服务器 架构模式,它的特点是,客户端只需要浏览器,应用程序的逻辑和数据都存储在服务器端。浏览器只需要请求服务器,获取Web资源,服务器把Web资源发送给浏览器即可。
image-20220122224300475

  • 打开浏览器访问百度首页,输入要搜索的内容,点击回车或百度一下,就可以获取和搜索相关的内容
  • 思考下搜索的内容并不在我们自己的点上,那么这些内容从何而来?答案很明显是从百度服务器返回给我们的
  • 日常百度的小细节,逢年过节百度的logo会更换不同的图片,服务端发生变化,客户端不需做任务事情就能获取最新内容
  • B/S架构的好处:易于维护升级:服务器端升级后,客户端无需任何部署就可以使用到新的版本。

1.3、 静态资源

  • 静态资源主要包含HTML、CSS、JavaScript、图片等,主要负责页面的展示。

1.4、 动态资源

  • 动态资源主要包含ServletJSP等,主要用来负责逻辑处理。
  • 动态资源处理完逻辑后会把得到的结果交给静态资源来进行展示,动态资源和静态资源要结合一起使用。
  • 动态资源虽然可以处理逻辑,但是当用户来登录百度的时候,就需要输入用户名密码,这个时候我们就又需要解决的一个问题是,用户在注册的时候填入的用户名和密码,这就需要数据库来对数据进行存储

1.5、 数据库

  • 数据库主要负责存储数据。

  • 整个Web的访问过程如下:

    • 浏览器发送一个请求到服务端,去请求所需要的相关资源;
    • 资源分为动态资源和静态资源,动态资源可以是使用Java代码按照Servlet和JSP的规范编写的内容;
    • 在Java代码可以进行业务处理也可以从数据库中读取数据;
    • 拿到数据后,把数据交给HTML页面进行展示,再结合CSS和JavaScript使展示效果更好;
    • 服务端将静态资源响应给浏览器;
    • 浏览器将这些资源进行解析;
    • 解析后将效果展示在浏览器,用户就可以看到最终的结果。

    image-20220122225057722

1.6、 HTTP协议

  • HTTP协议:主要定义通信规则
  • 浏览器发送请求给服务器,服务器响应数据给浏览器,这整个过程都需要遵守一定的规则,如同在网络编程中的TCP、UDP,这些都属于规则,这里我们需要使用的是HTTP协议,这也是一种规则。

1.7、 Web服务器

  • Web服务器:负责解析 HTTP 协议,解析请求数据,并发送响应数据
  • 浏览器按照HTTP协议发送请求和数据,后台就需要一个Web服务器软件来根据HTTP协议解析请求和数据,然后把处理结果再按照HTTP协议发送给浏览器

2、HTTP

Hyper Text Transfer Protocol,超文本传输协议,规定了浏览器和服务器之间数据传输的规则

image-20220122122144598

2.1、协议特点

  • 基于TCP协议,面向连接、安全
  • 基于请求-相应模型,即一次请求对应一次相应
  • HTTP协议是无状态的协议,对于事务处理没有记忆能力,每次请求-相应都是独立的
    • 缺点:多次请求间不能共享数据,后期可通过Java中的会话技术(Cookie、Session)来解决这个问题
    • 优点:速度快

2.2、请求数据格式

请求数据分为3部分,分别为请求行、请求头和请求体

  • 请求行:请求数据的第一行。其中的GETPOST表示请求方式,/表示请求资源路径,HTT/1.1表示协议版本
  • 请求头:第二行开始,格式为key:value形式
  • 请求体POST请求的最后一部分,存放请求参数

image-20220122122922941

常见的HTTP请求头:

  • Host:表示请求的主机名
  • User-Agent:浏览器版本,例如Chrome浏览器的表示类似Mozilla/5.0…Chrome/79;
  • Accept:表示浏览器能接受的资源类型,如text/*image/* 或者*/* 表示所有;
  • Accept-Language:表示浏览器偏好的语言,服务器可以据此返回不同语言的网页;
  • Accept——Encoding:表示浏览器可以支持的压缩类型,例如gzip、deflate等。

GET请求和POST请求的区别

  1. GET请求中的请求参数在请求行中,没有请求体。POST请求的请求参数在请求体中
  2. GET请求的请求参数有限制,POST没有

2.3、响应数据格式

响应数据氛围3部分,分别为响应行、响应头和响应体

  • 响应行:相应数据的第一行。其中HTTP/1.1表示协议版本,200表示响应状态码,OK表示状态码描述
  • 响应头:第二行开始,格式为key:value形式
  • 响应体:最后一部分,存放响应数据

image-20220122124114809

常见的HTTP响应头:

  • Content-Type:表示该相应内容的类型。例如text/htmlimage/jepg
  • Content-length:表示该响应内容的长度(字节数);
  • COntent-Encoding:表示该响应压缩算法。例如gzip;
  • Cache-Control:指示客户端应如何缓存,例如max-age=300表示可以最多缓存300秒。

2.4、Java模拟服务端

打开IDEA运行下面代码,启动自定义的服务端

/**
 * 模拟服务端
 * @author xBaozi
 * @version 1.0
 * @className Server
 * @description 模拟服务端
 * @date 2022/1/22 20:49
 */
public class Server {
    public static void main(String[] args) throws IOException {
        // 监听指定端口
        ServerSocket ss = new ServerSocket(8080);
        System.out.println("server is running...");
        while (true){
            // 调用accept()表示接受来自于客户端的socket
            Socket sock = ss.accept();
            System.out.println("connected from " + sock.getRemoteSocketAddress());
            Thread t = new Handler(sock);
            t.start();
        }
    }
}

class Handler extends Thread {
    Socket sock;

    public Handler(Socket sock) {
        this.sock = sock;
    }

    @Override
    public void run() {
        // 获取输入流
        try (InputStream input = this.sock.getInputStream()) {
            // 获取输出流
            try (OutputStream output = this.sock.getOutputStream()) {
                handle(input, output);
            }
        } catch (Exception e) {
            try {
                this.sock.close();
            } catch (IOException ioe) {
            }
            System.out.println("client disconnected.");
        }
    }

    private void handle(InputStream input, OutputStream output) throws IOException {
        BufferedReader reader = new BufferedReader(new InputStreamReader(input, "GBK"));
        BufferedWriter writer = new BufferedWriter(new OutputStreamWriter(output, "GBK"));
        // 读取HTTP请求:
        boolean requestOk = false;
        String first = reader.readLine();
        if (first.startsWith("GET / HTTP/1.")) {
            requestOk = true;
        }
        while(true) {
            String header = reader.readLine();
            // 读取到空行时, HTTP Header读取完毕
            if (header.isEmpty()) {
                break;
            }
            System.out.println(header);
        }
        System.out.println(requestOk ? "Response OK" : "Response Error");
        if (!requestOk) {
            // 发送错误响应:
            writer.write("HTTP/1.0 404 Not Found\r\n");
            writer.write("Content-Length: 0\r\n");
            writer.write("\r\n");
            writer.flush();
        } else {
            // 发送成功响应:

            //读取html文件,转换为字符串
            BufferedReader br = new BufferedReader(new FileReader("http-demo/html/a.html"));
            StringBuilder data = new StringBuilder();
            String line = null;
            while ((line = br.readLine()) != null){
                data.append(line);
            }
            br.close();
            int length = data.toString().getBytes("GBK").length;

            writer.write("HTTP/1.1 200 OK\r\n");
            writer.write("Connection: keep-alive\r\n");
            writer.write("Content-Type: text/html\r\n");
            writer.write("Content-Length: " + length + "\r\n");
            // 空行标识Header和Body的分隔
            writer.write("\r\n");
            writer.write(data.toString());
            writer.flush();
        }
    }
}

浏览器中输入localhost:8080后按下回车即可看到准备好的html资源

image-20220122213218470

打开开发者工具选择Network即可看到请求头和响应头的详细信息

image-20220122213133989

3、状态码大类

状态码分类说明
1xx响应中——临时状态码,表示请求已经接受,告诉客户端应该继续请求或者如果它已经完成则忽略它
2xx成功——表示请求已经被成功接收,处理已完成
3xx重定向——重定向到其它地方:它让客户端再发起一个请求以完成整个处理。
4xx客户端错误——处理发生错误,责任在客户端,如:客户端的请求一个不存在的资源,客户端未被授权,禁止访问等
5xx服务器端错误——处理发生错误,责任在服务端,如:服务端抛出异常,路由出错,HTTP版本不支持等

状态码大全:https://cloud.tencent.com/developer/chapter/13553

3.1、常见的响应状态码

状态码英文描述解释
200OK客户端请求成功,即处理成功,这是我们最想看到的状态码
302Found指示所请求的资源已移动到由Location响应头给定的 URL,浏览器会自动重新访问到这个页面
304Not Modified告诉客户端,你请求的资源至上次取得后,服务端并未更改,你直接用你本地缓存吧。隐式重定向
400Bad Request客户端请求有语法错误,不能被服务器所理解
403Forbidden服务器收到请求,但是拒绝提供服务,比如:没有权限访问相关资源
404Not Found请求资源不存在,一般是URL输入有误,或者网站资源被删除了
428Precondition Required服务器要求有条件的请求,告诉客户端要想访问该资源,必须携带特定的请求头
429Too Many Requests太多请求,可以限制客户端请求某个资源的数量,配合 Retry-After(多长时间后可以请求)响应头一起使用
431Request Header Fields Too Large请求头太大,服务器不愿意处理请求,因为它的头部字段太大。请求可以在减少请求头域的大小后重新提交。
405Method Not Allowed请求方式有误,比如应该用GET请求方式的资源,用了POST
500Internal Server Error服务器发生不可预期的错误。服务器出异常了,赶紧看日志去吧
503Service Unavailable服务器尚未准备好处理请求,服务器刚刚启动,还未初始化好
511Network Authentication Required客户端需要进行身份验证才能获得网络访问权限

4、Tomat

Tomcat是Apache软件基金会一个核心项目,是一个开源民爱妃的轻量级Web服务器,支持Servlet/JSP少量JavaEE规范。因为Tomcat支持Servlet/JSP规范,所以Tomcat也被称为Web容器、Servlet容器。Servlet需要依赖Tomcat才能运行。

JavaEE为Java企业版(Java Enterprise Edition),指Java企业级开发的技术规范总和,其中包含13项技术规范:JDBC、JNDI、EJB、RMI、JSP、Servlet、XML、JMS、Java IDL、JTS、JTA、JavaMail、JAF。

4.1、下载安装

打开Tomcat官网下的Download界面,选择对应的版本,根据自己个人电脑和系统的情况对tomcat进行下载。官网传送门,这里提供本人使用的Tomcat压缩包- -> 传送门,提取码:6c8p。

image-20220122225850077

值得注意的是Tomcat是绿色版,直接解压即可

  • 为了避免后期部署项目时部署失败,在非中文没有空格的目录下,将下载的压缩包进行解压缩,会得到一个apache-tomcat-版本号的目录,Tomcat就已经安装成功。

  • 打开apache-tomcat-版本号目录就能看到如下的目录结构

image-20220122230855431

bin:目录下有两类文件,一种是以.bat结尾的,是Windows系统的可执行文件,一种是以.sh结尾的,是Linux系统的可执行文件。

webapps:就是以后项目部署的目录

如果有一天忍不住想卸载了,直接将整个文件夹删掉即可。

4.2、配置

打开电脑中系统属性下的环境变量,在系统变量中添加JAVA_HOME变量,变量值为jdk的安装路径。Java环境搭建(JDK1.8)

image-20220122231723398

在系统变量中添加CATALINA_HOME变量,变量值为Tomcat安装路径。

image-20220122232051530

在 Path 环境变量中加入 Tomcat 解压目录\bin 目录,即%CATALINA_HOME%\bin

image-20220122232319535

Tomcat默认的端口是8080,要想修改Tomcat启动的端口号,需要修改 conf/server.xml

与此同时,HTTP协议默认端口号为80,如果将Tomcat端口号改为80,则将来访问Tomcat时,将不用输入端口号。

image-20220122232527509

为了避免控制台打开Tomcat时出现中文乱码,因此需要修改安装目录下的conf下的logging.properties文件,将其中的encoding修改成GBK即可(不出意外的话会在51行)

java.util.logging.ConsoleHandler.encoding = GBK

4.3、启动和关闭

打开解压文件夹下的bin目录我们会发现存在一下两个程序startup.batshutdown.bat,分别对应着正常启动和正常关闭。

image-20220122233707870

但是上面的操作都可以在控制台完成。由于配置了CATALINA_HOME系统变量,我们可以打开控制台,直接输入catalina run,即可实现Tomcat的启动。

image-20220122234040815

在启动了Tomcat之后,如果想关闭Tomcat,可直接按下Ctrl+c即可实现Tomcat的关闭。

这里值得注意的是,直接叉掉控制台程序也能同时关闭Tomcat,但是这属于强制关闭,是不安全的,有可能出现数据丢失的风险。

image-20220122234238304

4.4、部署

Tomcat部署项目: 将项目放置到webapps目录下,即部署完成。

  • 将 编写好的hello.txt文件拷贝到Tomcat的webapps/example目录下
  • 通过浏览器访问http://localhost:8080//examples/hello.txt,能看到下面的内容就说明项目已经部署成功。

image-20220122234958055

5、Maven创建Web项目

5.1、Web项目结构

Web项目的结构分为:开发中的项目和开发完可以部署的Web项目,这两种项目的结构是不一样的,对应的介绍如下:

  • Maven Web项目结构: 开发中的项目

image-20220123111029831

  • 开发完成部署的Web项目

image-20220123111050770

  • 开发项目通过执行Maven打包命令package,可以获取到部署的Web项目目录
  • 编译后的Java字节码文件resources的资源文件,会被放到WEB-INF/classes目录下
  • pom.xml中依赖坐标对应的jar包,会被放入WEB-INF/lib目录下

5.2、使用骨架创建Web项目

具体的步骤如下:

  1. 创建Maven项目

image-20220123112340247

  1. 选择使用Web项目骨架

image-20220123112401608

  1. 输入Maven项目坐标创建项目

image-20220123112424880

  1. 确认Maven相关的配置信息后,完成项目创建

image-20220123112436800

  1. 删除pom.xml中多余内容

image-20220123112614492

  1. 补齐Maven Web项目缺失的目录结构

image-20220123112627875

5.3、不使用骨架创建Web项目

具体的步骤如下:

  1. 创建Maven项目

image-20220123112748340

  1. 选择不使用Web项目骨架

image-20220123112806733

  1. 输入Maven项目坐标创建项目

image-20220123112905693

  1. 在pom.xml设置打包方式为war

image-20220123112948746

  1. 补齐Maven Web项目缺失webapp的目录结构

image-20220123113154810

  1. 补齐Maven Web项目缺失WEB-INF/web.xml的目录结构

image-20220123113411603

  1. 目录补充完毕之后的最终结构如下

image-20220123114039225

6、IDEA中使用Tomcat

Maven Web项目创建成功后,通过Maven的package命令可以将项目打包成war包,将war文件拷贝到Tomcat的webapps目录下,启动Tomcat就可以将项目部署成功,然后通过浏览器进行访问即可。然而我们在开发的过程中,项目中的内容会经常发生变化,如果按照上面这种方式来部署测试,是非常不方便的。

如何在IDEA中能快速使用Tomcat呢?

在IDEA中集成使用Tomcat有两种方式,分别是集成本地Tomcat和Tomcat Maven插件

6.1、集成本地Tomcat

  1. 点击Edit Configurations…

image-20220123114958419

  1. 添加本地Tomcat

image-20220123115049500

  1. 指定本地Tomcat的具体路径

image-20220123115154579

  1. 修改Tomcat的名称,此步骤可以不改,只是让名字看起来更有意义,HTTP port中的端口也可以进行修改,比如把8080改成80

image-20220123115259084

  1. 将开发项目部署项目到Tomcat中。这里值得注意的是有两种不同的后缀选择,两者的介绍如下:
    • war模式是将WEB工程打成war包,把war包发布到Tomcat服务器上
    • war exploded模式是将WEB工程以当前文件夹的位置关系发布到Tomcat服务器上
    • war模式部署成功后,Tomcat的webapps目录下会有部署的项目内容
    • war exploded模式部署成功后,Tomcat的webapps目录下没有,而使用的是项目的target目录下的内容进行部署
    • 建议选war模式进行部署,更符合项目部署的实际情况

image-20220123115428547

  1. 在webapp目录下添加hello.html页面以便更好的看到启动效果

image-20220123115909657

  1. 启动成功后,可以通过浏览器进行访问测试

image-20220123120046754

6.2、Tomcat Maven插件

在IDEA中使用本地Tomcat进行项目部署,相对来说步骤比较繁琐,所以我们需要一种更简便的方式来替换它,那就是直接使用Maven中的Tomcat插件来部署项目,具体的实现步骤,只需要如下的三步:

  1. 在pom.xml中添加Tomcat插件,第一次使用时等待Maven家在完成对应的依赖即可

image-20220123121001913

  1. 打开setting下的plugin,添加Maven helper插件重启IDEA

image-20220123121222171

  1. 使用Maven Helper插件快速启动项目,选中项目,右键–>Run Maven --> tomcat7:run

image-20220123121746190

值得注意的是,Maven Tomcat插件目前只有Tomcat7版本,没有更高的版本可以使用,如果对于Tomcat的版本有比较高的要求,要在Tomcat7以上,这个时候就只能用集成本地Tomcat的方式了。使用Maven Tomcat插件,要想修改Tomcat的端口和访问路径,可以直接修改pom.xml。

<build>
    <plugins>
    	<!--Tomcat插件 -->
        <plugin>
            <groupId>org.apache.tomcat.maven</groupId>
            <artifactId>tomcat7-maven-plugin</artifactId>
            <version>2.2</version>
            <configuration>
                <!--访问端口号 -->
            	<port>80</port>
                <!--项目访问路径
					未配置访问路径: http://localhost:80/tomcat-demo2/a.html
					配置/后访问路径: http://localhost:80/a.html
					如果配置成 /hello,访问路径会变成什么?
						答案: http://localhost:80/hello/a.html
				-->
                <path>/</path>
            </configuration>
        </plugin>
    </plugins>
</build>

image-20220123122350622
2.2


80

/




[外链图片转存中...(img-1xfsQvPo-1642911866459)]
  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-01-24 10:41:48  更:2022-01-24 10:42:38 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 10:01:17-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码