Linux用nginx配置登录认证

在Linux系统中,使用Nginx配置登录认证可以通过以下步骤实现:

Linux用nginx配置登录认证
(图片来源网络,侵删)

1、安装Nginx和相关模块

首先确保已经安装了Nginx,如果没有安装,可以使用以下命令进行安装:

sudo aptget update
sudo aptget install nginx

接下来,需要安装http_auth_request_module模块,该模块用于处理HTTP基本认证,在编译Nginx时,需要添加withhttp_auth_request_module选项:

sudo aptget install libpcre3dev libssldev
wget http://nginx.org/download/nginx1.20.1.tar.gz
tar zxvf nginx1.20.1.tar.gz
cd nginx1.20.1
./configure withhttp_auth_request_module
make
sudo make install

2、配置Nginx

编辑Nginx配置文件,通常位于/etc/nginx/nginx.conf/etc/nginx/sitesavailable/default,在server块中添加以下内容:

location / {
    auth_request /auth;
    proxy_pass http://backend;
}
location = /auth {
    internal;
    proxy_pass http://authentication;
}

这里,/auth是用于处理认证请求的路径,authentication是用于验证用户名和密码的服务地址。

3、创建认证服务

创建一个名为authentication的文件夹,用于存放认证服务的脚本,在该文件夹中创建一个名为auth.sh的脚本文件,并添加以下内容:

#!/bin/bash
获取客户端发送的用户名和密码
user=$(echo $REDIRECT_REMOTE_USER | base64 d)
password=$(echo $REDIRECT_REMOTE_PASSWORD | base64 d)
验证用户名和密码是否正确
if [ "$user" == "your_username" ] && [ "$password" == "your_password" ]; then
    echo "OK"
else
    echo "Invalid credentials"
fi

your_usernameyour_password替换为实际的用户名和密码。

4、设置脚本权限

auth.sh脚本添加可执行权限:

chmod +x auth.sh

5、重启Nginx

重启Nginx以应用更改:

sudo service nginx restart

现在,当访问受保护的路径时,浏览器会弹出一个登录窗口,要求输入用户名和密码,如果输入正确的用户名和密码,将允许访问;否则,将拒绝访问。

原创文章,作者:未希,如若转载,请注明出处:https://www.kdun.com/ask/669300.html

本网站发布或转载的文章及图片均来自网络,其原创性以及文中表达的观点和判断不代表本网站。如有问题,请联系客服处理。

(0)
未希新媒体运营
上一篇 2024-06-01 00:23
下一篇 2024-06-01 00:33

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注

产品购买 QQ咨询 微信咨询 SEO优化
分享本页
返回顶部
云产品限时秒杀。精选云产品高防服务器,20M大带宽限量抢购 >>点击进入