URL中绝对路径与相对路径拼接问题总结

URL中绝对路径与相对路径拼接问题总结

1. 基础环境

这里用nginxdocker镜像构建了一个服务,步骤如下:

  • sudo docker pull nginx
  • sudo docker run -d --name nginx01 -p 8083:80 nginx

nginx发布的根目录是/usr/share/nginx/html,目录结构如下:

.
|-- 50x.html
|-- assets
|   `-- images
|       |-- t1.png
|       `-- t2.jpg
|-- index.html
`-- subpage
    `-- sub.html

2. 测试

请求的urlhttp://192.168.136.167:8083/subpage/sub.htmlhtml的测试数据如下:

  • <img src="./assets/images/t2.jpg" alt="测试以.开头" style="width:50px;height:60px;">
  • <img src="../assets/images/t1.png" alt="测试以开头" style="width:50px;height:60px;">
  • <img src="/assets/images/t2.jpg" alt="测试以/开头" style="width:50px;height:60px;">
  • <img src="//assets/images/t2.jpg" alt="测试以//开头" style="width:50px;height:60px;">

请求时的最终拼接后的url:

  • http://192.168.136.167:8083/subpage/assets/images/t2.jpg
  • http://192.168.136.167:8083/assets/images/t1.png
  • http://192.168.136.167:8083/assets/images/t2.jpg
  • http://assets/images/t2.png

界面最终的显示结果:
在这里插入图片描述

2.1 总结

  • ...目录或文件名 开头的路径,拼接时会以url地址栏的当前目录路径与该路径拼接
  • / 开头的路径,拼接时会以url地址栏的协议及域名与该路径拼接
  • // 开头的路径,拼接时会以url地址栏中的协议与该路径拼接

url地址栏中目录路径与文件路径区分:

  • url地址栏中路径以/结尾表示目录路径,如http://localhost:8083/abc/,此时abc就表示目录
  • url地址栏中路径不以/结尾表示文件路径,如http://localhost:8083/abc,此时abc就表示文件

2.2 本地文件url

打开本地文件时url格式如下:

  • file:///D:/readme.html
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值