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

[经验分享] nginx登录账户认证

[复制链接]
累计签到:224 天
连续签到:4 天
发表于 2019-8-4 18:10:26 | 显示全部楼层 |阅读模式
概述
  Basic和Digest身份验证是Web应用程序中常用的备用身份验证机制,基本身份验证通常与无状态客户端一起使用,后者在每个请求上传递其凭据.将它与基于表单的身份验证结合使用是很常见的,其中应用程序通过基于浏览器的用户界面和作为Web服务使用.但是,基本身份验证将密码作为纯文本传输,因此建议只在加密传输层(如HTTPS)上使用
Basic Authentication
Basic Authentication负责处理HTTP标头中显示的基本身份验证凭据,这可以用于验证Spring远程协议(例如Hessian和Burlap)以及普通浏览器用户代理(例如Firefox和Internet Explorer)进行的调用
配置
  • 之前的文章中有详细提说过http认证HTTP Authentication,包括用户认证信息的生成机制,存放方式等
  • 此处依然是使用简单的htpasswd工具生成用户认证信息,并使用文本文件进行存储
  • 生成用户认证信息,添加一个用户名为obama的账号,并两次输入密码,再继续添加第二个用户是不要在使用-c选项
htpasswd -c -m htpasswd obamaNew password:Re-type new password:Adding password for user obamahtpasswd -m htpasswd trumpNew password:Re-type new password:Adding password for user trump
  • 配置文件中对需要进行认证的域进行配置
location /president {     auth_basic "This is for president";     auth_basic_user_file /app/ngx/ssl/htpasswd; }DigestAuthentication
Digest Authentication能够处理HTTP标头中提供的摘要认证凭证.摘要式身份验证尝试解决基本身份验证的许多弱点,特别是通过确保永远不会通过网络以明文形式发送凭据,但是兼容性较差
Digest Authenticaton EntryPoint具有指定key用于生成随机数令牌的nonceValiditySeconds属性,以及用于确定到期时间的属性(默认值300,等于五分钟).Whist永远是nonce有效,摘要是通过连接各种字符串计算的,包括用户名,密码,nonce,请求的URI,客户端生成的nonce(只是用户代理生成每个请求的随机值),领域名称等,然后执行MD5哈希。
服务器和用户代理都执行此摘要计算,如果它们在包含的值(例如密码)上不一致,则会产生不同的哈希码
配置
  • 遗憾的是,nginx官方没有提供此模块,也没用收入第三方模块,只能自己开发或者使用别人开发的编译进去,此处推荐一个nginx-http-auth-digest
  • 将其编译进去即可
./configure --prefix=/app/ngx ... \--add-dynamic-module=/app/software/nginx-http-auth-digest...
  • 生成用户认证信息
[root@ngx-1 ssl]# htdigest -c digesthtpass "president" trumpAdding password for trump in realm president.New password:Re-type new password:
  • 配置文件中对需要进行认证的域进行配置
auth_digest_user_file /app/ngx/ssl/digesthtpass;auth_digest_shm_size 4m;    location /president {    auth_digest "president";    auth_digest_timeout 60s;    auth_digest_expires 10s;    auth_digest_replays 20;}

运维网声明 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.yunweiku.com/thread-974246-1-1.html 上篇帖子: 网站必须要登录访问,nginx+tomcat要如何实现动静分离呢 下篇帖子: 查看nginx cache命中率
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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