上一节,亿元程序员为我们简单介绍了基于Lua的命令行远程打包系统的后端接收指令并执行指令的方法,当我们的系统可以给不同的角色使用时,我们需要建立一套用户以及权限的管理方法,用户需要有账号和密码才可以使用系统,用户需要有对应指令的权限才可以使用相应的指令,这一篇文章我们将讲解服务端如何对使用的角色进行用户名和密码的匹配校验以及对不同的用户授予不同指令的使用权限。下面我们跟随着亿元程序员一起来看看。
用户的身份验证和指令权限
1.创建一个管理用户名和密码的table。
Passwd = {
YiyuanCoder = "123456",
user1 = "123456",
user2 = "123456"
}
2.创建一个管理用户使用指令的权限table。
Authz = {
test1 = {"YiyuanCoder"},
test2 = {"user1","user2"},
}
3.用户登陆的校验方法如下。
function Login(username,password)
return username ~= nil and password ~= nil and Passwd[username] == password
end
4.用户是否有权限使用指令的校验如下。
function HasAuthz(username,cmd)
if username ~= nil and cmd ~= nil then
if Authz[cmd] == nil then
return true
end
for i=1,#Authz[cmd] do
if Authz[cmd][i] == username then
return true
end
end
end
return false
end
5.server.lua的改造加入用户登陆校验以及指令权限校验。
引入Properties模块
require("Common/Properties")
用户登陆校验
local function process_accept()
local client,msg = server:accept()
if client