本文共 1769 字,大约阅读时间需要 5 分钟。
首先这是个有危险的动作,刚刚试过修改用户名,发现网上搜索到的方法大部分是有错误的,所以觉得有必要分享出来。 下面讲的是不添加用户的情况下直接修改当前用户的用户名(大部分用户的ubuntu系统只有一个管理员账户,下面讲的就是如何修改这一个用户的名字)。更改用户名之前,需要了解/etc/passwd 、 /etc/shadow 、/etc/group 三个文件,我们要修改这三个文件。 /etc/passwd 文件是一个纯文本文件,每行采用了相同的格式: name:password:uid:gid:comment:home:shell name,用户登录名,我们需要修改的是这个 password,用户口令。此域中的口令是加密的。当用户登录系统时,系统对输入的口令采取相同的算法,与此域中的内容进行比较。如果此域为空,表明该用户登录时不需要口令。 uid,指定用户的 UID。用户登录进系统后,系统通过该值,而不是用户名来识别用户。 gid,GID。如果系统要对相同的一群人赋予相同的权利,则使用该值。 comment,用来保存用户的真实姓名和个人细节。 home指定用户的主目录的绝对路径。 shell如果用户登录成功,则要执行的命令的绝对路径放在这一区域中。它可以是任何命令。 /etc/group 文件文件的格式和 /etc/passwd 文件格式类似,它也是一个纯文本文件,定义了每个组中的用户。每行的格式是: group_name:passwd:GID:user_list 它们的含义如下: group_name组名 password组口令。此域中的口令是加密的。如果此域为空,表明该组不需要口令。 gid指定 GID。 user_list该组的所有用户,用户名之间用逗号隔开。 与上面两个不同,Linux /etc/shadow文件是只有系统管理员才有权利进行查看和修改的文件。 Linux /etc/shadow文件中的记录行与/etc/passwd中的一一对应,它由pwconv命令根据/etc/passwd中的数据自动产生。它的文件格式与/etc/passwd类似,由若干个字段组成,字段之间用“:”隔开。这些字段是: 登录名:加密口令:最后一次修改时间:最小时间间隔:最大时间间隔:警告时间:不活动时间:失效时间:标志 1)“登录名”是与/etc/passwd文件中的登录名相一致的用户账号 2)“口令”字段存放的是加密后的用户口令字,长度为13个字符。如果为空,则对应用户没有口令,登录时不需要口 令;如果含有不属于集合{./0-9A-Za-z}中的字符,则对应的用户不能登录。 3)“最后一次修改时间”表示的是从某个时刻起,到用户最后一次修改口令时的天数。时间起点对不同的系统可能不一样。例如在SCOLinux中,这个时间起点是1970年1月1日。 4)“最小时间间隔”指的是两次修改口令之间所需的最小天数。 5)“最大时间间隔”指的是口令保持有效的最大天数。 6)“警告时间”字段表示的是从系统开始警告用户到用户密码正式失效之间的天数。 7)“不活动时间”表示的是用户没有登录活动但账号仍能保持有效的最大天数。 8)“失效时间”字段给出的是一个绝对的天数,如果使用了这个字段,那么就给出相应账号的生存期。期满后,该账号就不再是一个合法的账号,也就不能再用来登录了。 下面是修改办法: 注意:用户名不能使用不合法的字符,具体怎样才能合法还没查清楚,目前知道全小写字母肯定可以,首字母不能是大写! 1)打开一个终端,输入 sudo su转为root用户。 注意,必须先转为root用户!!! 2)gedit /etc/passwd ,找到代表你的那一行,修改用户名为新的用户名。 注意:只修改用户名!后面的全名、目录等不要动! 3)gedit /etc/shadow,找到代表你的那一行,修改用户名为新用户名 4)gedit /etc/group,你应该发现你的用户名在很多个组中,全部修改! 完毕,修改的时候要格外小心,不要打错一个字母。修改完,保存,重启。 修改用户目录名的方法请查询usermod命令的使用方法 转载于:https://my.oschina.net/arvinjones/blog/139480