QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4211|回复: 1
打印 上一主题 下一主题

如何自动登录linux[转载]

[复制链接]
字体大小: 正常 放大

1253

主题

442

听众

-586

积分

复兴中华数学头子

  • TA的每日心情
    开心
    2011-9-26 17:31
  • 签到天数: 3 天

    [LV.2]偶尔看看I

    自我介绍
    数学中国网站(www.madio.cn)是目前中国最大的数学建模交流社区

    邮箱绑定达人 优秀斑竹奖 发帖功臣 元老勋章 新人进步奖 原创写作奖 最具活力勋章 风雨历程奖

    群组越狱吧

    群组湖南工业大学数学建模同盟会

    群组四川农业大学数学建模协会

    群组重庆交通大学数学建模协会

    群组中国矿业大学数学建模协会

    跳转到指定楼层
    1#
    发表于 2004-9-27 14:26 |只看该作者 |正序浏览
    |招呼Ta 关注Ta |邮箱已经成功绑定
    <>如何自动登录linux[转载]</P>
    4 o1 @* q& `! u% T- f<>本文以redhat 8.0操作系统平台为背景,阐述如何实现启动级别为3时的自动登录,及自动运行相应程序,并简要介绍了如何在redhat 8.0下自动登录X window(系统启动级别为5),并自动运行指定的应用程序。 3 \5 O( R! h0 k0 P+ Q
    [b:804aea7097]一、启动级别为3时自动登录的实现[/b:804aea7097] 3 W/ Y: a6 K9 Y4 g3 d7 ?
    $ \  y2 z8 U, g
    启动级别为3时自动登录的实现涉及两个软件包:mingetty-1.00-3.src.rpm软件包及util-linux-2.11r-10.src.rpm软件包。
    ! |/ B' e6 d6 h; o, N9 B
    , w( n. F7 d! X  I(1)mingetty-1.00-3.src.rpm软件包  
    $ Q0 g4 B( n3 o% m对于启动级别为3的自动登录的实现,仍然需要考察/etc/inittab脚本,  8 z7 j  r8 q" |1 m9 H# A& W0 Z
    3:123:respawn:/sbin/mingetty tty3
    5 d( ?9 M3 L% K* C
    , y# k( p3 ^! c9 p. _
    ' F  d4 G7 s5 V1 D/ U8 q6 N  
    + j; ]+ i. {0 b: B) \( U% W+ \, c2 Q/ E' ?6 d9 C

    : H. X( L% c! p7 V8 ~因此,如果想在启动级别3的情况下实现自动登录,必须要了解mingetty的功能,甚至要修改mingetty的代码。用命令rpm -qf /sbin/mingetty 可知redhat 8.0版本的mingetty包含在mingetty-1.00-3.src.rpm软件包中,下载该软件包,安装源代码,缺省情况下,代码会安装在/usr/src/redhat/下,我们关心的只是mingetty.c源文件。mingetty.c约有五百行代码,主要实现如下功能:
    1 @+ }8 G: I" u; K# }7 R. V
    0 I' c+ D! g$ R5 [
    ( c' U+ q2 `, b/ }7 p6 i打开指定的tty(由参数指定);  
    9 `% o; M% v/ V8 s/ z# P提示用户登录(login:);  " u* W. Z- Y2 [8 I3 r& K+ [
    获得登录用户名;    s& m( Z( c$ g7 x+ J
    把用户登录名作为参数,调用/bin/login。  
    % ]. l2 _! h0 c# K9 e: D/ _# n: G! V+ r, a' ]
    我们所关心的部分实质上只有以下三行: 4 X$ g: I7 A. Q, V

    3 U. ]. x7 E/ D; [& \7 z8 v+ q2 y  K& V% W5 X( N6 x; p$ o
    ... ... 6 n8 n7 {5 U* u! d. i2 e, }& o
    438 while ((logname = get_logname ()) == 0); //mingetty.c文件438行
    7 E- j6 ]0 v5 A$ U: r! Y# [; s$ R439 execl (_PATH_LOGIN, _PATH_LOGIN, "--", logname, NULL);
    + P, W6 n, N( q! B2 _/ j440 error ("%s: can't exec " _PATH_LOGIN ": %s", tty, sys_errlist[errno]);   Q* y0 d7 P: k: S. {" S
    ... ... - Y' f+ A3 ?/ T" Z

    3 g$ o$ j/ N& e  
    $ e- N& k, r$ c2 G2 _$ Z# G+ l' N7 W* l7 f. S! [  {4 b. g
    第一行的功能是输出login提示,并获得用户输入的登录用户名,登录用户名由logname返回。因此,可作如下修改 7 a( v( F4 g0 k. l* j
    ) P9 u5 O2 o! {# O" y0 d7 f# _( U: g& X# ]
    ; ?" U% ~% s: G. G9 b7 j# t, |/ Y* G
    ... ...
    5 q0 ^: l) U8 H# y  u' N5 l% ]0 N438 // while ((logname = get_logname ()) == 0); //注释掉本行,不再提示login: / J6 X# S. M7 W+ \3 T; j
    439 logname = "root"; //添加本行代码 0 U8 k5 c4 m6 J1 g! g
    440 execl (_PATH_LOGIN, _PATH_LOGIN, "--", logname, NULL);
    5 F7 d; O: W$ O* W, U441 error ("%s: can't exec " _PATH_LOGIN ": %s", tty, sys_errlist[errno]); % O6 R7 x' A" O5 C
    ... ... / a/ ~# d* P1 z

    4 R9 Z! S: G, w* J' r  5 z% J. b5 \6 S5 J
    $ B3 ~& e$ Z# `& C( D
    注意,这里假定用户以超级用户身份登录。 5 ]- n' ~4 T. z: C4 k2 ?; }
    ! @8 u9 X# H$ ]8 k3 y# [# r' Z' R
    第二行以用户登录名为参数,调用/bin/login程序,进一步实现登录。因此,要想实现自动登录,还应该了解/bin/login的功能,必要时还应修改其源代码。 5 Y( f" z& `' M+ p$ X

    & P5 G& d  K; Q第三行为出错处理。
    2 n9 x! p% O2 U' \& n! ~8 w0 ^6 E) r1 }8 q
    (2)util-linux-2.11r-10.src.rpm软件包  
    ! K/ Q; U8 f( m1 H. H2 E采用同样的方法,查看/bin/login所属软件包(redhad8.0版本的login包含在util-linux-2.11r-10.src.rpm软件包中),下载并安装util-linux-2.11r-10.src.rpm,login可执行文件有几个源文件编译而成,我们最关心的是login.c源文件(大约1500行的代码)。下面简要分析一下login要实现的功能,并对相应部分作必要的修改。 ) J3 e8 N+ z: Z, I1 |7 A, E/ w3 @
    ( X5 \' b. t: A9 G5 P# G. l$ _* D; K
    Login程序主要可以分为以下几个主要部分: $ `3 p0 z; O9 Z/ ?, E/ z! u

    ; P/ _6 n" w# Y8 L1.Login首先检查登录者是否为超级用户,如果不是超级用户,并且存在/etc/nologin文件,则输出该文件内容,并中止登录过程;主要由checknologin()实现;  
    ' s4 n$ Z% G( M; n# U+ g  v0 r2.如果登录用户是超级用户,那么login必须在/etc/securetty/中指定的tty列表中实现登录,否则将导致登录失败。同样可以不指定/etc/securetty文件,此时,超级用户可以在任何tty上登录。  
    3 q0 E4 b# Q1 S# P+ x* F3.经过前两步测试后,login接下来将提示输入登录密码(由getpass()调用完成,有兴趣的读者可参考其手册页面),并进行验证,如果密码不对,则提示重新登录。  $ {# p6 I$ f8 ~5 T0 w4 I
    4.顺利经过密码验证后,login还将检查是否存在.hushlogin文件,如果该文件存在,则执行一次"quiet"登录(所谓的quiet登录指的是,登录时不再提示邮件mail,不再显示最后一次登录时间,不输出任何消息。启动级别为3时,正常情况下输出这些信息)  : e( s2 O7 G) k/ N
    5.login接下来设置登录tty的用户ID和组ID,并设置相应的环境变量,包括HOME、PATH、SHELL、TERM、LOGNAME等。对于普通用户来说,PATH缺省被设置成/usr/local/bin: /bin/usr/bin:;对于超级用户来说,PATH被设置成/sbin: /bin: /usr/sbin: /usr/bin:  
    / B/ U) y" @  c. l6.login的最后一步是为用户启动shell。如果在/etc/passwd中没有为用户指定shell,那么将使用/bin/sh,如果在/etc/passwd中没有给出当前工作目录,则使用"/"。  
    8 w3 @6 H/ s) X- M4 n3 e2 m至此,一个完整的登录过程就结束了。
      P* h& C- A# U6 t4 z1 [* ]  t, {1 i( s" V
    从以上对login源程序分析过程中可发现,如果要实现自动登录,应该在第三步做文章,设法绕过提示输入密码以及对密码进行验证这一过程。实际上很简单,login源程序对是否要求输入密码设置了一个开关控制passwd_req,缺省情况下,其值为1(passwd_req = 1),即要求输入密码进行身份验证。把该行代码改为(passwd_req = 0)后,问题就解决了。即对源文件作如下修改即可:
    : A0 B& A8 h+ |0 m- w; M, x4 W% q  V4 E/ x  E% Q

    " }0 z* E: m& t: S( o; g* U1 z... ...   Q& z; x7 g) ~+ ]4 @& W& j5 @
    402 fflag = hflag = pflag = 0; //login.c文件402行
    / H+ k+ E, O' Z; Y8 r8 [403 //passwd_req = 1   //缺省时,要求进行密码验证,注释掉本行
    7 V1 C. n0 [( N6 D, _404 passwd_req = 0 //添加本行 0 b* ?  x( y5 W3 o) V% n
    ... ...
    5 Q6 U" @6 n& _1 m* q9 g7 E. n4 T" q' W5 B
      
    - P! x9 ]$ d' A) c* R% Y, l# `' e, C$ d( O  o  F+ H$ U6 r9 D
    修改后,可以直接使用util-linux-2.11r-10.src.rpm提供的Makefile进行重新编译,也可以自己对其编译:
    9 ~8 \- G  _9 g1 u5 I" N7 F% `& A7 L. V- E! Y

    ) S0 K6 ^, J9 Egcc -o login login.c setproctitle.c checktty.c xstrncpy.c -Wall -lcrypt注意包含后面的编译选项-lcrypt,否则会出问题。
    5 E) |+ ]+ m2 i' T$ G$ d  R/ e/ |, c( M4 }1 T$ W
    3 \( v5 n- P& F1 y
    有了新版的mingetty及login后,拷贝mingetty到/sbin/目录,拷贝login到/bin目录,并将/etc/inittab中的启动级别设置为3,再重新引导系统即可(读者可以自己写一个脚本实现上述过程)。 ; ~% Y* h* G9 h/ h( i7 v4 |& p4 v

    3 R9 |( ?' F* i6 `如果读者对mingetty或login代码的其他部分感兴趣,可以反复修改login.c或mingetty.c的源代码,测试一下代码的功能,这里要注意的是,在拷贝新版mingetty和login之前,一定要把原来的mingetty和login备份,同时还要准备系统引导盘(有系统安装盘亦可,这样读者有机会键入linux rescue),在测试新版程序前更应如此,如果对代码修改稍有不当,系统将不能正常启动。 3 e0 r$ F0 I  y6 [" T) b1 C6 h
    # l% t1 m, d- K5 I! O4 |$ e
    如果不想再作进一步的代码测试,只是按本文给出的方法进行代码修改,在系统启动上不会出现什么问题。 - _4 k8 ]5 |& A) h- o, b% Y

    , q6 P0 X3 k# X+ I+ L4 @[b:804aea7097]二、自动登录后,自动运行特定的应用程序[/b:804aea7097] 6 y* i. U& B& N) \3 U. w7 o3 y; o

    5 p' [  M/ h% T  P在实现了启动级别3时的自动登录后,自动运行应用程序非常简单,把应用程序添加在/etc/rc.d/rc.local脚本中既可。(读者可以尝试一下把startx加入脚本中,看一看效果如何。在某种意义上,又增加了一种自动登录X window的方法)
    + C/ g* v; l8 U1 K8 Z' r& d! X) K
    [b:804aea7097]三、对自动登录X window(系统启动级别为5),并自动运行指定的应用程序的补充[/b:804aea7097]
    " v* ?1 T1 P- |& y3 a0 {% T) ?4 |* {  q& D) o) y2 r/ l1 h3 h
    在"如何实现自动登录linux"中,主要以redhat 7.2平台为背景进行阐述的,其中的自动登录部分可以直接用于redhat 8.0中,不需要任何修改。 $ l! ^; B4 U; {8 N) ?& Q4 V
    9 @' a( X! }$ b" e
    但是,登录后自动运行应用程序的接口在redhat 8.0中有所不同,主要是登录gnome后,自动运行应用程序的接口有所改变:首先点击面板上的GNOME帮助(那个红色的小帽子),然后选择/其它/首选项/Sessions,在Session对话框的启动程序属性页中添加要启动的程序即可。
    8 f5 u2 T# k/ l- m% D
    ! L3 q1 ]7 J3 G* W7 i8 C8 z8 K对于登录kde后,自动运行程序的接口没有改变。 5 c9 O% v1 J$ K* p! m; i* S+ [

    + {% m: h1 E5 O0 u[b:804aea7097]四、结论[/b:804aea7097] & S& I0 ]: \; N

    ) l& I/ R4 z4 X本文同"如何实现自动登录linux"一文,基本上解决了如何实现自动登录Linux,并自动运行相应应用程序的问题。对于两个最常见的启动级别(3、5),都给出了各自的方法。 # F0 l, C# M8 s* N; X
    3 d7 s- Z3 x2 A& `3 l% C& u% B
    在系统初始化到mingetty及login这一阶段,内核实际上已经完成了引导过程,已经到了系统初始化的最高阶段,与内核没什么关系了。此时,主要是/sbin/init根据/etc/inittab的内容而相机行事。读者可通过(man 8 init)或者(man 5 inittab)了解更多东西。
    : I( O3 O+ Y3 ~5 f" Q4 x+ G2 {. u) h! S8 Q
    在对文中提到的软件包修改时,请遵守GNU General Public License(GPL)相关标准,另外,替换login通常被视为黑客行为,应当谨慎行事。 : s2 B; V" H) k+ g" v

    ; D+ V, _2 n1 H9 }; G2 F/ T6 d+ a
    1 E" W# S- N# D9 N& f# X% v& ~; I* @/ _% y4 e1 O0 X; I
    [b:804aea7097]参考文献[/b:804aea7097] ) p  B+ Z& {! z; X3 \/ }9 A& B* }

    5 ?5 K% Z5 X* [3 u1 ]- a4 n
    4 n$ t, N, f$ ~/ ~  [5 t' }1.login手册页面  ; d, R* [4 j- `2 _" ]2 D
    2.mingetty-1.00-3.src.rpm,在redhat 8.0的发行版本的源代码中,包含该软件包;  
    5 A0 w3 [1 s! F3 Q& G# n: b6 c3.util-linux-2.11r-10.src.rpm,  ; f0 S% X- g( L: _7 P; `
    + A! i7 m. C6 j" N& P) l# m
    可在http://rpmfind.net/linux/RPM/redhat/8.0/i386/util-linux-2.11r-10.i386.html处下载,注意下载源代码包(..src.rpm)
    1 k! c3 l8 U  q$ E8 ?* P# s) ?. m& p) Y2 N+ n/ ?
    [b:804aea7097]关于作者[/b:804aea7097]  3 M1 [& Z8 D" W( p5 s8 w: ~; t

    ; |% x$ W( p9 A0 Q; _) ^2 O9 ]3 o郑彦兴,男,现攻读国防科大计算机学院博士学位。您可以通过电子邮件 mlinux@163.com和他联系
    * A+ H6 B8 o  z( x7 n+ N, M5 c) [2 U, c8 R8 l; _: z
    </P>
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    数学中国网站是以数学中国社区为主体的综合性学术社区,下分建模、编程、学术理论、工程应用等版块。从2003年11月建站以来一直致力于数学建模的普及和推广工作,目前已经发展成国内会员最多,资源最丰富,流量最大的数学建模网络平台。我们始终秉承服务大众的理念,坚持资源共享、共同进步的原则,努力营造出严肃、认真、务实、合作的学术氛围,为中国数学的发展做出应有的贡献。

    1253

    主题

    442

    听众

    -586

    积分

    复兴中华数学头子

  • TA的每日心情
    开心
    2011-9-26 17:31
  • 签到天数: 3 天

    [LV.2]偶尔看看I

    自我介绍
    数学中国网站(www.madio.cn)是目前中国最大的数学建模交流社区

    邮箱绑定达人 优秀斑竹奖 发帖功臣 元老勋章 新人进步奖 原创写作奖 最具活力勋章 风雨历程奖

    群组越狱吧

    群组湖南工业大学数学建模同盟会

    群组四川农业大学数学建模协会

    群组重庆交通大学数学建模协会

    群组中国矿业大学数学建模协会

    如何实现自动登录Linux (Runlevel 5)
    3 V, c9 a. s) K9 A. j8 V% E+ L& s- @: X; R4 P& i6 A# w, O9 v
    机自动登录linux,并自动运行X window应用程序,有其特殊的应用背景,如基于linux平台的监控系统,linux启动后不需要身份验证,而直接运行监控程序等等。本文以Redhat7.2为平台,结合linux启动过程,介绍了如何避免身份验证自动登录,并直接进入X window自动运行应用程序。
    5 K5 C8 t# m& H3 N, h5 S( g( Z一、linux启动的最后阶段的工作   Q. m4 Q- C4 E

    4 V# M' `8 K3 q' z% ?8 Ylinux 在启动过程的最后阶段(具体启动步骤略),init 会根据 /etc/inittab文件的最后一行x:5:respawn:/etc/X11/prefdm -nodaemon运行/etc/X11/prefdm脚本,(Red hat 7.2缺省时是这样的)。prefdm脚本的主要任务是完成X window的启动,可以有几种启动X window的方法,都包含在prefdm脚本中,几种主要方法有: 5 z8 j1 ]+ o. O

    ) [% I+ W. X: b- S3 [7 y9 G运行xdm启动X window;  5 G8 c0 K- n6 J2 b! z
    运行gdm,进入gnome桌面环境;  
    0 B# r  @7 j6 z& M运行kdm进入kde桌面环境;  9 j/ H1 m" X2 P0 O+ K6 v1 e
    自动登录进入linux;  : e% ]* V' H! j. t7 L
    prefdm脚本框架大致如下:
    9 v% e5 e" R2 E2 `  j  E8 w1 D
    7 p' D. k( R  a#!/bin/sh 4 ^) \" Q  [  T) v
    PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin
    ; R- A7 [+ f/ C6 O' \5 }& ]( I. /etc/profile.d/lang.sh $ L0 T. w! x8 C8 i5 f
    # 第一步:查看是否为自动登录 ' G. O! `. s9 O4 }! k% N- k/ h
    if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
    6 P$ ^% ?1 m4 R. P7 D* Pif /usr/sbin/autologin; then 6 G; j9 [$ O' `
    exit 0 * e8 E7 w5 n/ l6 d% {$ R" ~) [
    fi
    ( w/ b1 V  [; O6 k( [- N+ ^- @fi " V" j  @, ~. m" p2 ^

    ( i5 _6 k  @' ^: b8 X# 第二步:如果不是自动登录方式,就会在/etc/sysconfig/desktop中搜寻用户偏爱的登录方式
    % |7 O- Z% o' E+ a0 w6 c" H......   v9 V+ W+ T* t5 J3 Y6 L2 m: A
    # 可以是kdm、gdm以及xdm,并运行相应的kdm、gdm以及xdm。 3 V6 N, W5 P7 g" u, L/ O# b, _
    ......
    , L8 v% G) W- u% G! \
    # \9 n/ B9 U' S6 C& S+ k. o  & J3 J+ v6 E. H" h% P' z( G9 c

    9 r) H' K  E1 K" p& j
    - Q0 D) Y) {& k5 Z6 L! z二、自动登录的实现(autologin的实现) * i3 U1 N' u' k: Y# o
    0 a1 z& L% M9 Y- O/ O# {6 V" [
    在/etc/X11/prefdm脚本中,是否实现自动登录有一个条件测试开关,事实上,可以在这里注释掉测试开关,直接执行启动X window的操作。 # ~" E! c+ Z$ s2 ^, v
    , G/ V: g) m- u2 h3 T
    自动登录实质上就是绕过身份验证,直接启动X window。X window的启动可以由xinit来完成。 & U( x. m& `$ Q5 V  b  c, n" z& ]

    2 I( h( K2 H4 Z# n1 j, ~Xinit用来启动X window系统服务器以及系统上的第一个客户程序,可以通过为xinit传递命令行参数的形式指定要启动的服务器及客户程序。如果不传递参数给xinit,它将在用户的根目录下寻找并运行 .xinitrc脚本来启动客户程序;在用户的根目录下寻找并运行 .xserverrc脚本来启动服务器。如果xinit在用户的根目录下找不到.xinitrc、.xserverrc,xinit将使用缺省的X :0。  # _/ a$ Y1 D4 u1 T
    实际上,用startx来启动X更为方便。对于运行单一会话的X window 系统,startx提供了更为良好的用户接口。同样,startx首先在用户的根目录下寻找 .xinitrc及.xserverrc脚本,如果找不到这两个脚本,startx将使用/etc/X11/xinit/xinitrc以及/etc/X11/xinit/xserverrc脚本。  
    , E2 Z* s. p, K) [startx脚本的最基本框架是:
    $ F: g( C+ j. c3 b  B; U- b% y. |$ U; `' M3 }) I* V( C
    a、 寻找.xinitrc,如果没有则使用xinitrc; 7 s- T: i$ g- y$ e- R( \; d. @* t
    b、 寻找.xserverrc,如果没有则使用xserverrc;
    " `  m: ]( _9 d8 cc、 根据找到的脚本确定xinit的参数;
    . m, ~2 w1 q" @; t: p" M$ i! f1 B% m0 ]
    由此可看出,startx在不需要传递任何参数的情况下,可以完成启动X的任务,因此,可以如下修改/etc/X11/prefdm脚本来实现自动登录:
    ) S3 E" l/ [! f: s) Y
    # R! v8 P' Q8 O3 A, [* W. \" g+ {& r4 I6 L8 S+ l2 s, Z
    #!/bin/sh
    5 X4 v+ Q3 y; D; p# \, N2 vPATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin
    % ]6 t/ A' _9 \8 X. /etc/profile.d/lang.sh ' t; ?* b5 |5 }' y- V
    # 第一步:查看是否为自动登录
    ( \8 n8 G/ O4 }2 l4 M#if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
    ! j4 F/ q* b0 E$ T; g#注释掉上边的条件测试,直接运行startx ( T, V! X3 C* v% |
    if /usr/X11R6/bin/startx; then 4 h) f! D% M5 E
    exit 0
    + f- F, A' s5 j$ c  m$ A! |fi
    + v+ A4 `1 g6 Q; z#fi
    / o3 A% o2 _4 h4 g5 o; l8 D( W4 @- q. S- ~
      
    7 I8 z# `- e8 R" P# J2 {8 `
    # c& H7 z& }) _8 Y2 P. C  f
    " A$ c5 p3 ~7 |当然,应确保/etc/inittab中的启动级别为5。 + n8 H( ?: I' B7 p  U$ M/ T
    7 n" Y6 Y) N+ x! P" M; k
    重新启动系统,会发现系统不验证用户身份,直接进入X window,此时的用户身份为root。但是,如果原来root有自己的桌面、默认shell时,上述方法启动X不一定保证还能拥有原来的设置。为了在启动X后,在避免验证身份的同时,又不改变用户原来的设置,那么在运行startx之前,还有工作要做。
    3 s& I+ N) e  A( H+ }6 u: c2 k+ W9 n3 V2 N; m
    三、自动登录后,保持用户原来的配置(桌面、shell以及其它的一些环境变量)。 2 U! N2 P( R$ M4 s- Q5 Y
    + s/ J) w% H# _% a' z6 n$ H
    观察原来/etc/X11/prefdm脚本的自动登录部分:
    * i" e; P; a: C9 H5 x: K/ l! |2 V0 M  O4 u9 v4 F

    3 Q8 {7 b, |8 A/ C1 N( a3 H$ M...... * u2 M- d! ]& ^$ ?& Y0 H5 z- C
    # 第一步:查看是否为自动登录 3 x/ C$ e' O& J4 z
    if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
    6 C( `2 D. A% F1 }# ]( v* |/ t+ rif /usr/sbin/autologin; then
    & M  p' J( K- {- A/ ?1 p- w6 Vexit 0   ?4 u( \& a; G
    fi 1 B* M% o. y6 h2 X: ^# I9 r
    fi 5 T" {. }. b8 z
    ......
    ! r5 {3 _4 `2 |+ H, j+ Q" d
    : h8 ]* G& F% `5 F8 W  
    $ M5 x% I8 D1 z  k2 E/ Q4 l4 @; C( i+ \

    / p3 f: h' J) \" k* }) w: ?不难看出,脚本中保留了自动登录的接口:一个可执行文件/usr/sbin/autologin以及一个配置文件/etc/sysconfig/autologin。
    ; c3 W) F7 z8 ~! h7 i" Z7 M  @1 Y+ M: E1 `
    1、/etc/sysconfig/autologin配置文件的实现:
    * s3 n. \# s5 ~' Z2 Y4 I0 @" b+ N" @  M0 k

    ' G( X0 M' H0 Q; ]#config for autologin 8 o, ~. K/ A+ c* I
    USER=root 4 E. p* P4 B( I* H
    EXEC=/usr/X11R6/bin/startx
    " d9 r( H8 M+ b( K- e& p说明,USER指定自动登录时的用户名;EXEC指定启动X要运行的程序。 . r3 K3 y( Q3 v5 K

    * u8 `' B% u) m/ W( W) |0 C  
    $ r: O$ C: `# S/ R0 c) |1 a4 q$ [) U
    1 @1 r8 w- }6 N; j
    2、/usr/sbin/autologin可执行文件的实现: 1 H# |  D+ Q0 [4 _, e
    6 `( |, F9 S) m8 M$ Z4 G- Z
    , N* T& N- S4 g  c% X9 ^
    /********************* 6 c% n/ A* m+ q4 X  E& i
    ****  autologin.c  **** " ?+ e( h4 @* c5 k" u: ~* s5 }
    *********************/ 4 A* b6 E" J) `; @0 N1 a& A( Q
    #include &lt;stdio.h&gt; 9 m) j( N: l6 Z
    #include &lt;unistd.h&gt; " h1 G( d3 {% R" c* s8 P: m! ~
    #include &lt;string.h&gt;
    2 d+ Y0 W/ Y0 Z6 ~  N8 y. ?#include &lt;errno.h&gt;
    9 v0 V6 o' G" _  |#include &lt;sys/types.h&gt; # I+ Q; ^1 z* |9 R- n
    #include &lt;sys/stat.h&gt; - D5 P' I7 d" l# G9 o2 @4 a
    #include &lt;pwd.h&gt; + s7 [8 a0 S; |) y

    ( r8 M6 r3 i* E7 }! Gint main(int argc, char **argv)
    ! Q% `1 r3 o+ e4 z% U/ u{ 2 j8 |7 P$ g$ f
    struct stat st; ) Q6 j$ R8 L2 _/ f  Q( [
    FILE *f;
    1 |* c' V5 p+ M0 I; E3 zchar *cfg; 2 W5 q. y( q' a. L
    struct passwd *pw;
    + Z% r4 C- q6 q  Auid_t uid;
    - L+ X$ D% q$ y, I: g6 cgid_t gid;
    : J9 r/ Y" Z* U6 a8 ?8 lchar *dir, *shell;
    6 O: i6 `. G: S& ^1 achar *user=NULL; + [% l9 ^" t) B
    char *cmd=NULL; : r4 T. s: c+ E, T/ \3 i5 i
    # n5 M0 ^  \) y/ l
    user="root";
    9 h. V3 A* W4 r8 a7 L0 F# ?  r/*为了能说明问题又保持程序简洁,这里默认登录用户为root,实际上, . D# p. |7 i' |! }; u5 i5 u( D# ?  n
    登陆用户名应该从/etc/sysconfig/autologin中得到,
    8 Z6 B& }4 i, N0 M  `: C程序实现时要注意过滤掉/etc/sysconfig/autologin中的无效用户名*/
    ) V( W+ R; V. M" U5 r/ ?7 kcmd="/usr/X11R6/bin/startx";   X1 l) X' X. X, m$ d. i! L. r( E
    /*同样,这里直接指定启动X window的程序,实际上,该程序应该从/etc/sysconfig/autologin中得到*/
    7 _7 I* M9 A! g8 s6 Q  |% l. b* @8 O, H8 Y" L6 y
    pw = getpwnam(user); ) O! ^) R) b8 x' \8 _& }1 i# Z
    //getpwnam返回包含用户信息的passwd结构(该结构在pwd.h中定义)。
    " s4 T# z. K2 K, F# d: C* hif(pw) {
    2 d& c' S5 h/ j7 {, W8 [uid=pw-&gt;pw_uid;
    " x: L+ B# z7 hgid=pw-&gt;pw_gid; dir=strdup(pw-&gt;pw_dir);
    ' P  H$ {+ D9 A9 J8 S3 N; l6 s$ H1 gshell=strdup(pw-&gt;pw_shell);
    7 ~, I, Z+ R/ Z$ |}
    % ~& Y$ G+ I$ |2 D//获得用户相关信息
    / _  a  \) ~  M' P9 g. B+ X5 G5 b4 c else { " l! X8 k$ B* k: R1 E& V
    printf("ERROR: No such user %s!\n", user);
    ; s8 T# y7 y8 _) l& v' [return 1; ( n, j  w5 s' a' w0 y+ F
    }
    . K, T/ i) b9 L1 u7 L
    3 U6 h: t9 ?; B8 Y9 Pchown("/dev/console", uid, gid);
    9 w  K3 _3 c& b! c9 E, rchown("/dev/tty", uid, gid);
    # A: N) U- a" g& \: a: `7 y//为控制台和终端设置用户ID及组ID
    , L- `. {; E: b7 q' T# N: n
    & y, n* `; ~  C/ S% w, T! T" y- C//下面是设置用户相关ID * B, b& G6 u8 w) r
    setregid(gid, gid);
    - g/ j  }. s% ?setegid(gid); 2 c0 I+ x" D$ T& G
    setgid(gid);
    0 v: v  W& }: R( Z* zsetreuid(uid, uid); 7 y& `/ ]* v6 q
    seteuid(uid);
    ( C/ ?) w4 t9 dsetuid(uid); 3 t7 U6 J, U1 B! t  ?' W. P6 X0 ~
    5 Z( A4 U3 f: j
    setenv("HOME", dir, 1);
    % S- w$ ~, ]7 w$ E8 D; x7 ^* A6 Wsetenv("SHELL", shell, 1);
    ' s3 T, r$ n8 R) l  m$ csetenv("USER", user, 1); 0 `: \/ E3 S6 V$ |4 P3 P
    setenv("LOGNAME", user, 1); ) {$ A. C$ U* [" p1 C
    //设置用户相关环境变量 7 d) b! i8 g! l! |; o4 f# D' H
    / t: m: l9 A; P6 y$ m# f/ Q
    chdir(dir);
    ( s0 `' d  z( p  c/ \1 \; K* l//切换到用户根目录 1 b; Z6 b# i2 s! X) `6 @
    user=NULL;
    ) r6 l, }1 j! ~5 h" V
    ) Y5 ]/ [% b$ ^! |) Rexecvp(cmd, argv); ' F; E3 s3 `6 C
    /*在配置完用户的相关信息后,执行启动X window操作。注意这里默认执行/usr/X11R6/bin/startx */
    5 B/ J0 v' H" D- _printf("ERROR: Couldn't exec %s: %s\n", cmd, strerror(errno));
    + T, z; P2 V/ l6 T7 }! breturn 2;
    % E0 n6 f7 q( I5 m3 K} 4 P& X6 H5 [: O; K8 g, ]  |

    0 o% b; v$ L5 r$ G* O( s4 l5 a  
    $ e; r% p8 p( Z9 n" I: d* L  H) W9 U) u  M7 [" H

    , I/ I$ y. \7 I! L4 w" m0 S  ]运行gcc -o autologin autologin.c,拷贝autologin可执行文件到/usr/sbin/autologin,拷贝autologin配置文件到/etc/sysconfig/autologin。 重新启动系统,会直接进入X window并保留用户原来所有的风格。 $ R5 S( H9 H  U) m& E
    4 G+ e; `" h  K" z. Q+ d- M
    如果不需要自动登录的配置文件/etc/sysconfig/autologin,所有的操作都在/usr/sbin/autologin以默认的方式实现(比如,默认登录身份为root,默认执行操作为/usr/X11R6/bin/startx等),那么,/etc/X11/prefdm脚本的自动登录部分可简化如下: # L( K- E5 G. t, D) q3 w9 R

    8 j% y9 B2 U- e( r8 l( z* C' ?5 _) s7 l' n( X
    ...... 4 L( `+ d3 Y6 K! Q
    # 第一步:查看是否为自动登录
    6 d5 X) O( v0 b& r7 [# K/ [if /usr/sbin/autologin; then % x; |- ]6 h5 y
    exit 0 0 f7 ]" U: |2 d8 ~# |! m
    fi , I- u% n! {  l* G( M3 \9 c
    //第二步 ......
    5 x! Z! ^; U! ~) l) X9 I...... 0 j1 Y/ B# T0 M- `& w3 D3 A5 h

    1 F- |$ C$ ]2 R. ^( T0 }0 s  
    + e0 O/ U3 Y7 a0 p) Q* A
    1 H) o1 V/ o4 E1 G2 Z2 [; x. `; d" v! S+ a
    即在脚本中去掉条件测试开关,直接执行/usr/sbin/autologin,这时,只需要拷贝autologin可执行文件到/usr/sbin/autologin,不再需要拷贝autologin配置文件到/etc/sysconfig/autologin。
    7 r7 Q, p9 B  j& f# s. a4 @
    + T+ o  {+ ~. |2 ?" S! ]+ R四、选择进入kde或者gnome,并自动启动X window应用程序
    ( S+ {5 m2 y9 H1 |6 c4 A7 D) _0 d3 p1 F1 N" t6 e
    如果重新启动后系统进入了kde,而用户需要进入gnome,只需运行switchdesk gnome在重新启动系统即可,以后每次启动时会自动进入gnome;反之亦然。  
    - c/ v% l7 W8 h+ D% ?一般系统自动登录的目的是启动X window 后自动运行某个X window程序。如果系统默认的启动级别为3,那么如果要在系统启动后自动运行某些应用程序,只需要在某些脚本中加入相应命令即可,不再详述。在X window启动后自动运行应用程序要复杂一些,幸好,kde和gnome都为此留下了自动启动接口。如果在kde桌面环境下自动启动应用程序,只需要把应用程序名字加入/root/.kde/Autostart/目录下即可(这里注意不同用户的根目录可能不同,如用户zyx的根目录可能为/home/zyx)。如果在gnome桌面环境下自动启动应用程序,只需把应用程序的名字加入/主菜单/程序/设置/会话/会话特性及启动程序的startup programs属性页中即可。  # _8 i! u! J# b9 B9 a/ \

    2 _3 L" a  Q' x3 o" n4 ^$ P
    & `6 X5 X! G. I1 y. f' c% thttp://www-900.ibm.com/developerWorks/cn/linux/l-tip-prompt/tip20/index.shtml
    数学中国网站是以数学中国社区为主体的综合性学术社区,下分建模、编程、学术理论、工程应用等版块。从2003年11月建站以来一直致力于数学建模的普及和推广工作,目前已经发展成国内会员最多,资源最丰富,流量最大的数学建模网络平台。我们始终秉承服务大众的理念,坚持资源共享、共同进步的原则,努力营造出严肃、认真、务实、合作的学术氛围,为中国数学的发展做出应有的贡献。
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-4-18 22:00 , Processed in 0.341067 second(s), 57 queries .

    回顶部