hosts.equiv和.rhosts文件详解
远程用户启动rlogin访问你的本地主机,此时做如下安全性检查:
-
- 本地
rlogind
在本地/etc/passwd
文件中寻找远程用户名,没有则拒绝访问
- 本地
-
/etc/passwd
中存在远程用户名,rlogind
在/etc/hosts.equiv
寻找远程主机名,找到则允许访问。
-
/etc/hosts.equiv
无远程主机名,rlogind
在$HOME/.rhosts
寻找远程主机名,找到且该项后无用户名则允许访问,找到且该项后有用户名,若远程用户名位于其中,则允许访问。注意这里的$HOME
是与远程用户同名的本机用户的主目录。
-
- 若通过了
/etc/passwd
的检查,但没有通过/etc/hosts.equiv
或者$HOME/.rhosts
的检查,远程用户给出口令可以登录本机,但无法使用rcp
、rsh
等。反之则可以使用rcp
或者rsh
。
- 若通过了
-
/etc/hosts.equiv
中的+意味着任意主机,此时与/etc/hosts
无关。netterm
下rlogin
除root
外的所有用户可以成功,solaris
下简单的rlogin hostname
同netterm
,但是rlogin -l username hostname
不成功。这个事实说明netterm
下rlogin
的时候,指定的参数实际上是远程主机的当前用户名。还说明hosts.equiv
文件不支持rlogin -l username hostname
,不支持root
的rlogin
。
-
值得注意的是两个+号出现在
$HOME/.rhosts
中是非常危险的,意味着任意主机任意用户都可以不用口令登录到你的用户上来。.rhosts中的第一个+意味着所有主机,与/etc/hosts
文件无关。.rhosts
中的第二个+意味着所有用户,与/etc/passwd
文件无关。若只有一个+
,netterm
中的rlogin可以成功,但来自sco root
下的rlogin -l jhli hostname
不成功,来自sco jhli
的rlogin -l jhli hostname
和rlogin hostname
都成功。说明当.rhosts
文件中只有主机名时,不支持rlogin -l username hostname
,这点和/etc/hosts.equiv
一样。若+ root
,则netterm
因无法实现rlogin -l username hostname
而失败(只能实现rlogin hostname
),来自sco root
下的rlogin -l jhli hostname
成功。+ +
则都成功。注意,$HOME/.rhosts
支持root
的rlogin
。 -
当这两个文件中没有使用+号代表所有主机时,与
/etc/hosts
文件有关。这两个文件中指定的hostname
必须是/etc/hosts
文件中出现的,而且必须是主机名,IP地址和别名无效。在/etc/hosts
文件中别名位于第三列。做主机判断时与在远程主机上hostname
命令所显示的东西无关,与远程主机上的/etc/hosts
定义无关。如果出现与这里讲述不符合的,是因为缓冲没有得到刷新的缘故,可以通过ping
相关名字得到检验。此外,若没有使用+
号,rlogin localhost、rlogin 127.0.0.1
的效果和rlogin 134.*.*.*、rlogin zhuzhou
的效果不一样,前者的检查不会通过。当hosts.equiv
中定义为localhost
时,效果则反过来。
-
rlogin -l username hostname
和rlogin hostname
的检查有点细微的差别,首先在/etc/passwd
的检查中是以-l
的参数为准的,没有-l
参数才使用远程主机的当前用户名,所谓当前用户名是考虑了su
出来的用户。其次,$HOME
也是先以-l
参数为准。第三,$HOME/.rhosts
文件中的用户名不是针对-l
参数来的,而是针对远程主机的当前用户名来的,但是对于这个远程主机的当前用户名,并不要求出现在/etc/passwd
文件中。这第6条尤其重要,许多不成功的$HOME /.rhost
就是因为对第6条的不了解。
-
$HOME/.rhosts
文件的权限问题,chmod 0
都没有影响,不过当时是处理root
用户。对于一般用户,一定要保证.rhosts
文件对于$HOME
的属主是可读的。一般来说,这个文件最好chmod 400
。对于root
,如果不希望某个用户建立自己的.rhosts
或者想替该用户建立.rhosts
后不允许该用户自己修改,可以通过chown root .rhosts
然后chmod 444 .rhosts
实现。除了root
,如果$HOME/.rhosts
文件的属主和$HOME
的属主不一致,检查将失败。
-
$HOME/.rhosts
文件中每行只跟一个用户名,若想多个指定,只好分多行指定用户名。
-
sco unix
下$HOME/.rhosts
中若用+
代表主机,与其他Unix
系统不同,这里的+
没有任何特殊的意义,所以检查将失败。但是用户名仍然可以用+
代表。并且sco unix
下若root
的.rhosts
文件go+w
,则检查失败。
-
- 建议
man rhosts
看看,各个系统有许多细微的差别。
- 建议