曲径通幽论坛

 找回密码
 立即注册
搜索
查看: 5598|回复: 0
打印 上一主题 下一主题

[系统应用] 允许非 root 用户登录到 LUCI 进行配置

[复制链接]

4917

主题

5879

帖子

3万

积分

GROAD

曲径通幽,安觅芳踪。

Rank: 6Rank: 6

积分
34382
跳转到指定楼层
楼主
发表于 2015-2-17 21:55:19 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
有些时候,可能需要使用非 root 用户登录到 LUCI 进行配置,而不是用 root,这个可能是出于 linux 使用者的习惯,或者出于某些安全的需要。
我的路由器是 AR71XX 平台的,使用了 BB 14.07 ,下面的方法不保证全部平台及各版本的 Openwrt 都适用,但至少大部分确实可行的。
1. 首先,创建一个非 root 用户并赋其密码比如:
  1. opkg update
  2. opkg install shadow-useradd
  3. useradd beyes
  4. passwd beyes
复制代码

2. 编辑 /etc/passwd 文件,对该新建的用户添加到 root 用户组,并且设置不可以登录到 shell,比如:
beyes:x:1000:0:beyes:/home/beyes:/bin/false

还有一种办法,在给 beyes 这个用户创建密码时,可以先编辑  /etc/shadow 文件,方法是复制 root 的那行信息出来,然后改名为 beyes,接着再 passwd 给 beyes 添加密码。
3. 编辑相关的 lua 文件
/usr/lib/lua/luci/controller/admin/index.lua 中找到 :
page.sysauth = "root"

将其改为:
page.sysauth = {"beyes","root"}

在 /usr/lib/lua/luci/controller/admin/system.lua 中找到:
stat = luci.sys.user.setpasswd("root", p1)

将其中的 root 改为 beyes,你起什么名字,则相应改之。这一步很重要,否则 LUCI 会允许你用这个新建的用户修改了 root 的密码(在 system->administration 这里操作)。
在 /usr/lib/lua/luci/controller/admin/servicectl.lua 中找到:
entry({"servicectl"}, alias("servicectl", "status")).sysauth = "root"

改为:
entry({"servicectl"}, alias("servicectl", "status")).sysauth = {"beyes","root"}

这么做则允许 LUCI 可以保存并且激活所做的设置。
现在,你可以用新建的用户来登录 LUCI 并进行配置了,但该用户没有登录到 shell 的权限。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|曲径通幽 ( 琼ICP备11001422号-1|公安备案:46900502000207 )

GMT+8, 2024-5-2 12:52 , Processed in 0.061300 second(s), 22 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表