重磅!基于Lua的命令行远程打包系统(五)

上一节,亿元程序员为我们简单介绍了基于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 == nil  then
		if msg ~= "timeout
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

亿元程序员

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值