码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Nginx基于Basic Auth实现静态资源的访问权限控制


    Nginx基于Basic Auth实现静态资源的访问权限控制

    • 前言
    • 教程
      • nginx安装
      • 修改nginx.conf配置文件
      • 生成密码
    • 常见问题
    • 参考

    前言

    最近遇到一个小项目,有这样一个需求:需要把一些静态资源挂在web容器下提供给对方,毫无疑问,可以用nginx实现,但需要一定的鉴权(账号密码或token)不同的用户能访问的资源是不一样的,因为项目很小,项目金额也有限,肯定是考虑最小的成本实现,因此查找了一些nginx相关的资料。

    教程

    nginx安装

    这里就不说了,百度一大堆,此处省略大约一万字…………

    修改nginx.conf配置文件

    主要是加以下两行

    auth_basic "Please input password"; #提示输入用户名和密码的提示框
    auth_basic_user_file /etc/nginx/conf.d/auth_pwd.auth; #密码文件
    
    • 1
    • 2

    加在server /http /location 都可以,这个看每个人的需求

    生成密码

    1. apache 带的 htpasswd(需要另外安装,具体可以搜索以下)
    2. openssl 自带工具(装有sshd的linux都自带了)推荐

    这里就介绍openssl密码生成方式,如下:

    	openssl passwd 密码明文
    
    • 1

    实操:

    [root@localhost conf.d]# pwd
    /etc/nginx/conf.d
    [root@localhost conf.d]# openssl passwd Sec@123456
    wrg8FUthRnwdQ
    [root@localhost conf.d]# echo -n "test:wrg8FUthRnwdQ" > auth_pwd.auth
    [root@localhost conf.d]# 
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    注:这里的test:wrg8FUthRnwdQ是用户名:生成的密码密文
    
    • 1

    常见问题

    1. auth_basic_user_file 配置的路径不对,nginx不会有报错信息,这点比较难发现,配置的时候要特别留意
    2. Chrome 一次输错密码之后,不会重新弹出对话框了,测试的时候可以使用chrome 无痕窗口,这样每次都会弹出密码输入窗口

    参考

    1.Nginx 官方文档 - Nginx Documentation

    2.Nginx 官方文档 - Module ngx_http_auth_basic_module

    3.victorc666-Nginx配置auth密码鉴权的方法

  • 相关阅读:
    华为云云耀云服务器L实例评测|利用云服务器部署个人博客站
    useRef有什么用?
    Java访问修饰符private、default、protected、public的区别
    Oracel增加IP白名单限制
    数据库使用psql及jdbc进行远程连接,不定时自动断开的解决办法
    CSS布局秘籍(1)-任督二脉BFC/IFC
    Ultra Math Preview : VSCode上的LaTeX公式实时预览插件
    微服务环境搭建
    【ABAP】SAP发送消息至RabbitMQ
    Android 四大组件 -- BroadcastReceiver(广播)
  • 原文地址:https://blog.csdn.net/cjiankai/article/details/127881831
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号