当你在浏览器中输入url之后会发生是什么

整体过程:

浏览器如何解析网址,浏览器会根据网址的含义来生成请求信息,请求消息生成之后,浏览器会委托操作系统Web服务器发送请求(浏览器告诉操作系统接收方的ip地址,这一步需要向DNS服务器将域名转换为ip地址)

  • URL

    Uniform Resource Locator,统一资源定位符

    不只是只有http://开头的才会被称作URL,其实ftp:、file:、mailto等也可以是网址,浏览器是一个具有多种客户端功能的综合性客户端软件,访问web服务器时用"http:",访问FTP服务器时用"ftp:",浏览器以此来判断应该使用哪种功能来访问相应的数据

  • URL的格式

    上一条介绍了url的含义,url的格式会根据协议的不同而不同,现在列举几个常用的格式
    HTTP协议

    http://user:password@www.xxx.com:80/my/hello.html

    user:password绿色的字体 是指的用户名和密码,是可省略的

    @www.xxx.com红色的字体 是指Web服务器的域名

    :80蓝色的字体 是指端口,可以省略,默认是80

    /my/hello.html紫色的字体 是指文件的路径名
    ftp协议

    ftp://user:password@ftp.xxx.com:21/my/file.txt

    user:password绿色的字体 是指的用户名和密码,是可省略的

    @ftp.xxx.com红色的字体 是指FTP服务器的域名

    21蓝色的字体 是指端口,可以省略,默认是21

    /my/file.txt紫色的字体 是指文件的路径名
    读取计算机本地文件

    file://localhost/c:/my/file.txt

    localhost绿色的字体 是指计算机名,是可省略的

    c:/my/file.txt紫色的字体 是指文件的路径名

  • URL解析

    以访问web服务器为例,首先对url进行拆分,拆分为协议+web服务器名称+文件路径

  • HTTP请求消息

    请求消息分为请求行、请求头、请求体三部分组成

    请求行也是由三部分组成的,请求方法、URI、HTTP协议版本,分别用空格隔开

    请求头主要是用于描述请求正文,定义了很多信息,如支持的数据类型、语言、客户端和服务端的软件名称和版本等

    请求头之后空一行是请求体,也就是消息的主体

是不是认为组织完请求之后就会直接访问到该地址了,其实并不是。

相关推荐
serendipity_hky26 分钟前
【SpringCloud | 第5篇】Seata分布式事务
分布式·后端·spring·spring cloud·seata·openfeign
五阿哥永琪41 分钟前
Spring Boot 中自定义线程池的正确使用姿势:定义、注入与最佳实践
spring boot·后端·python
Victor3561 小时前
Netty(16)Netty的零拷贝机制是什么?它如何提高性能?
后端
Victor3561 小时前
Netty(15)Netty的线程模型是什么?它有哪些线程池类型?
后端
canonical_entropy2 小时前
Nop入门:增加DSL模型解析器
spring boot·后端·架构
渣娃-小晴晴2 小时前
java集合在并发环境下应用时的注意事项
java·后端
Jaising6663 小时前
PF4J 日志类冲突与 JVM 类加载机制
jvm·后端
Undoom3 小时前
智能开发环境下的 Diagram-as-Code 实践:MCP Mermaid 技术链路拆解
后端
计算机毕设VX:Fegn08953 小时前
计算机毕业设计|基于springboot + vue图书借阅管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计