Rumah >Operasi dan penyelenggaraan >Nginx >Cara menggunakan Nginx untuk melaksanakan kawalan akses berasaskan peranan pengguna

Cara menggunakan Nginx untuk melaksanakan kawalan akses berasaskan peranan pengguna

WBOY
WBOYasal
2023-08-04 14:36:171037semak imbas

Cara menggunakan Nginx untuk melaksanakan kawalan akses berasaskan peranan pengguna

Pengenalan:
Dalam aplikasi rangkaian moden, kawalan akses ialah keperluan keselamatan yang sangat penting. Banyak aplikasi memerlukan kawalan peranan dan kebenaran ke atas akses pengguna untuk memastikan pengguna yang berbeza hanya boleh mengakses kandungan yang mereka mempunyai kebenaran. Nginx ialah pelayan web berprestasi tinggi dan pelayan proksi terbalik yang bukan sahaja boleh mengendalikan perkhidmatan fail statik, tetapi juga melaksanakan kawalan kebenaran asas melalui beberapa ciri. Artikel ini akan memperkenalkan cara menggunakan Nginx untuk melaksanakan kawalan akses berasaskan peranan pengguna dan memberikan contoh kod.

1. Konfigurasi asas Nginx
Pertama, kita perlu menetapkan maklumat asas dan peraturan kawalan akses dalam fail konfigurasi Nginx. Buka fail konfigurasi Nginx (biasanya /etc/nginx/nginx.conf), cari blok http, dan tambah kandungan berikut di dalamnya:

http {
    ...
    # 用户角色配置文件路径
    include /etc/nginx/user_roles.conf;

    # 默认拒绝访问
    location / {
        deny all;
    }

    # 静态文件服务
    location /static/ {
        alias /path/to/static/files/;
    }

    # 动态请求代理
    location /dynamic/ {
        proxy_pass http://localhost:8000;
        # 其他proxy相关配置
    }
}

Dalam konfigurasi di atas, kami menetapkan peraturan penafian akses lalai dan mengkonfigurasi Fail statik penyampaian dan proksi permintaan dinamik. Seterusnya, kami mencipta fail user_roles.conf khusus untuk konfigurasi peranan pengguna Cipta fail dalam direktori /etc/nginx/ dan tambah kandungan berikut:

user john: editor;
user alice: admin;

Dalam fail konfigurasi ini, kami mentakrifkan dua pengguna john dan alice, dan mereka. peranan yang sepadan. Peranan ini akan digunakan untuk keputusan kawalan akses.

2. Kawalan akses berdasarkan peranan pengguna
Nginx menyediakan beberapa pembolehubah dan arahan yang boleh digunakan untuk mengawal akses berdasarkan peranan pengguna.

  1. Gunakan pembolehubah untuk kawalan akses
    Nginx menyediakan pembolehubah $remote_user, yang mengandungi nama pengguna pengguna (diperolehi melalui pengesahan asas HTTP). Kita boleh melaksanakan kawalan capaian berdasarkan peranan pengguna dengan menilai nilai pembolehubah ini. Sebagai contoh, kita boleh menggunakan arahan if untuk melaksanakan peraturan kawalan akses berikut:
location /admin/ {
    if ($remote_user != "alice") {
        return 403;
    }
    # 其他配置指令
}

Dalam contoh ini, jika nama pengguna pengguna bukan alice, Nginx akan mengembalikan halaman ralat 403 dan menafikan akses kepada kandungan di bawah /admin / laluan.

  1. Gunakan skrip Lua untuk kawalan akses
    Nginx juga menyokong pembenaman skrip Lua untuk pertimbangan kawalan akses yang lebih kompleks. Kita boleh menulis skrip Lua untuk membaca fail user_roles.conf dan melaksanakan kawalan akses berdasarkan peranan pengguna. Berikut ialah contoh skrip Lua:
location /editor/ {
    access_by_lua_block {
        local roles_file = "/etc/nginx/user_roles.conf"
        local file = io.open(roles_file, "r")
        local roles = file:read("*a")
        file:close()
        
        local current_user = ngx.var.remote_user
        local role = string.match(roles, current_user .. ": (%a+);")
        
        if role ~= "editor" then
            ngx.exit(ngx.HTTP_FORBIDDEN)
        end
    }
    # 其他配置指令
}

Dalam contoh ini, kami membaca fail user_roles.conf dan memadankan peranan pengguna semasa menggunakan ungkapan biasa. Jika peranan pengguna semasa bukan editor, Nginx akan mengembalikan halaman ralat 403 dan menafikan akses kepada kandungan di bawah laluan /editor/.

Kesimpulan:
Melalui konfigurasi Nginx dan beberapa ciri, kami boleh melaksanakan kawalan akses berdasarkan peranan pengguna. Artikel ini menyediakan contoh kod asas untuk rujukan dan kegunaan pembaca. Sudah tentu, ini hanyalah kaedah pelaksanaan asas Dalam aplikasi sebenar, langkah keselamatan lain mungkin perlu digabungkan, seperti sijil SSL dan tembok api, untuk memastikan keselamatan sistem.

Rujukan:

  1. Dokumentasi Nginx: https://nginx.org/en/docs/
  2. OpenResty Dokumentasi Modul Nginx Lua: https://github.com/openresty/lua-nginx-module

Atas ialah kandungan terperinci Cara menggunakan Nginx untuk melaksanakan kawalan akses berasaskan peranan pengguna. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn