实验环境:
接nginx(2),server2、3的http服务打开
一、重定向
这里实验结果有问题。
(1)域名保护
防止域名恶意解析到服务器IP,为了安全不想让客户端直接以ip形式访问
以下是未加入域名保护时,客户curl服务器的结果
data:image/s3,"s3://crabby-images/b95c6/b95c6dc3706e925c875058f12fb179c1a898a883" alt=""
配置文件? 加入return 500;
?nginx -s reload
此时curl的结果为
data:image/s3,"s3://crabby-images/1df73/1df739b64e36b6d69a43221ed9a6b6b9f1f49447" alt=""
?(2)重定向:80重定向443
? 配置文件加入 ??? rewrite ^/(.*)$ https://www.westos.org permanent;
data:image/s3,"s3://crabby-images/2fafd/2fafd1bfd960e22aa34a6a2887e2e47433bbe47e" alt=""
?客户端curl www.westos.org
这里客户端一定要有解析!
?data:image/s3,"s3://crabby-images/25a50/25a5036ad988848478ebcb4b97405f4f87accec9" alt=""
?data:image/s3,"s3://crabby-images/e18a2/e18a2dc5b33a91e32ea3094c0b09b95d904c6747" alt=""
?若配置文件改为rewrite ^/(.*)$ https://www.westos.org/$1 permanent;
表示在网页中用户鼠标点击后的页面进行重定向
data:image/s3,"s3://crabby-images/57e33/57e33baa95b548f130bc3b8959e2998e56baa79e" alt=""
(3)网站的整体迁移
?比如某个网站A需要维护但是不能停止服务,那么用临时网站C代替,用户访问A时自动跳到C
配置文件底部新加一个虚拟主机,并新建相应文件
?? server { ????????????? listen 80; ???????????? server_name bbs.westos.org;
???????????? location / { ????????????????? root /bbs; ????????????????? index index.html; ??????????????? } ?????? }
data:image/s3,"s3://crabby-images/06363/063635237cc3c539de4f76b23f553593181a6124" alt=""
?此时客户端 curl bbs.westos.org
可以看到新页面,但要注意我们更想要另一种效果
data:image/s3,"s3://crabby-images/95c80/95c80c0efb409e20a10c5fb0bf186980db687a8b" alt=""
配置文件新增rewrite ^/bbs$ http://bbs.westos.org permanent;
data:image/s3,"s3://crabby-images/0d455/0d4557e18c07d43d74c0a8e609e2a96768a084eb" alt=""
客户端测试:?? 效果如下
curl www.westos.org/bbs curl www.westos.org curl www.westos.org/bbs -I?
data:image/s3,"s3://crabby-images/14c14/14c14d7cf24017259c55c4735c346a026f45f89f" alt=""
?但是这里出现一个问题,curl www.westos.org/bbs/index.html -I
出现404的情况,也就是说不能继续往下重定向
data:image/s3,"s3://crabby-images/731b2/731b2deeaf4685c504ea027b9ec6d9123518da9b" alt=""
解决办法:配置文件取消注释
? rewrite ^/bbs/(.*)$ http://bbs.westos.org/$1 permanent;
data:image/s3,"s3://crabby-images/11ffa/11ffad547f937c2ed639c6d1e9860959050f1b20" alt=""
?再次测试 ? ? ? curl www.westos.org/bbs/index.html -I,成功
data:image/s3,"s3://crabby-images/10a83/10a83959d39ab7492fe4fc0852b02f9fb4b5f50c" alt=""
?(4)基于if语句的网站迁移
通过一条if语句,用一个服务器实现重定向
配置文件需要把上边定义的服务器注销
data:image/s3,"s3://crabby-images/93bd6/93bd6124e7ff3d8c3eb14dff34ceae166c9c65ec" alt=""
?原有server上,注销旧策略,加入if判断
???????????? if ($host = "bbs.westos.org"){ ?????????????????? rewrite ^/(.*)$ http://www.westos.org/bbs/$1 permanent; ?????????????? }
???????????? location / { ???????????????? # proxy_pass http://westos; ?????????????????? root html; ?????????????????? index index.html;
data:image/s3,"s3://crabby-images/63f68/63f681a57d5e3c92b46fe91d172ce103af3838d9" alt=""
将bbs目录拷贝到
nginx -s reload
?data:image/s3,"s3://crabby-images/e3e2b/e3e2b6eda0dcdeca68e777f72dc9dad896fd31df" alt=""
?主机测试
data:image/s3,"s3://crabby-images/a77d3/a77d3f3d8f0c715346d9eec1ab6d7343cc3251b4" alt=""
?二、防盗链
(1)简单的盗链方式
server2:新建haha.html,内容如下
<html> <body>
<img src='http://172.25.73.1/download/haha.jpg'/>
</body> </html>
浏览器 http://172.25.73.2/haha.html出现下图?
要注意的是,文件中仅添加了一个地址,也就是说这个页面并不耗费server2的流量,而是耗费的 http://172.25.73.1/download/haha.jpg的流量,所以这种行为非常不道德,要防止盗链。
data:image/s3,"s3://crabby-images/a2f6f/a2f6f271ae33a3a5e22f773198e175eab8fdeb41" alt=""
(2)防盗链
?1、遇到盗链情况,让他返回值是403
配置文件修改:
??????? location ~ \.(jpg|png)$ { ??????????????? valid_referers none blocked www.westos.org; ??????????????? if ($invalid_referer) { ??????????????????????? return 403;? 返回403 ??????????????????????? #rewrite ^/ http://www2.westos.org/daolian.jpg;?? 连接到另一个图 ?????? } ????? }
data:image/s3,"s3://crabby-images/925ef/925efff03f9e7a4e062cf97b45ca65d6aa40fb95" alt=""
?这里和重定向有关系,没有出来效果
|