分类: LINUX
2009-04-02 10:12:45
开机自动登录linux,并自动运行X window应用程序,有其特殊的应用背景,如基于linux平台的监控系统,linux启动后不需要身份验证,而直接运行监控程序等等。本文以Redhat7.2为平台,结合linux启动过程,介绍了如何避免身份验证自动登录,并直接进入X window自动运行应用程序。
linux启动的最后阶段的工作
linux 在启动过程的最后阶段(具体启动步骤略),init 会根据 /etc/inittab文件的最后一行x:5:respawn:/etc/X11/prefdm -nodaemon运行/etc/X11/prefdm脚本,(Red hat 7.2缺省时是这样的)。prefdm脚本的主要任务是完成X window的启动,可以有几种启动X window的方法,都包含在prefdm脚本中,几种主要方法有:
prefdm脚本框架大致如下:
#!/bin/sh PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin . /etc/profile.d/lang.sh # 第一步:查看是否为自动登录 if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then if /usr/sbin/autologin; then exit 0 fi fi # 第二步:如果不是自动登录方式,就会在/etc/sysconfig/desktop中搜寻用户偏爱的登录方式 ...... # 可以是kdm、gdm以及xdm,并运行相应的kdm、gdm以及xdm。 ...... |
autologin的实现)
在/etc/X11/prefdm脚本中,是否实现自动登录有一个条件测试开关,事实上,可以在这里注释掉测试开关,直接执行启动X window的操作。
自动登录实质上就是绕过身份验证,直接启动X window。X window的启动可以由xinit来完成。
startx脚本的最基本框架是:
由此可看出,startx在不需要传递任何参数的情况下,可以完成启动X的任务,因此,可以如下修改/etc/X11/prefdm脚本来实现自动登录:
#!/bin/sh PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin . /etc/profile.d/lang.sh # 第一步:查看是否为自动登录 #if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then #注释掉上边的条件测试,直接运行startx if /usr/X11R6/bin/startx; then exit 0 fi #fi |
当然,应确保/etc/inittab中的启动级别为5。
重新启动系统,会发现系统不验证用户身份,直接进入X window,此时的用户身份为root。但是,如果原来root有自己的桌面、默认shell时,上述方法启动X不一定保证还能拥有原来的设置。为了在启动X后,在避免验证身份的同时,又不改变用户原来的设置,那么在运行startx之前,还有工作要做。
shell以及其它的一些环境变量)。
观察原来/etc/X11/prefdm脚本的自动登录部分:
...... # 第一步:查看是否为自动登录 if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then if /usr/sbin/autologin; then exit 0 fi fi ...... |
不难看出,脚本中保留了自动登录的接口:一个可执行文件/usr/sbin/autologin以及一个配置文件/etc/sysconfig/autologin。
1、/etc/sysconfig/autologin配置文件的实现:
#config for autologin USER=root EXEC=/usr/X11R6/bin/startx 说明,USER指定自动登录时的用户名;EXEC指定启动X要运行的程序。 |
2、/usr/sbin/autologin可执行文件的实现:
/********************* **** autologin.c **** *********************/ #include #include #include #include #include #include #include int main(int argc, char **argv) { struct stat st; FILE *f; char *cfg; struct passwd *pw; uid_t uid; gid_t gid; char *dir, *shell; char *user=NULL; char *cmd=NULL; user="root"; /*为了能说明问题又保持程序简洁,这里默认登录用户为root,实际上, 登陆用户名应该从/etc/sysconfig/autologin中得到, 程序实现时要注意过滤掉/etc/sysconfig/autologin中的无效用户名*/ cmd="/usr/X11R6/bin/startx"; /*同样,这里直接指定启动X window的程序,实际上,该程序应该从/etc/sysconfig/autologin中得到*/ pw = getpwnam(user); //getpwnam返回包含用户信息的passwd结构(该结构在pwd.h中定义)。 if(pw) { uid=pw->pw_uid; gid=pw->pw_gid; dir=strdup(pw->pw_dir); shell=strdup(pw->pw_shell); } //获得用户相关信息 else { printf("ERROR: No such user %s!\n", user); return 1; } chown("/dev/console", uid, gid); chown("/dev/tty", uid, gid); //为控制台和终端设置用户ID及组ID //下面是设置用户相关ID setregid(gid, gid); setegid(gid); setgid(gid); setreuid(uid, uid); seteuid(uid); setuid(uid); setenv("HOME", dir, 1); setenv("SHELL", shell, 1); setenv("USER", user, 1); setenv("LOGNAME", user, 1); //设置用户相关环境变量 chdir(dir); //切换到用户根目录 user=NULL; execvp(cmd, argv); /*在配置完用户的相关信息后,执行启动X window操作。注意这里默认执行/usr/X11R6/bin/startx */ printf("ERROR: Couldn't exec %s: %s\n", cmd, strerror(errno)); return 2; } |
运行gcc -o autologin autologin.c,拷贝autologin可执行文件到/usr/sbin/autologin,拷贝autologin配置文件到/etc/sysconfig/autologin。重新启动系统,会直接进入X window并保留用户原来所有的风格。
如果不需要自动登录的配置文件/etc/sysconfig/autologin,所有的操作都在/usr/sbin/autologin以默认的方式实现(比如,默认登录身份为root,默认执行操作为/usr/X11R6/bin/startx等),那么,/etc/X11/prefdm脚本的自动登录部分可简化如下:
...... # 第一步:查看是否为自动登录 if /usr/sbin/autologin; then exit 0 fi //第二步 ...... ...... |
即在脚本中去掉条件测试开关,直接执行/usr/sbin/autologin,这时,只需要拷贝autologin可执行文件到/usr/sbin/autologin,不再需要拷贝autologin配置文件到/etc/sysconfig/autologin。
kde或者gnome,并自动启动X window应用程序