QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3959|回复: 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>" k3 J  f4 `* t, H! ?+ ]
    <>本文以redhat 8.0操作系统平台为背景,阐述如何实现启动级别为3时的自动登录,及自动运行相应程序,并简要介绍了如何在redhat 8.0下自动登录X window(系统启动级别为5),并自动运行指定的应用程序。
    $ T! k3 b( }, f* ]/ d, U: Y[b:804aea7097]一、启动级别为3时自动登录的实现[/b:804aea7097]
    5 e( M7 ^' [  _  I! T. W
    0 Z) p" I3 I0 W8 q; P- V启动级别为3时自动登录的实现涉及两个软件包:mingetty-1.00-3.src.rpm软件包及util-linux-2.11r-10.src.rpm软件包。 ' c! f" ]2 i; O  Q0 d5 q& g
    & d: c1 Q0 T3 F* T( ^
    (1)mingetty-1.00-3.src.rpm软件包  
    - o' F! c7 t+ U# M1 v6 r5 }对于启动级别为3的自动登录的实现,仍然需要考察/etc/inittab脚本,  
    ( q/ ^- |' C9 b8 Z4 Z0 F3:123:respawn:/sbin/mingetty tty3 5 s1 \2 T, Q' k5 r2 \7 H# Y( ^
    ( B( h3 n) c4 }  Q7 \$ B! @- C2 O
    * W4 X$ @& H( U/ A3 D
      ' s; l/ k* O4 @( c

    4 y8 }& E5 r4 R; u* ?% Q' I3 I9 v- [4 r' h7 `/ S* ?8 t
    因此,如果想在启动级别3的情况下实现自动登录,必须要了解mingetty的功能,甚至要修改mingetty的代码。用命令rpm -qf /sbin/mingetty 可知redhat 8.0版本的mingetty包含在mingetty-1.00-3.src.rpm软件包中,下载该软件包,安装源代码,缺省情况下,代码会安装在/usr/src/redhat/下,我们关心的只是mingetty.c源文件。mingetty.c约有五百行代码,主要实现如下功能:
    & R: ^3 d# q8 M/ r* M. k- t, h. x3 d0 [% ?' L
    ( R5 v! y& E, b6 n
    打开指定的tty(由参数指定);  
    4 d5 S2 h# g0 O0 P: M  Q) F3 |提示用户登录(login:);  
    % ~6 @: l1 H3 G3 u获得登录用户名;  
    * Q5 [+ N$ Q9 w6 r7 M' O把用户登录名作为参数,调用/bin/login。  % ?' n) y0 f8 p) V/ W; G! e
    ) e5 r9 ~7 r% n7 W+ R
    我们所关心的部分实质上只有以下三行: ) J* d' F) `; }8 b) h

    0 m0 n( C& E' \( E/ j' s* g
    8 _/ [( n9 b' L... ... 3 A; ~! Z6 [6 b  W* e1 z
    438 while ((logname = get_logname ()) == 0); //mingetty.c文件438行 , x: n; P8 N$ c9 v$ ]: J
    439 execl (_PATH_LOGIN, _PATH_LOGIN, "--", logname, NULL); $ S$ b, n+ Y: k, f# E
    440 error ("%s: can't exec " _PATH_LOGIN ": %s", tty, sys_errlist[errno]); ; Y+ E0 C$ T7 R* Q. W  |6 t+ b! l
    ... ... . `. f2 U4 y* v$ j/ m5 r+ e

    # ^3 z2 v+ G2 s+ t! d  0 m9 m7 o& k1 w% D3 N0 `: V
      c) `8 m) ^) C5 R/ k) B* e  M; G
    第一行的功能是输出login提示,并获得用户输入的登录用户名,登录用户名由logname返回。因此,可作如下修改 " Z5 [/ w/ C5 ^% R' ~  w

    0 n# v! V1 n  P0 m4 O/ b- r
    ; ?) n' Q  z: P4 S% B... ...
    6 r" i0 n0 R7 O) E  n) S- p438 // while ((logname = get_logname ()) == 0); //注释掉本行,不再提示login:
    . ]0 J& \6 ~# X* B$ q& |1 E439 logname = "root"; //添加本行代码
    & A0 \. w  E2 W$ b% D& p440 execl (_PATH_LOGIN, _PATH_LOGIN, "--", logname, NULL); / i( S$ R" ]7 |1 l% {, t
    441 error ("%s: can't exec " _PATH_LOGIN ": %s", tty, sys_errlist[errno]); $ M) I/ Z6 Z0 L+ B) k+ k
    ... ...
    / D$ ^3 x4 H5 j; y+ m( m: {' s3 Z
    : _* U7 ?$ T. y' N/ g. E  R  
    * `5 ]2 u: ~; w. N: {& }1 Y
    * B' i. k$ L# [' Q注意,这里假定用户以超级用户身份登录。
    5 ~' Z& `  x& q) |3 [1 u# x5 x6 ~& b+ D) S
    第二行以用户登录名为参数,调用/bin/login程序,进一步实现登录。因此,要想实现自动登录,还应该了解/bin/login的功能,必要时还应修改其源代码。 4 e) B9 D5 l) I9 C
    2 \$ n* A; j. {. S& ]
    第三行为出错处理。
    % }. s0 E  _) B" g: \2 L# |1 C
    % c/ V8 A3 I( Q6 \. T" @2 E: p(2)util-linux-2.11r-10.src.rpm软件包  
    * K" [% a+ d8 N( c- l1 ~3 F5 V采用同样的方法,查看/bin/login所属软件包(redhad8.0版本的login包含在util-linux-2.11r-10.src.rpm软件包中),下载并安装util-linux-2.11r-10.src.rpm,login可执行文件有几个源文件编译而成,我们最关心的是login.c源文件(大约1500行的代码)。下面简要分析一下login要实现的功能,并对相应部分作必要的修改。 & x/ Q# Z5 ~0 Q8 _5 E6 m

    : }0 \- i' m+ B: Q4 y9 U# xLogin程序主要可以分为以下几个主要部分:
    ) V/ D9 l0 s3 D( U# q  U" p6 `- k/ J7 K9 ?
    1.Login首先检查登录者是否为超级用户,如果不是超级用户,并且存在/etc/nologin文件,则输出该文件内容,并中止登录过程;主要由checknologin()实现;  
    ; P. ~/ v0 a  o3 @/ t2 ^- {2.如果登录用户是超级用户,那么login必须在/etc/securetty/中指定的tty列表中实现登录,否则将导致登录失败。同样可以不指定/etc/securetty文件,此时,超级用户可以在任何tty上登录。  : t; `. e9 \. W, w6 J- l# N% x) l
    3.经过前两步测试后,login接下来将提示输入登录密码(由getpass()调用完成,有兴趣的读者可参考其手册页面),并进行验证,如果密码不对,则提示重新登录。  
    " T. U6 q4 Y, d4 C4.顺利经过密码验证后,login还将检查是否存在.hushlogin文件,如果该文件存在,则执行一次"quiet"登录(所谓的quiet登录指的是,登录时不再提示邮件mail,不再显示最后一次登录时间,不输出任何消息。启动级别为3时,正常情况下输出这些信息)  6 u3 @4 l, `0 w" `" h5 z
    5.login接下来设置登录tty的用户ID和组ID,并设置相应的环境变量,包括HOME、PATH、SHELL、TERM、LOGNAME等。对于普通用户来说,PATH缺省被设置成/usr/local/bin: /bin/usr/bin:;对于超级用户来说,PATH被设置成/sbin: /bin: /usr/sbin: /usr/bin:  ' p! `; n% Y6 R; `
    6.login的最后一步是为用户启动shell。如果在/etc/passwd中没有为用户指定shell,那么将使用/bin/sh,如果在/etc/passwd中没有给出当前工作目录,则使用"/"。  0 h0 P7 t$ Y) R" E4 q1 s0 Z
    至此,一个完整的登录过程就结束了。
    , j8 ^; _. U9 x( _: r$ ]7 L
    ( P$ V9 j- {2 I/ B从以上对login源程序分析过程中可发现,如果要实现自动登录,应该在第三步做文章,设法绕过提示输入密码以及对密码进行验证这一过程。实际上很简单,login源程序对是否要求输入密码设置了一个开关控制passwd_req,缺省情况下,其值为1(passwd_req = 1),即要求输入密码进行身份验证。把该行代码改为(passwd_req = 0)后,问题就解决了。即对源文件作如下修改即可:
    + |& b1 U+ i5 F0 [- J, ^8 @# [- t$ B$ I1 i6 [/ c
    : }6 x7 E8 j' t
    ... ... 5 Q% J  X) X& ~* B
    402 fflag = hflag = pflag = 0; //login.c文件402行
    ' K' _& t% B: e0 @403 //passwd_req = 1   //缺省时,要求进行密码验证,注释掉本行
    * F. I2 i0 K7 f404 passwd_req = 0 //添加本行 6 i* h$ T. Y7 V5 `
    ... ...
    ( {; p, V" F+ J3 s  ?! l- f
    . s7 Q1 D6 b) R  o  
    ) t! b2 j) v! K, K- g
    7 l0 _5 f3 e& g+ ^/ {3 J修改后,可以直接使用util-linux-2.11r-10.src.rpm提供的Makefile进行重新编译,也可以自己对其编译:
    0 I" W& l% E- r& }0 |1 L
    9 Z, I# l* r- E9 h& F6 }) w
    , n* v) w  @9 ^gcc -o login login.c setproctitle.c checktty.c xstrncpy.c -Wall -lcrypt注意包含后面的编译选项-lcrypt,否则会出问题。 8 _& A3 b" X. Q# r1 J* l+ g$ M( h
    5 j3 i/ s7 t: O# H
    8 {, ?3 v8 x9 A7 L- z
    有了新版的mingetty及login后,拷贝mingetty到/sbin/目录,拷贝login到/bin目录,并将/etc/inittab中的启动级别设置为3,再重新引导系统即可(读者可以自己写一个脚本实现上述过程)。
    0 N% {5 }3 o- k/ S
    % i3 v2 @; s* z如果读者对mingetty或login代码的其他部分感兴趣,可以反复修改login.c或mingetty.c的源代码,测试一下代码的功能,这里要注意的是,在拷贝新版mingetty和login之前,一定要把原来的mingetty和login备份,同时还要准备系统引导盘(有系统安装盘亦可,这样读者有机会键入linux rescue),在测试新版程序前更应如此,如果对代码修改稍有不当,系统将不能正常启动。 4 L7 |& K" M& j8 d

    8 a( h8 r% J1 M) i如果不想再作进一步的代码测试,只是按本文给出的方法进行代码修改,在系统启动上不会出现什么问题。
    . T5 C% K3 c  H) S2 b3 [; W! Z+ j0 d  i! T2 k9 X, ~, E/ `1 a2 n
    [b:804aea7097]二、自动登录后,自动运行特定的应用程序[/b:804aea7097] $ s3 r5 v# U- |
    ( H0 ?& S- I; ^0 K( [2 l
    在实现了启动级别3时的自动登录后,自动运行应用程序非常简单,把应用程序添加在/etc/rc.d/rc.local脚本中既可。(读者可以尝试一下把startx加入脚本中,看一看效果如何。在某种意义上,又增加了一种自动登录X window的方法)
    * M2 w/ u6 ]! I6 W( c
    ; b$ B9 P+ q- a- F2 B$ s/ B[b:804aea7097]三、对自动登录X window(系统启动级别为5),并自动运行指定的应用程序的补充[/b:804aea7097] ; T$ ?" h+ z, w. z. i) m# N
    " O2 O$ a% B5 l. a- q( @+ M; N5 Z' r6 o
    在"如何实现自动登录linux"中,主要以redhat 7.2平台为背景进行阐述的,其中的自动登录部分可以直接用于redhat 8.0中,不需要任何修改。
    3 Z6 Z8 `; V! E; r3 r
    7 T- Q: r1 X- o) m# j6 R' a但是,登录后自动运行应用程序的接口在redhat 8.0中有所不同,主要是登录gnome后,自动运行应用程序的接口有所改变:首先点击面板上的GNOME帮助(那个红色的小帽子),然后选择/其它/首选项/Sessions,在Session对话框的启动程序属性页中添加要启动的程序即可。
    1 o2 E! k6 t- q3 Q: ]& ^$ I5 f* X
    & \" L/ W# }8 V. }7 s对于登录kde后,自动运行程序的接口没有改变。 . R# |, g& }3 \4 l$ x1 Z6 W
    7 g# ?/ _8 q; O! A  t) E
    [b:804aea7097]四、结论[/b:804aea7097] 3 x. J; n. j' L3 [+ _
    - R1 L  F7 E7 w2 \% Z9 z
    本文同"如何实现自动登录linux"一文,基本上解决了如何实现自动登录Linux,并自动运行相应应用程序的问题。对于两个最常见的启动级别(3、5),都给出了各自的方法。 ) t4 r4 e+ t2 u/ V' {

    7 d; V( v" p6 S+ @在系统初始化到mingetty及login这一阶段,内核实际上已经完成了引导过程,已经到了系统初始化的最高阶段,与内核没什么关系了。此时,主要是/sbin/init根据/etc/inittab的内容而相机行事。读者可通过(man 8 init)或者(man 5 inittab)了解更多东西。 6 G! j' c! l7 \0 b+ W3 |9 Y
    & S: O* E, J( N  b
    在对文中提到的软件包修改时,请遵守GNU General Public License(GPL)相关标准,另外,替换login通常被视为黑客行为,应当谨慎行事。 ) S0 c5 Q: U# {! t4 L
    ; `  P7 j) Z7 V# D& h' ~  h9 k

    & R0 L4 |% m) B6 `) c: j" ]% ]- F5 y9 A; c5 x- g
    [b:804aea7097]参考文献[/b:804aea7097]
    : b" }& Q$ G. s' C# [
    8 ]/ E, [6 p- `0 R2 }
    0 ^- `0 u1 w4 E& U1.login手册页面  6 B9 n  i3 k, A$ K7 K
    2.mingetty-1.00-3.src.rpm,在redhat 8.0的发行版本的源代码中,包含该软件包;  
    . n! c/ l7 l' h' G% z3.util-linux-2.11r-10.src.rpm,  
    5 |: Y7 Y+ o: V
    % V* \1 q7 X: N% ~可在http://rpmfind.net/linux/RPM/redhat/8.0/i386/util-linux-2.11r-10.i386.html处下载,注意下载源代码包(..src.rpm)
    9 {; `" |2 @* R. \( O4 l- i  F0 P* j1 O
    [b:804aea7097]关于作者[/b:804aea7097]  " I: L" {+ ?! o& c( u  `# r  U

    * Z% X1 ?8 ~  \( R  `4 ]郑彦兴,男,现攻读国防科大计算机学院博士学位。您可以通过电子邮件 mlinux@163.com和他联系
      a, d2 T, f/ h, S1 C/ O. f* Q% Z8 `9 z: p  g( T
    </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) 9 Z! c% m) I: _/ o1 y  X% C. j

    ( @# d3 u8 {* R% ]机自动登录linux,并自动运行X window应用程序,有其特殊的应用背景,如基于linux平台的监控系统,linux启动后不需要身份验证,而直接运行监控程序等等。本文以Redhat7.2为平台,结合linux启动过程,介绍了如何避免身份验证自动登录,并直接进入X window自动运行应用程序。 6 S6 J- E! u, j+ G( I0 {" K
    一、linux启动的最后阶段的工作 , N2 L5 k, n" g* s( T# I

    % T+ k, |0 i: l1 Alinux 在启动过程的最后阶段(具体启动步骤略),init 会根据 /etc/inittab文件的最后一行x:5:respawn:/etc/X11/prefdm -nodaemon运行/etc/X11/prefdm脚本,(Red hat 7.2缺省时是这样的)。prefdm脚本的主要任务是完成X window的启动,可以有几种启动X window的方法,都包含在prefdm脚本中,几种主要方法有:
    & i4 A( u& f4 w. i# W6 C4 G2 |! K7 O. E
    运行xdm启动X window;  
    ) _$ N* o8 F+ h$ V+ l, X运行gdm,进入gnome桌面环境;  
    6 [& i- c( {& G+ b; m' h2 T! N7 v运行kdm进入kde桌面环境;  0 S6 S: F5 y7 D& H$ G0 _: r1 O, f
    自动登录进入linux;  , j2 S# ~8 F3 P7 e& X
    prefdm脚本框架大致如下: ; O7 H: q" @  w$ r: U4 a
    ) R4 t" X2 [6 Y
    #!/bin/sh ' z' C7 Y: }7 Y. a5 j; A
    PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin
    8 V% D& [, w8 Y0 X2 Q6 l) Y( w; @( U. /etc/profile.d/lang.sh
    ! f0 U* j4 z& L' {7 w1 X: o# 第一步:查看是否为自动登录
      ?. T  @5 D: p) D1 V4 jif [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then   |! I( N# k. [' a/ ]5 c1 e
    if /usr/sbin/autologin; then 1 p# Q% l6 P; `) U( U' S3 U$ m
    exit 0 , c# z' J) `2 A$ m" z3 l  p7 l- y
    fi
    , P4 W: X) V( T; @( [( U" lfi
    5 T( Q7 J6 h' B. o
    ( q0 a6 u* u$ B$ G$ \" a0 F# 第二步:如果不是自动登录方式,就会在/etc/sysconfig/desktop中搜寻用户偏爱的登录方式 * ?" G( Y( k* a9 O
    ......
    & C, {& b! B* {0 O* E: J, |# 可以是kdm、gdm以及xdm,并运行相应的kdm、gdm以及xdm。 ! w0 T  ]0 F) [
    ......
    4 T" r1 i$ b, p! i' z+ D' Q- a. \  Q3 h9 w4 e% r
      
    , ~, F: d3 @7 b# L( H: f! c+ B2 x6 r$ P4 b

    0 X/ i" }2 s+ T. {  B4 W. P二、自动登录的实现(autologin的实现) . p* B! i3 }8 k9 d& o# Q
    / J$ Q" l, D/ Q% \# v4 W
    在/etc/X11/prefdm脚本中,是否实现自动登录有一个条件测试开关,事实上,可以在这里注释掉测试开关,直接执行启动X window的操作。
    1 _5 {" m. N2 |; Y# u7 Q
    1 e$ z8 i5 [. Y- J自动登录实质上就是绕过身份验证,直接启动X window。X window的启动可以由xinit来完成。
    - d2 ^/ W/ t2 |, p8 u( N" {( k6 p$ p% _: m9 X) ]& p3 f
    Xinit用来启动X window系统服务器以及系统上的第一个客户程序,可以通过为xinit传递命令行参数的形式指定要启动的服务器及客户程序。如果不传递参数给xinit,它将在用户的根目录下寻找并运行 .xinitrc脚本来启动客户程序;在用户的根目录下寻找并运行 .xserverrc脚本来启动服务器。如果xinit在用户的根目录下找不到.xinitrc、.xserverrc,xinit将使用缺省的X :0。  ' l% a7 `3 g$ l, M
    实际上,用startx来启动X更为方便。对于运行单一会话的X window 系统,startx提供了更为良好的用户接口。同样,startx首先在用户的根目录下寻找 .xinitrc及.xserverrc脚本,如果找不到这两个脚本,startx将使用/etc/X11/xinit/xinitrc以及/etc/X11/xinit/xserverrc脚本。  
    6 T% u- |$ P  S( O- @' t! fstartx脚本的最基本框架是: 1 k8 U% n9 m% ?! j1 |
    7 i$ `% o( O5 z7 T8 C
    a、 寻找.xinitrc,如果没有则使用xinitrc;
    6 s1 i! ^% k- H" ?( b; Lb、 寻找.xserverrc,如果没有则使用xserverrc;
    & D) Q+ b& E' v$ ?5 h$ v1 vc、 根据找到的脚本确定xinit的参数; - {) p* F9 M! c1 n( ^# r

    ; x, d& G+ {; W3 P6 v) s* s由此可看出,startx在不需要传递任何参数的情况下,可以完成启动X的任务,因此,可以如下修改/etc/X11/prefdm脚本来实现自动登录:
    0 C  ~) B5 E0 o& N* n/ h4 Z# L$ L# _0 i( C/ H! Q
    : }" b) K' {$ e2 t
    #!/bin/sh 0 d. p  m! ~. |
    PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin ' `& X% P) t- D+ i* e9 \
    . /etc/profile.d/lang.sh ' F- c. f3 e9 A7 l8 Q6 D0 h
    # 第一步:查看是否为自动登录 8 G$ n4 A: p* A8 g# p8 r1 Z
    #if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
    " x8 c! ~% I% `) S! ^2 \#注释掉上边的条件测试,直接运行startx % p- e  u; Y1 t" ~
    if /usr/X11R6/bin/startx; then / E. D5 g) A/ j' Y/ Q8 K
    exit 0 3 L$ |* K- J% f3 s6 _: v
    fi $ F; w; c6 T! B, f2 u# b4 Z
    #fi
    : Q$ \+ z9 p$ j  C0 Z7 g$ ]
    5 T: u( v1 R6 }/ h0 h, @/ k  
    - U( @, D& L* B2 ^
    / A3 |9 J% K' J4 U; T5 s4 a& N- H: J6 _0 j2 B
    当然,应确保/etc/inittab中的启动级别为5。
    ( N9 R0 F9 a! u
    ; e0 Q1 L" A8 A) l2 P, G# X重新启动系统,会发现系统不验证用户身份,直接进入X window,此时的用户身份为root。但是,如果原来root有自己的桌面、默认shell时,上述方法启动X不一定保证还能拥有原来的设置。为了在启动X后,在避免验证身份的同时,又不改变用户原来的设置,那么在运行startx之前,还有工作要做。 3 I) O, k- `# N5 @& b

    * n9 ~# v( }$ r  n, m三、自动登录后,保持用户原来的配置(桌面、shell以及其它的一些环境变量)。 " U6 K: B  K( b* z0 J

    ; Q+ B5 x7 B  Y观察原来/etc/X11/prefdm脚本的自动登录部分:
    - J. S9 B) N2 C) {  R. s
    * F6 F) G. `6 C+ o7 i" o# k* {& i% Y% Q
    ...... & `& ]  n0 r" k& C; J
    # 第一步:查看是否为自动登录
    ! m0 z1 \; Z: `9 o9 y6 @2 ?if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then 5 q, g9 Z  t% v5 Y& {9 y2 x5 D  ^
    if /usr/sbin/autologin; then
    2 `. P; U! M5 O7 K* l) u1 lexit 0
    / X$ D( J* w& O# Y% S8 Hfi + b0 X: K& Z/ K1 K6 s. H1 j
    fi
    + k7 ~( d  E9 c* R3 w" P......
    9 @, ~' x0 v/ H8 ]3 t% D7 @+ g
    + T& Y" z  `! y; v8 J5 ?  
    3 J( Z( J- ^6 \# d4 O5 l2 C, w
    " L2 }$ G; g: O8 O
    ; r1 y1 y# O; S3 j9 o0 z不难看出,脚本中保留了自动登录的接口:一个可执行文件/usr/sbin/autologin以及一个配置文件/etc/sysconfig/autologin。
    6 G% r# U9 I# }+ Q( G, Y* t0 \
    ( T2 a# y8 p, q8 u  P5 P& N1、/etc/sysconfig/autologin配置文件的实现: 5 m$ M5 E6 J2 I" w1 j

    + O9 f* u) o) R* [
    ( Y" E9 N- r5 r. M#config for autologin 8 C( H2 p6 |9 v7 M( h
    USER=root
    % Z6 f" p3 U6 ^; cEXEC=/usr/X11R6/bin/startx
    4 i2 G" w7 e( r+ c; ?) D说明,USER指定自动登录时的用户名;EXEC指定启动X要运行的程序。 # W. A8 n$ F- k8 u) n) d4 r

    2 r0 @6 O' b9 m. v! F  
    - D& A( D: ~$ P$ e+ g; g
    ' I1 B9 `; v5 R, y. P
    ( {' M* e9 P# L0 c# L4 f2、/usr/sbin/autologin可执行文件的实现:
    2 M- l! k3 F1 a  k7 d% f3 ?# [# C7 a( C, _5 j

    8 ?5 _' E6 L& _1 V; J2 R& u/*********************
    ( j/ [  V2 p1 E' X! |. n; m, r****  autologin.c  ****
    / X+ S* o1 I" g: P*********************/
      L7 b% v8 g1 h* j7 R#include &lt;stdio.h&gt; 0 ]5 p7 t; _. t- K: b6 h6 C
    #include &lt;unistd.h&gt;
    ( i+ x2 {0 j( ]7 F2 b9 m#include &lt;string.h&gt;
    ' y+ G; ~0 T0 C9 W#include &lt;errno.h&gt; $ e- n" _) o+ c! G% E+ O
    #include &lt;sys/types.h&gt; ( V/ v! ]- ?9 u% V. E
    #include &lt;sys/stat.h&gt;
    # R3 A; ], |' j/ T6 D1 \) a8 u#include &lt;pwd.h&gt; 8 {) L' h: n/ {/ r! M3 a
    5 r* m5 @- e2 n0 ?' E7 }' ^
    int main(int argc, char **argv)
    4 F% E" s3 D1 d- q5 V. o{ 4 H  o) e( o; @  t/ P* q/ ], u4 B% n
    struct stat st; & U/ o8 `' e7 f
    FILE *f;
    , {5 V& n8 d+ ychar *cfg; , c( b1 c( v7 x. y  T
    struct passwd *pw; * h3 u( @+ Y6 I$ k( r+ N
    uid_t uid;
    - a* [) k# l) tgid_t gid; : A; ^  _/ ^; _) I
    char *dir, *shell; 4 b5 x+ _% v; M9 h) ?
    char *user=NULL;
    1 }; [" ~! _& ?2 v/ m& Xchar *cmd=NULL; 2 i0 {/ ^) Y( d) M% p

    " U$ K1 G" K0 W) r# [: \7 {user="root";
    7 P' k( V: A1 ]+ b/*为了能说明问题又保持程序简洁,这里默认登录用户为root,实际上, # {( \1 r) e; e3 E4 f
    登陆用户名应该从/etc/sysconfig/autologin中得到,
    3 k4 r" L9 I+ A/ j* F7 b4 h2 V程序实现时要注意过滤掉/etc/sysconfig/autologin中的无效用户名*/ - e5 O& }3 G" U( q8 f: S- k+ i
    cmd="/usr/X11R6/bin/startx"; 2 d; |9 R5 E: t/ Z7 h
    /*同样,这里直接指定启动X window的程序,实际上,该程序应该从/etc/sysconfig/autologin中得到*/
    5 }6 S$ B& n) @4 z. E4 J
    ( w& T! U' Y4 }7 `" H4 S8 gpw = getpwnam(user);
    # |2 U$ I) C( k0 G7 d, y: T) A//getpwnam返回包含用户信息的passwd结构(该结构在pwd.h中定义)。 1 u2 e9 {7 |2 X+ o: {9 h3 C! Q. C
    if(pw) {
    0 S/ i! \, N* u1 f! U5 Q; j) E* ouid=pw-&gt;pw_uid; 9 |: q% _6 K3 i
    gid=pw-&gt;pw_gid; dir=strdup(pw-&gt;pw_dir); 3 Z1 U; A8 m2 c. Y! T! ~
    shell=strdup(pw-&gt;pw_shell);
    1 L2 S; p/ @$ ?0 s6 D  L' `}
    5 |; j5 u9 O  [  R% Q  e+ J//获得用户相关信息 & l. F8 B6 C: }/ v0 G7 k1 G+ `  ?7 G
    else {
    " y/ O( n7 K- K! ^, xprintf("ERROR: No such user %s!\n", user); 0 K3 ~$ X9 ~: s9 x
    return 1; 1 V7 N4 d) {- \0 {- w2 p9 K
    } ! }: I1 @- U3 u

    8 W# ^+ i/ D' tchown("/dev/console", uid, gid);
    3 l) k9 L& Y# H! T; I# Q0 echown("/dev/tty", uid, gid);
    6 C: n1 A! W4 `//为控制台和终端设置用户ID及组ID , x5 r& I/ ~! A8 a( _
    % K- }  K4 O0 H7 R( x  B
    //下面是设置用户相关ID
    2 [5 A7 U" W, E9 F6 P: h, Tsetregid(gid, gid);
    ( _# P0 ?2 D/ Q& _setegid(gid); - K8 u2 j$ ]9 D! u5 Q; K
    setgid(gid); & ^% D! ~/ ?! b% N+ B. z
    setreuid(uid, uid);
    3 e" `2 v; ^! P+ R9 H  j$ {seteuid(uid);
    : A" ^. |% K& R$ n8 A! z, g! U5 Ysetuid(uid);
    $ _& ]! t* G4 \0 G5 C5 S' i9 J
    ' D3 \- A( |1 v) ]# W/ jsetenv("HOME", dir, 1); ! Z( ]% W3 i  L$ I" E" w4 @' x" K
    setenv("SHELL", shell, 1); ) j( n. ]9 ~1 k! R
    setenv("USER", user, 1); : o  Z' {' c7 ~+ ^6 P
    setenv("LOGNAME", user, 1);
    : X1 Q( `  ?) l9 p+ q( Y//设置用户相关环境变量 8 C% i0 M8 R4 x  _* F0 a, f
    # c1 u1 w: E* e; k" T" n& j
    chdir(dir);
    4 Y( x- x' g- c6 G2 V//切换到用户根目录
    # [) ~5 O) e+ ?  D) A7 g9 G9 Cuser=NULL; - \* p( g8 Z6 z8 f% {, p/ i7 s2 c8 }

    , g; B: C5 W' g3 `( l: lexecvp(cmd, argv);
    1 c% y# z1 R$ ^7 p( N: n/*在配置完用户的相关信息后,执行启动X window操作。注意这里默认执行/usr/X11R6/bin/startx */
    $ W0 D& s6 N$ o: ^% ^printf("ERROR: Couldn't exec %s: %s\n", cmd, strerror(errno)); & ~; X$ c7 F! S- e; P* R2 G
    return 2; & m# z6 l2 h; r; G  l8 a) v" H) I  E
    } 8 d! r; i" s6 ?3 |

    7 Q+ a; W# H# d+ y) h  . D5 s; }! w/ C: n% z7 [$ G( G
    : ]4 `& V. |2 m0 ~2 v

    4 C/ n8 J' R1 C/ E3 O运行gcc -o autologin autologin.c,拷贝autologin可执行文件到/usr/sbin/autologin,拷贝autologin配置文件到/etc/sysconfig/autologin。 重新启动系统,会直接进入X window并保留用户原来所有的风格。
    ( |, V* _  O( K- ]8 @8 u! ]. o, ^
    1 Z" Q8 F/ x- I5 i6 x如果不需要自动登录的配置文件/etc/sysconfig/autologin,所有的操作都在/usr/sbin/autologin以默认的方式实现(比如,默认登录身份为root,默认执行操作为/usr/X11R6/bin/startx等),那么,/etc/X11/prefdm脚本的自动登录部分可简化如下:
    " ^/ \" [! u2 Y5 Q- V- X2 x
    ) \. r5 O. k) `4 I' k( K0 b
    : f; J. W1 R! ^+ Q$ V# Z+ c+ d( T( |...... ; }4 |  N, x) x/ R/ ]& e% a" ]6 f% |
    # 第一步:查看是否为自动登录 ! O1 y8 ]+ T5 m& ?$ Y
    if /usr/sbin/autologin; then 8 @7 w6 L1 ^# `9 C, K0 {
    exit 0 " A' g. ]; _& m& W9 C
    fi
    , u: ]1 R: I+ J, R( O0 y//第二步 ......
    ' E; L& L# X$ E1 S* N+ @......
    7 H5 `. v+ A! N! F% {: o
      `& B9 \3 ?% O  3 K0 r; Z2 x4 C* r
    " B" F) e2 [+ L$ E8 X5 n

    3 M, g+ p3 f- v1 J即在脚本中去掉条件测试开关,直接执行/usr/sbin/autologin,这时,只需要拷贝autologin可执行文件到/usr/sbin/autologin,不再需要拷贝autologin配置文件到/etc/sysconfig/autologin。 ) f  e, k- m5 A* r
    : i% W% Y" k  b
    四、选择进入kde或者gnome,并自动启动X window应用程序
    : O, T6 i0 s- _6 m! @4 `5 r+ w# A5 H1 \+ N/ m7 X3 M
    如果重新启动后系统进入了kde,而用户需要进入gnome,只需运行switchdesk gnome在重新启动系统即可,以后每次启动时会自动进入gnome;反之亦然。  
    2 v/ _# Z9 {4 u1 i0 m0 U2 C7 A' w4 ^4 S一般系统自动登录的目的是启动X window 后自动运行某个X window程序。如果系统默认的启动级别为3,那么如果要在系统启动后自动运行某些应用程序,只需要在某些脚本中加入相应命令即可,不再详述。在X window启动后自动运行应用程序要复杂一些,幸好,kde和gnome都为此留下了自动启动接口。如果在kde桌面环境下自动启动应用程序,只需要把应用程序名字加入/root/.kde/Autostart/目录下即可(这里注意不同用户的根目录可能不同,如用户zyx的根目录可能为/home/zyx)。如果在gnome桌面环境下自动启动应用程序,只需把应用程序的名字加入/主菜单/程序/设置/会话/会话特性及启动程序的startup programs属性页中即可。  
    3 o+ x+ d8 p# m7 I+ |! a3 H1 z; d' `. J( ?" R
    8 F- T% |! N" y1 A3 k+ X
    http://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, 2025-8-19 07:14 , Processed in 0.929347 second(s), 56 queries .

    回顶部