设为首页 收藏本站
查看: 913|回复: 0

[经验分享] Nginx用户认证与域名重定向

[复制链接]

尚未签到

发表于 2018-11-9 11:03:38 | 显示全部楼层 |阅读模式
  笔记内容:


  • 12.8 Nginx用户认证
  • 12.9 Nginx域名重定向
  笔记日期:2017.10.19
  

12.8 Nginx用户认证


  创建虚拟主机配置文件:

  vim /usr/local/nginx/conf/vhost/test.com.conf

  文件内容如下:
  

server  
{
  listen 80;
  server_name test.com;
  index index.html index.htm index.php;
  root /data/wwwroot/test.com;
  

  
location  /
  {
  auth_basic              "Auth";  //定义用户认证的名称
  auth_basic_user_file   /usr/local/nginx/conf/htpasswd;  //用户名和密码文件的路径
  }
  
}
  


  创建test.com目录:

  mkdir /data/wwwroot/test.com

  创建一个索引页文件:

  echo "test.com" > /data/wwwroot/test.com/index.html

  安装httpd:

  yum install -y httpd

  然后使用httpd里的htpasswd 命令去生成一个用户密码文件:

  htpasswd -c /usr/local/nginx/conf/htpasswd user1

  生成完成后cat一下htpasswd 文件可以看到如下内容:

  如果再次添加用户的话就不需要加上-c选项了,加上-c选项会覆盖原来的htpasswd 文件。
  生成完用户密码文件之后,就重新加载配置文件:

  /usr/local/nginx/sbin/nginx -t

  /usr/local/nginx/sbin/nginx -s>
  使用curl命令测试一下是否配置成功,状态码为401代表成功:

  然后使用-u指定用户名和密码去访问,状态码为200代表成功:

  以上我们配置的是整个站点的用户认证,但是如果不需要整个站点都要用户认证,只有单独的某个站点下的目录需要进行用户认证,那么如何配置?
  示例:
  例如我要指定对admin目录进行用户认证,修改虚拟主机配置文件如以下内容即可:

  现在访问test.com就不会需要进行用户认证了,可以看到状态码为200:

  但是访问test.com下的admin目录就会需要进行用户认证了,可以看到状态码为401:

  这时候就需要指定用户名和密码才能访问这个目录了。
  
  除了控制目录外,还可以控制目录下的文件,例如我要控制访问admin.php文件时需要进行用户认证,修改虚拟主机配置文件如以下内容:

  ~ 表示根,表示整个站点
  这时候使用curl访问admin目录下的admin.php文件时就需要进行用户认证了,可以看到状态码为401:

  

12.9 Nginx域名重定向

  修改配置文件为以下内容:
  

server  
{
  listen 80;
  server_name test.com test1.com test2.com;
  index index.html index.htm index.php;
  root /data/wwwroot/test.com;
  if ($host != 'test.com' ) {
  rewrite  ^/(.*)$  http://test.com/$1  permanent;
  }
  
}
  


  重新加载配置文件:

  使用curl访问test2.com,状态码为301,并且重定向的目标域名是test.com就代表成功了:

  

扩展
  nginx.conf 配置详解
  http://www.ha97.com/5194.html
  http://my.oschina.net/duxuefeng/blog/34880
  
  nginx rewrite四种flag
  http://www.netingcn.com/nginx-rewrite-flag.html
  http://unixman.blog.51cto.com/10163040/1711943



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-632776-1-1.html 上篇帖子: nginx+tomcat 动静分离 的配置文件 下篇帖子: nginx网站502与504错误分析
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表