How Tomcat Works, A Guide to Developing Your Own Java Servlet Container

1.1 socket网络通信基础

客户端使用主机地址和端口实例化一个socket,此socket通过输出流将字符串等传向服务器主机。

服务器使用端口号实例化一个serverSocket,调用accept()方法监听此端口,等待客户端的连接。一旦连接成功,就可以获取到输入流,将客户端通过网络发送的字符串读取到;也可以获取输出流,将自己的反馈信息发给客户端(客户端获取输入流就可以读到反馈信息)。

ServerSocket serverSocket = new ServerSocket("8080",1,"客户机1");
Socket socket = serverSocket.accept();
input = socket.getInputStream();
// 处理
// ...
output = socket.getOutputStream();

1.2 Http服务器的原理

http服务器就是通过以上介绍的原理来接收HTTP请求的,只是它接收到的是完全按照http协议格式的请求字符串。在服务器被连接(accept())后,就可以获得输入流和输出流,使用它们可以实例化一个请求和一个响应对象。

ServerSocket serverSocket = new ServerSocket("8080",1,"客户机1");
Socket socket = serverSocket.accept();

input = socket.getInputStream();

Request request = new Request(input);

service(request,response);

output = socket.getOutputStream();

Response response = new Response(output);

1.3 Request类

Request类要做的事情就是从输入流中接收字符串,并将一个完全符合http协议的请求字符串分解为一个Request对象。

根据上图,使用indexOf()以及subString()等方法就可以将字符串分解,并将各部分的值封装在Request对象中。

1.4 Response类

Response类需要将响应的字符串按照http响应的格式写到输出流中去。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏你不就像风一样

Tomcat完美配置多个HOST主机,域名,SSL

1383
来自专栏行者悟空

Hadoop之RPC机制

861
来自专栏散尽浮华

nginx负载均衡(5种方式)、rewrite重写规则及多server反代配置梳理

Nginx除了可以用作web服务器外,他还可以用来做高性能的反向代理服务器,它能提供稳定高效的负载均衡解决方案。nginx可以用轮询、IP哈希、URL哈希等方式...

5756
来自专栏大史住在大前端

express中间件系统的基本实现

一直觉得express的中间件系统这种流式处理非常形象,就好像加工流水线一样,每个环节都在针对同一个产品的不同部分完成自己的工作,最后得到一个成品。今天就来实现...

1525
来自专栏JAVA后端开发

vue自动保存表单功能的实现

最近想实现一个表单内容的自动保存,原来是想通过监听表单的change事件来解决.但后面想想,现在都是数据驱动了,监听数据变化就行了. 页面表单如下:

5054
来自专栏轻量级微服务

微服务跨语言 gRPC 之 Java & Python

本文旨在说明 spring-boot-starter-grpc 框架与 Python 之间跨语言 RPC 调用的友好实现。阅读本文前,请详细阅读 wiki文档,...

3931
来自专栏有趣的django

Flask请求扩展和数据库连接池

2540
来自专栏专栏

跨环境测试框架介绍-pytest的高级用法

本文将介绍针对测试和生产等不同测试环境下,维护一套可读性,追溯性强的测试用例的工具-pytest。

1844
来自专栏Golang语言社区

即时通讯软件可以用GO语言实现吗

四个方面特点: 1. 并发支持 对于及时通讯、网络编程等方面,并发支持一定是并不可少的。 goroutine,用户态"线程",大家所说的协程,支持并发操作。已经...

29010
来自专栏coding

Linux命令帮助文档

1192

扫码关注云+社区