一篇文章详解请求头Host的概念

我们知道Http请求头信息里面会带有一个Host字段,很多人不是很清楚这个字段具体的作用或者用法,包括我被很多人问过也曾经有些迷茫,这里具体扫盲下。

我们知道一个IP地址可以对应多个域名,比如假设我有这么几个域名www.qiniu.com,www.taobao.com和www.jd.com然后在域名提供商那通过A记录或者CNAME记录的方式最终都和我的虚拟机服务器IP 111.111.111.111关联起来,那么我通过任何一个域名去访问最终解析到的都是IP 111.111.111.111。

但是还是没有提到Host的概念,其实可以这样看,我们的那台虚拟机111.111.111.111上面其实是可以放很很多网站的(不然如果只能放一个网站的话就太不合理了,虚拟机那么多资源都浪费了),我们可以把www.qiniu.com,www.taobao.com和www.jd.com这些网站都假设那台虚拟机上面,但是这样会有一个问题,我们每次访问这些域名其实都是解析到服务器IP 111.111.111.111,我怎么来区分每次根据域名显示出不同的网站的内容呢,其实这就要用到请求头中Host的概念了,每个Host可以看做是我在服务器111.111.111.111上面的一个站点,每次我用那些域名访问的时候都是会解析同一个虚拟机没错,但是我通过不同的Host可以区分出我是访问这个虚拟机上的哪个站点。

上面讲了这些如果还不能明白的话,我这里再举一个具体的Tomcat搭建网站站点的例子来说明这些Host具体在实际中是怎样设置的,我这里直接给出截图,因为只要是用Tomcat搭建过网站的应该都清楚,我直接在Tomcat目录中创建3个子目录来放我上面的3个站点就可以了,然后把具体的代码放到各个目录下面:
这里写图片描述
现在就需要我们来设置相关Host了,其实也比较简单,只需要编辑conf目录下的server.xml就可以了, 这里直接给出代码,可以看到其实是加了3个Host然后关联到以上3个目录下就可以了。
Host name="www.qiniu.com" appBase="qiniuwebapp"
Host name="www.taobao.com" appBase="taobaowebapp"
<Host name="www.jb.com" appBase="jbwebapp"

<Engine name="Catalina" defaultHost="www.qiniu.com">
      <Realm className="org.apache.catalina.realm.UserDatabaseRealm"
             resourceName="UserDatabase"/>

       <Host name="www.qiniu.com" appBase="qiniuwebapp"  unpackWARs="true" autoDeploy="true" >     
	       <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
               prefix="qiniuwebapp_access_log." suffix=".txt"
               pattern="%h %l %u %t "%r" %s %b" />
       </Host>
      <Host name="www.taobao.com" appBase="taobaowebapp"  unpackWARs="true" autoDeploy="true" >
		    <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
               prefix="taobaowebapp_access_log." suffix=".txt"
               pattern="%h %l %u %t "%r" %s %b" />
	 </Host> 
	 <Host name="www.jb.com" appBase="jbwebapp"  unpackWARs="true" autoDeploy="true" >
		    <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
               prefix="jbwebapp_access_log." suffix=".txt"
               pattern="%h %l %u %t "%r" %s %b" />
	 </Host> 
 </Engine>

然后每次访问都会根据不同的Host的信息请求到不同的站点上面。

  • 29
    点赞
  • 57
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
在使用axios发送网络请求时,可以通过headers配置参数来自定义请求头。以下是常用的请求头配置: 1. `Content-Type`:设置请求体数据格式,常见的有`application/json`、`application/x-www-form-urlencoded`、`multipart/form-data`等,其中`application/json`表示请求体数据为JSON格式,`application/x-www-form-urlencoded`表示请求体数据为URL编码格式。 2. `Authorization`:设置请求的认证信息,常见的有`Bearer token`、`Basic username:password`等,其中`Bearer token`表示使用JWT(JSON Web Token)方式进行认证,`Basic username:password`表示使用HTTP基本认证方式进行认证。 3. `Accept`:设置请求期望的响应数据格式,常见的有`application/json`、`text/html`、`text/plain`等,其中`application/json`表示期望响应数据为JSON格式,`text/html`表示期望响应数据为HTML格式。 4. `User-Agent`:设置客户端标识,常见的有`Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.36`等,其中`Mozilla`表示浏览器类型,`Windows NT 10.0`表示操作系统类型,`Chrome/58.0.3029.110`表示浏览器版本号。 以下是一个完整的axios请求示例,包括请求头的配置: ``` import axios from 'axios'; axios.defaults.baseURL = 'http://example.com/api'; axios.defaults.headers.common['Authorization'] = 'Bearer token'; axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded'; axios.post('/login', { username: 'admin', password: 'password' }).then(response => { console.log(response.data); }).catch(error => { console.error(error); }); ``` 在以上示例中,我们设置了请求的基础URL为'http://example.com/api',并在请求头中添加了一个名为'Authorization'的字段,其值为'token',还设置了POST请求的请求体数据格式为URL编码格式。我们发送了一个POST请求,请求体数据为一个包含用户名和密码的对象,最后我们使用了Promise的方式处理了请求的响应和错误。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值