Ubuntu更改用户名及相应的用户主目录

来源:互联网 发布:淘宝班龙音响是假的吗 编辑:程序博客网 时间:2024/06/04 19:07

某天突然感觉用了一阵子的用户名不爽,想换个名字新鲜新鲜,不过最好不要简单的编辑/etc/passwd和/etc/group了事,

linux有相应的命令来做这些dirty things。最好不要在当前用户下操作,去recovery模式下做这件事比较妥当。

  1、修改用户名。
  usermod -l new_username -d /home/new_username -m old_username
用usermod命令来修改用户帐户相关信息,-l指定新的登录名称,-d指定新的主目录,

如果同时指定-m选项则移动原来用户主目录的内容到新的用户住目录,最后指定原来的登录用户名。

  2、修改组名
  groupmod -n new_username old_username
groupmod命令用来修改组相关信息,-n用来指定新的组名,用原来的组名作为参数。这里修改的是与用户默认同名的组。
  3、更改用户的全称
  chfn -f new_fullname username
chfn命令来修改真实的用户名称和其他相关信息,-f指定新的用户全称,需要修改全称的用户名作为参数,  

全称即为开机登录时显示的用户名
  4、其他修改
更改用户主目录后,有些依赖于绝对路径的程序需要进行相应的修改。

firefox profile路径下的extensions.ini里面的有依赖于用户名的绝对路径,修改之,用vim打开,

然后:%s/old_username/new_username/g,然后:wq即可,prefs.js里面做同样的处理,firefox就可以正常使用了。

其他的东西基本不用动就可以了。

***************************************以下为直接修改/etc/passwd和/etc/group  /etc/shadow*******************************************

首先这是个有危险的动作,刚刚试过修改用户名,发现网上搜索到的方法大部分是有错误的,所以觉得有必要分享出来。 

下面讲的是不添加用户的情况下直接修改当前用户的用户名(大部分用户的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命令的使用方法


0 0