QQ登录

只需要一步,快速开始

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

如何自动登录linux[转载]

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

1253

主题

443

听众

-516

积分

复兴中华数学头子

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

    [LV.2]偶尔看看I

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

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

    群组越狱吧

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

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

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

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

    跳转到指定楼层
    1#
    发表于 2004-9-27 14:26 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta |邮箱已经成功绑定
    <>如何自动登录linux[转载]</P>, K; x0 t- |' X! Y+ H
    <>本文以redhat 8.0操作系统平台为背景,阐述如何实现启动级别为3时的自动登录,及自动运行相应程序,并简要介绍了如何在redhat 8.0下自动登录X window(系统启动级别为5),并自动运行指定的应用程序。 : @4 x  ^) q: V. \4 v
    [b:804aea7097]一、启动级别为3时自动登录的实现[/b:804aea7097] & i' @% [1 `1 E0 X- M! X" g/ i

    2 g" [6 B. t" d% \# I& a+ m启动级别为3时自动登录的实现涉及两个软件包:mingetty-1.00-3.src.rpm软件包及util-linux-2.11r-10.src.rpm软件包。 # P* Y) D/ [$ c- F' ?# L" S5 z) w
    # ^7 K" F$ g/ N5 c5 r
    (1)mingetty-1.00-3.src.rpm软件包  
    / n* O1 j2 m; a+ R' h1 M5 f对于启动级别为3的自动登录的实现,仍然需要考察/etc/inittab脚本,  % X* V. o0 O9 O1 J
    3:123:respawn:/sbin/mingetty tty3
    0 F5 J  E; J! S: _% i5 h2 D3 R7 F% g" ~1 r& l# M
    : c+ V' B: o% Q' c
      + E( N( @) |7 W5 `- [) K

    1 S/ g0 }( H' _# i4 p2 x0 ^8 V4 {8 G! y) y+ t: U
    因此,如果想在启动级别3的情况下实现自动登录,必须要了解mingetty的功能,甚至要修改mingetty的代码。用命令rpm -qf /sbin/mingetty 可知redhat 8.0版本的mingetty包含在mingetty-1.00-3.src.rpm软件包中,下载该软件包,安装源代码,缺省情况下,代码会安装在/usr/src/redhat/下,我们关心的只是mingetty.c源文件。mingetty.c约有五百行代码,主要实现如下功能:
    4 t% @  u8 p3 a6 z3 H( i8 q4 a
    # n, Z) Z0 L7 o- S- x+ r7 v/ f4 H' `* Q$ Z' i
    打开指定的tty(由参数指定);  9 o+ H! F4 c7 n7 @- `; n
    提示用户登录(login:);  + Z- e7 ]! B( z2 D8 F$ b) h% Q- Z
    获得登录用户名;  5 D! I' d- ?4 z3 i# M
    把用户登录名作为参数,调用/bin/login。  0 f% F/ _0 x8 R2 q

    / R( h+ G' a; t1 a' S" ~4 O" n我们所关心的部分实质上只有以下三行:
    / T5 C4 `' n; V4 h8 i, Q- L6 F/ f" Y0 a, D4 C; v- N
    9 ~! q8 @6 [! D, {1 X& h. H4 n% ^
    ... ...
    % q) k, p3 o; D  x( V438 while ((logname = get_logname ()) == 0); //mingetty.c文件438行 , H& |7 X9 y; N$ K! R5 _
    439 execl (_PATH_LOGIN, _PATH_LOGIN, "--", logname, NULL); 8 ]' S& E/ |5 ^, k
    440 error ("%s: can't exec " _PATH_LOGIN ": %s", tty, sys_errlist[errno]); ( i; S  L, x6 Z6 {
    ... ...
    8 Y2 `4 D! \( F/ ^5 s1 g) d8 W! K6 y$ M6 E1 {: Y- ?
      9 X2 t7 V7 }6 F3 E( C
    6 \, r# K7 Z6 J" ?# n
    第一行的功能是输出login提示,并获得用户输入的登录用户名,登录用户名由logname返回。因此,可作如下修改 ( y* {/ ]5 T' H' Z2 c
    ' a; o$ A, W2 P) M

    3 u5 }8 [' q& c. k$ \... ... " R* {2 e8 w  R/ Z! `" M! E, ~
    438 // while ((logname = get_logname ()) == 0); //注释掉本行,不再提示login: 0 l, O3 H% y; P
    439 logname = "root"; //添加本行代码
    . T8 B. r: y8 u6 n7 C$ \2 g$ K5 L- y440 execl (_PATH_LOGIN, _PATH_LOGIN, "--", logname, NULL);
    " Z  E& r$ `( p" c) y441 error ("%s: can't exec " _PATH_LOGIN ": %s", tty, sys_errlist[errno]);
    - [8 J4 f& `/ J5 H... ... $ ~1 E3 A( c/ s+ N# F: X, Y. V. ?
    9 y9 G: m) s3 X0 p; P- M
      
    0 }0 k+ X$ _4 D+ @2 T8 a9 m6 K" ~  @2 y/ u( \3 n: a: A$ H
    注意,这里假定用户以超级用户身份登录。
    ; s9 H4 P$ r. {  R' t' s: _# Y3 t; P
    第二行以用户登录名为参数,调用/bin/login程序,进一步实现登录。因此,要想实现自动登录,还应该了解/bin/login的功能,必要时还应修改其源代码。 ) A( B( N/ \* K4 ?2 S  k5 z1 j- A
    + ?' b8 Y% k$ e( j# R
    第三行为出错处理。
    . I2 s" {8 g( {; g! D% _& E( r4 n
    - S: ~2 [1 i2 D" K6 F* O2 g(2)util-linux-2.11r-10.src.rpm软件包  
    & |* x6 C; N' l# W# F+ x0 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要实现的功能,并对相应部分作必要的修改。 6 j  q1 j+ O( x- z2 z: J( F, D

    # E7 G  ]4 a9 rLogin程序主要可以分为以下几个主要部分:
    ' m. U0 e$ r0 X3 e1 x1 \) l& ~, g$ R) i$ C0 [+ R, c# o" s& ?
    1.Login首先检查登录者是否为超级用户,如果不是超级用户,并且存在/etc/nologin文件,则输出该文件内容,并中止登录过程;主要由checknologin()实现;  ) B% P9 P; q. c0 ^- T
    2.如果登录用户是超级用户,那么login必须在/etc/securetty/中指定的tty列表中实现登录,否则将导致登录失败。同样可以不指定/etc/securetty文件,此时,超级用户可以在任何tty上登录。  
    ' I$ g7 H2 A* ]5 i3.经过前两步测试后,login接下来将提示输入登录密码(由getpass()调用完成,有兴趣的读者可参考其手册页面),并进行验证,如果密码不对,则提示重新登录。  
    4 f/ x" |8 e8 Y. D4.顺利经过密码验证后,login还将检查是否存在.hushlogin文件,如果该文件存在,则执行一次"quiet"登录(所谓的quiet登录指的是,登录时不再提示邮件mail,不再显示最后一次登录时间,不输出任何消息。启动级别为3时,正常情况下输出这些信息)  * I4 L# @* u, `+ g) Z0 E2 S9 F
    5.login接下来设置登录tty的用户ID和组ID,并设置相应的环境变量,包括HOME、PATH、SHELL、TERM、LOGNAME等。对于普通用户来说,PATH缺省被设置成/usr/local/bin: /bin/usr/bin:;对于超级用户来说,PATH被设置成/sbin: /bin: /usr/sbin: /usr/bin:  . \: c5 u) }  ?2 F' i* s
    6.login的最后一步是为用户启动shell。如果在/etc/passwd中没有为用户指定shell,那么将使用/bin/sh,如果在/etc/passwd中没有给出当前工作目录,则使用"/"。  
    + o! T1 _# _; ^! I- \+ ?至此,一个完整的登录过程就结束了。
    + g( ], ]. C) [* l5 Y) F! [1 J9 x, v$ g/ m3 s! c3 ~
    从以上对login源程序分析过程中可发现,如果要实现自动登录,应该在第三步做文章,设法绕过提示输入密码以及对密码进行验证这一过程。实际上很简单,login源程序对是否要求输入密码设置了一个开关控制passwd_req,缺省情况下,其值为1(passwd_req = 1),即要求输入密码进行身份验证。把该行代码改为(passwd_req = 0)后,问题就解决了。即对源文件作如下修改即可: . M5 O% s7 J3 N! ^8 {
      K& F5 E- R0 z1 K  ?
    ( T- U- ^( ]  H, b% g/ ^. F0 S! ^& [. S
    ... ...
    1 M" h; A% W2 v  y: y2 D402 fflag = hflag = pflag = 0; //login.c文件402行
    - H. ~2 k  z: A; Q! e9 p403 //passwd_req = 1   //缺省时,要求进行密码验证,注释掉本行 7 q. t3 \3 O+ c; G
    404 passwd_req = 0 //添加本行
    , |$ @2 ]6 R) X8 u% r8 L( g... ... 6 W/ t1 O& K  X2 F/ ^) }- L
    $ V" O( h  ~* V/ E
      ) \) V$ z/ P& u. M, Y& N
    % u) X0 E2 o$ h5 W# H
    修改后,可以直接使用util-linux-2.11r-10.src.rpm提供的Makefile进行重新编译,也可以自己对其编译:
    9 F- m: S- X" H( ^3 Y6 a
    6 X9 t2 i2 i, B) C+ h, d, [0 x
    ! V( {) d7 Y+ @7 a1 Tgcc -o login login.c setproctitle.c checktty.c xstrncpy.c -Wall -lcrypt注意包含后面的编译选项-lcrypt,否则会出问题。 6 L, q/ p7 R( s# b( s
    0 n* q3 y/ K# i" F& \
    1 M! C, H0 C: J/ x
    有了新版的mingetty及login后,拷贝mingetty到/sbin/目录,拷贝login到/bin目录,并将/etc/inittab中的启动级别设置为3,再重新引导系统即可(读者可以自己写一个脚本实现上述过程)。
    # y* i3 g1 U/ p: j( {3 S4 W& R* T/ u: F
    如果读者对mingetty或login代码的其他部分感兴趣,可以反复修改login.c或mingetty.c的源代码,测试一下代码的功能,这里要注意的是,在拷贝新版mingetty和login之前,一定要把原来的mingetty和login备份,同时还要准备系统引导盘(有系统安装盘亦可,这样读者有机会键入linux rescue),在测试新版程序前更应如此,如果对代码修改稍有不当,系统将不能正常启动。 3 l( @$ V9 w& B6 N+ G
    ; O. Q1 W( Q5 v* q, t' z
    如果不想再作进一步的代码测试,只是按本文给出的方法进行代码修改,在系统启动上不会出现什么问题。 $ A* n; p: ^6 F! k0 [6 i0 \
    ( }4 D( V# J: Q8 ^. v
    [b:804aea7097]二、自动登录后,自动运行特定的应用程序[/b:804aea7097] 2 @+ k& S( f' D0 p4 t* b4 Y; A

    ' U' H7 L) ]) ~: T. S4 J在实现了启动级别3时的自动登录后,自动运行应用程序非常简单,把应用程序添加在/etc/rc.d/rc.local脚本中既可。(读者可以尝试一下把startx加入脚本中,看一看效果如何。在某种意义上,又增加了一种自动登录X window的方法) 9 ]; U1 o0 E2 W

    ) Z9 }( C- x% Q2 y7 n) ?[b:804aea7097]三、对自动登录X window(系统启动级别为5),并自动运行指定的应用程序的补充[/b:804aea7097] % u; v2 v  _5 m; O9 q
    2 ?- J. d+ P6 S7 y  ^
    在"如何实现自动登录linux"中,主要以redhat 7.2平台为背景进行阐述的,其中的自动登录部分可以直接用于redhat 8.0中,不需要任何修改。 8 H+ L* _/ I5 a2 s' w$ J' C. |
    + S. p! N3 P9 {+ b  c
    但是,登录后自动运行应用程序的接口在redhat 8.0中有所不同,主要是登录gnome后,自动运行应用程序的接口有所改变:首先点击面板上的GNOME帮助(那个红色的小帽子),然后选择/其它/首选项/Sessions,在Session对话框的启动程序属性页中添加要启动的程序即可。
      }  w( m9 J% }4 y, _# D
    + X. E. C# x% G, Q: G2 d$ k& y对于登录kde后,自动运行程序的接口没有改变。
    ) b+ `' N7 Y& ^% n0 U3 E% I! p" @$ b' w8 ^3 p: s: Y7 a7 ]
    [b:804aea7097]四、结论[/b:804aea7097]
    9 O( U9 N  u- a, n3 }" x8 g6 ]/ f2 E
    本文同"如何实现自动登录linux"一文,基本上解决了如何实现自动登录Linux,并自动运行相应应用程序的问题。对于两个最常见的启动级别(3、5),都给出了各自的方法。 $ e! g% H( H( Y. g3 ~
    8 `7 z, y, `; Y; q
    在系统初始化到mingetty及login这一阶段,内核实际上已经完成了引导过程,已经到了系统初始化的最高阶段,与内核没什么关系了。此时,主要是/sbin/init根据/etc/inittab的内容而相机行事。读者可通过(man 8 init)或者(man 5 inittab)了解更多东西。
    2 U- m( }) x: `2 X. s! g8 p4 ^/ w1 _: J
    在对文中提到的软件包修改时,请遵守GNU General Public License(GPL)相关标准,另外,替换login通常被视为黑客行为,应当谨慎行事。
    ( W' F( f# m# r" e" \
    0 U) a+ L& {6 g( c, C, z+ d
    + P/ R: Y4 L  k- @) q+ L
    % u: c1 Q* O4 ~! B[b:804aea7097]参考文献[/b:804aea7097]
    * r% S; `! x- i! ?* w/ c6 @1 S1 o
    ' ?" X1 p2 s4 u0 k. h4 ?4 {0 a' Y- C- F% f
    1.login手册页面  
    " Y5 \- f* Z6 k! a2.mingetty-1.00-3.src.rpm,在redhat 8.0的发行版本的源代码中,包含该软件包;  
    4 `4 \! T& Z0 z0 R3.util-linux-2.11r-10.src.rpm,  
    8 `% n3 X: E- P4 h8 V! z2 h1 O  @# ~& \& p
    可在http://rpmfind.net/linux/RPM/redhat/8.0/i386/util-linux-2.11r-10.i386.html处下载,注意下载源代码包(..src.rpm) . {5 a, Y! n1 A* t4 m  a

    ; R$ `& T: W7 M- \" P2 ^8 D[b:804aea7097]关于作者[/b:804aea7097]  9 k5 x, b8 C4 @! E: [  o$ w
    3 ^1 m! n( r) t( q7 O
    郑彦兴,男,现攻读国防科大计算机学院博士学位。您可以通过电子邮件 mlinux@163.com和他联系1 N% T1 `3 T( L; o, k

    ! h5 _  |* x2 p* g& L( B+ _1 N8 ~2 r</P>
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    数学中国网站是以数学中国社区为主体的综合性学术社区,下分建模、编程、学术理论、工程应用等版块。从2003年11月建站以来一直致力于数学建模的普及和推广工作,目前已经发展成国内会员最多,资源最丰富,流量最大的数学建模网络平台。我们始终秉承服务大众的理念,坚持资源共享、共同进步的原则,努力营造出严肃、认真、务实、合作的学术氛围,为中国数学的发展做出应有的贡献。

    1253

    主题

    443

    听众

    -516

    积分

    复兴中华数学头子

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

    [LV.2]偶尔看看I

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

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

    群组越狱吧

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

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

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

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

    如何实现自动登录Linux (Runlevel 5)
    6 H# Z7 P) u/ M
    8 Q9 d3 y# m+ Z1 t0 D; z机自动登录linux,并自动运行X window应用程序,有其特殊的应用背景,如基于linux平台的监控系统,linux启动后不需要身份验证,而直接运行监控程序等等。本文以Redhat7.2为平台,结合linux启动过程,介绍了如何避免身份验证自动登录,并直接进入X window自动运行应用程序。
    $ B- U9 n0 h. H5 ~: ]* ?一、linux启动的最后阶段的工作 - B4 X% V2 N* H) L* B
    / E2 H" `, c; C* Y$ A
    linux 在启动过程的最后阶段(具体启动步骤略),init 会根据 /etc/inittab文件的最后一行x:5:respawn:/etc/X11/prefdm -nodaemon运行/etc/X11/prefdm脚本,(Red hat 7.2缺省时是这样的)。prefdm脚本的主要任务是完成X window的启动,可以有几种启动X window的方法,都包含在prefdm脚本中,几种主要方法有:
    : l. E0 y' ]( ^7 ?& Y4 z& i" X( M5 D. i: b
    运行xdm启动X window;  8 f9 k# f1 Q* ?& `
    运行gdm,进入gnome桌面环境;  ) [5 S, i& [6 S$ k# c
    运行kdm进入kde桌面环境;  $ C. k0 {- P- O( _5 ~4 F0 G/ B" ~
    自动登录进入linux;  7 q) W1 L4 L/ g% B6 [
    prefdm脚本框架大致如下: 9 h0 a$ p; K4 K9 E# O
    3 t5 Q* l' m6 @- x* M6 ~7 U& b
    #!/bin/sh
    " P+ K* [0 G; V/ ^  l. QPATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin 2 i' Y: Q8 R  M6 Q' ~
    . /etc/profile.d/lang.sh
    8 U& e/ H  I6 @" f* f# 第一步:查看是否为自动登录 2 Z. b8 E6 m9 H
    if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then 7 m# k. z7 \6 B# O, B' x: S
    if /usr/sbin/autologin; then / G* w3 ~5 V/ b  q6 X/ U7 I
    exit 0 2 Y8 j* D+ \/ g3 R  G9 [& H
    fi
    * M5 }1 e6 _+ Y3 Ufi
    ' s- |0 k. C6 C' q9 ]& X: d, j/ F, I2 {" U( @0 B
    # 第二步:如果不是自动登录方式,就会在/etc/sysconfig/desktop中搜寻用户偏爱的登录方式
    : E; o+ f5 K& |, U4 ^- r...... & |; A& e' j" p: f0 C$ g) m* W# [
    # 可以是kdm、gdm以及xdm,并运行相应的kdm、gdm以及xdm。 - X" u# Y& z6 M: W% |
    ...... $ ]/ s! E& l1 p, w# ]7 `4 o
    6 _+ v; k& M7 F4 _. e9 M
      
    - @6 m# x9 {8 r. p( @- ~, [, e7 Q6 p9 k7 U" j3 s# s

    ! W/ a0 A& j# y. [: Z8 n二、自动登录的实现(autologin的实现) * U; d6 M( r% C

    1 U: H% O; J4 z; h! @+ W: R在/etc/X11/prefdm脚本中,是否实现自动登录有一个条件测试开关,事实上,可以在这里注释掉测试开关,直接执行启动X window的操作。 ( `0 ]' W3 ?- J, e* T$ J0 M1 t
    , e* x9 U& A# \: R5 s5 z( }1 N
    自动登录实质上就是绕过身份验证,直接启动X window。X window的启动可以由xinit来完成。 2 u. f2 L0 k# V
    6 I6 I$ S& p* S( U8 I2 E& v
    Xinit用来启动X window系统服务器以及系统上的第一个客户程序,可以通过为xinit传递命令行参数的形式指定要启动的服务器及客户程序。如果不传递参数给xinit,它将在用户的根目录下寻找并运行 .xinitrc脚本来启动客户程序;在用户的根目录下寻找并运行 .xserverrc脚本来启动服务器。如果xinit在用户的根目录下找不到.xinitrc、.xserverrc,xinit将使用缺省的X :0。  
    5 \- }  Z6 e! {5 P& z  P实际上,用startx来启动X更为方便。对于运行单一会话的X window 系统,startx提供了更为良好的用户接口。同样,startx首先在用户的根目录下寻找 .xinitrc及.xserverrc脚本,如果找不到这两个脚本,startx将使用/etc/X11/xinit/xinitrc以及/etc/X11/xinit/xserverrc脚本。  5 |0 \: m4 D& ?  J- p! F
    startx脚本的最基本框架是:
    0 j( S1 S5 ~4 s9 t2 S4 f8 N
    5 r! d$ I# C7 A) n& R$ i0 Q  i3 Da、 寻找.xinitrc,如果没有则使用xinitrc; 0 f* S: ?+ g9 }5 L( z
    b、 寻找.xserverrc,如果没有则使用xserverrc; ! O2 g" j5 o- o
    c、 根据找到的脚本确定xinit的参数;
    $ Y& }& `. L1 J( \
    , C9 ?# Z( [- H9 r; f由此可看出,startx在不需要传递任何参数的情况下,可以完成启动X的任务,因此,可以如下修改/etc/X11/prefdm脚本来实现自动登录: 3 h2 b; U& X* U; ~. k' ?% l* N" x

    + A& w2 k5 D) u2 B& u( I' F3 W, T7 c
    0 y7 Y: N5 `* i' }- j#!/bin/sh 5 Z+ @& Q7 I5 ~6 a/ {( m9 L
    PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin 5 n/ f: H- ^. E, n$ I: P2 Z* ^
    . /etc/profile.d/lang.sh
    ! f0 p* H% J; u( W# 第一步:查看是否为自动登录
    5 f" r8 W/ r- \' e' J7 z#if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then 4 O* l3 w$ o! Y3 ^
    #注释掉上边的条件测试,直接运行startx 2 |9 I+ f7 k, ~0 y5 [. g
    if /usr/X11R6/bin/startx; then * D! D* t( \" v# U; S" c% l6 C9 @* L
    exit 0
    4 B8 D' m, a7 i. ~0 G. K5 ofi % M$ t* E/ L; u
    #fi + X! j4 m5 S5 m: M$ M

    / a7 ~+ b) k' h" V! |% s7 U/ }* `) x  
    1 x. U6 R5 P( h/ ^' T6 f" Q0 ~! I6 ~! T: I
    * O5 [2 f! U+ o: n( e9 P
    当然,应确保/etc/inittab中的启动级别为5。
    + V# E3 Q: J' R% O/ V6 H9 e
    3 Z" K1 H2 {* u9 [6 O$ D重新启动系统,会发现系统不验证用户身份,直接进入X window,此时的用户身份为root。但是,如果原来root有自己的桌面、默认shell时,上述方法启动X不一定保证还能拥有原来的设置。为了在启动X后,在避免验证身份的同时,又不改变用户原来的设置,那么在运行startx之前,还有工作要做。
    & l( l5 [* b# C) P& ^" s! _- U0 V
    : l" g+ S& X2 Q/ K  n; u1 k三、自动登录后,保持用户原来的配置(桌面、shell以及其它的一些环境变量)。 6 f8 [8 f5 ~8 `

    3 G5 S8 }, \4 d" z: Q3 N观察原来/etc/X11/prefdm脚本的自动登录部分: 3 t) u* U1 `( }8 e9 I) F
    * N8 D# f) B; a& W. s

    ' R2 d  X6 _( t' E2 x. g" f! I0 v...... ' q0 D- _' J) m& s- Q
    # 第一步:查看是否为自动登录
    * y2 B3 r$ ^% Y1 R  P$ [if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
    0 g. O/ b) P3 O  J$ uif /usr/sbin/autologin; then / g  P1 b7 [1 W2 ~; H* ]
    exit 0
    + Y4 H. ?  r2 D$ m5 E0 Mfi % v+ E# R9 ~; d2 K
    fi 6 S" K: n( U% `2 @6 Y! g
    ...... ( }* s, o9 v. Z6 j0 B4 P

    " j9 Y! y4 F4 t  
    + h: a, B4 X8 y/ v& L- q  H: D
    % m- I% m8 [, C6 K
    8 Z4 E0 L) C' d- \/ R! ?不难看出,脚本中保留了自动登录的接口:一个可执行文件/usr/sbin/autologin以及一个配置文件/etc/sysconfig/autologin。
    ( d5 T& K: b2 z
    & C, V9 m( k& J5 K* V3 h. Y# B2 ^1、/etc/sysconfig/autologin配置文件的实现:
    % N& q& [( d/ k/ Z- H5 N2 R8 ^5 w' ^$ J( J8 c/ m
    / @' {9 J+ w- t1 J1 R- p
    #config for autologin
    # T$ M/ \) g  D7 W9 EUSER=root
    ; r9 p/ B* Q, Z. s4 X. }& KEXEC=/usr/X11R6/bin/startx
    8 H. C  c# K/ j& O说明,USER指定自动登录时的用户名;EXEC指定启动X要运行的程序。 * j, ~% y# Z% L0 w- ^
    4 F/ v4 l. {4 ]* C! n$ i
      6 n& T6 I5 N! N& |) i
    0 \' \" ^' G* T2 b0 I! u

    ! _. A5 z. I# |* R# c3 y' {+ U5 `2、/usr/sbin/autologin可执行文件的实现: # H! v2 X9 B* b( _2 @
    4 e9 h( z% w5 d) C* q" M
    ! L0 h0 m: t' c3 Q/ D0 }% I5 o
    /********************* ( s$ {* a% m- O, W
    ****  autologin.c  ****
      Q  X! H& N. I( ]# X2 `*********************/
    8 ~" X2 t, L. g& ~( }" o7 t#include &lt;stdio.h&gt;
    ; ^3 j& I3 x5 P0 X7 l! p% H# `$ R#include &lt;unistd.h&gt; 9 c& v* h2 w, c4 K) h4 y- H
    #include &lt;string.h&gt; 5 V! W& h5 {5 q
    #include &lt;errno.h&gt;
    ( i8 m7 N( O: ^+ Q) {; z6 C$ C8 t#include &lt;sys/types.h&gt; 8 f+ O8 V  M$ j
    #include &lt;sys/stat.h&gt;
    ( M% o, [3 C# S#include &lt;pwd.h&gt; 2 v) M% ~9 ~- [% p1 ]+ r# q8 H7 w
    + V/ {% C# m7 U) O. o9 e
    int main(int argc, char **argv) 4 g/ H& F! j* e' v3 f. Y( `
    { " t, R: Y2 u3 p4 u: [7 m: }: r0 U- p5 I
    struct stat st;
    : m7 \+ R+ f" FFILE *f;
    , g5 c8 X: R7 R+ gchar *cfg;
    + N! X' `7 s- y. U; a* a6 ?% zstruct passwd *pw; 6 u: D9 O3 ^2 p2 B6 U0 s) C! O
    uid_t uid;
    9 I8 v3 c- P# {' X- t* @8 Ygid_t gid; " Y) F8 V/ }3 ?* F! d* J' K
    char *dir, *shell;
    ! `0 ?7 @0 N" N5 N$ G! bchar *user=NULL;
    5 D1 q! S/ ]" D+ j4 K9 b: R3 cchar *cmd=NULL; 0 @$ U1 c6 T- u1 r( M- p

    9 Z0 s  x( l8 Q# M) g$ Uuser="root";
    # d; ~7 P) B1 T1 b; q8 C) a& g/*为了能说明问题又保持程序简洁,这里默认登录用户为root,实际上,
    ! U: k1 e) d+ `- D6 \( P7 i5 i+ j登陆用户名应该从/etc/sysconfig/autologin中得到, 5 D4 ?. G; s1 I8 I
    程序实现时要注意过滤掉/etc/sysconfig/autologin中的无效用户名*/
    7 @! r" {; e6 o" Hcmd="/usr/X11R6/bin/startx"; $ Z& I( L& B8 r! Q3 q, u
    /*同样,这里直接指定启动X window的程序,实际上,该程序应该从/etc/sysconfig/autologin中得到*/ , Q; @0 p) p* i" s) T5 F/ M
    - I7 K# y- Y4 b9 l
    pw = getpwnam(user);
    9 b' A/ k' U# p6 ?6 b9 o//getpwnam返回包含用户信息的passwd结构(该结构在pwd.h中定义)。
    , S8 d% ~$ x8 ?* j2 \' w' cif(pw) { , Z' d7 h* {* n  i5 J& z5 `: r- B
    uid=pw-&gt;pw_uid; . Q# d  b  b# [6 j5 D; r1 i
    gid=pw-&gt;pw_gid; dir=strdup(pw-&gt;pw_dir); ; o5 K3 a5 ]+ m
    shell=strdup(pw-&gt;pw_shell);
    ' i$ A0 r/ q8 U( @# Q} 6 Z+ n9 k' h' [1 i/ b5 H
    //获得用户相关信息 3 t/ W3 V8 r& b. A+ Z2 A3 [
    else { 6 U; C* ~% X. P3 L+ U  s% T" r9 s. @
    printf("ERROR: No such user %s!\n", user); + F" _0 C0 M! g. o
    return 1;
    8 G! {0 d- Q( g( t}
    5 G/ c7 E: R, S; J( D0 h
    ' b# z1 i' k0 B" }chown("/dev/console", uid, gid); * l6 L  ^9 T8 G$ w
    chown("/dev/tty", uid, gid); 5 H4 @+ C/ f8 U  D! L! S( Y
    //为控制台和终端设置用户ID及组ID
    ! H. R  v8 r! H! E% i1 t
    ) V1 _) k0 [1 n, c//下面是设置用户相关ID 2 O3 T- n5 `" A: y* k& i3 S
    setregid(gid, gid); 3 y- S" R/ |2 ]9 L
    setegid(gid);
      n# N! Q1 L# F! y' f& V# _1 `setgid(gid);
    7 N+ k8 B9 r) n+ c% k9 Rsetreuid(uid, uid); ' o! d0 E& W+ e  C2 Z
    seteuid(uid);
    , Q  a, G" f' n3 isetuid(uid);
    * R" V5 `( ]8 ]$ p# H( B
    ' F8 v. Y) P9 A+ [7 z) E' q( e8 Y; ~setenv("HOME", dir, 1); ; e8 ]4 o/ f0 W: H. w' U) g; C
    setenv("SHELL", shell, 1);
    $ \9 H' N- L5 X5 M* U, l# Osetenv("USER", user, 1);
    , S! C: v# i" b( {( h9 a' A. e/ @setenv("LOGNAME", user, 1);
    8 k. K1 j: ]- x7 K5 T9 @//设置用户相关环境变量 ; m% b. W8 Z4 y# [. [/ T
    - [* Z  C8 e6 Q6 D( }, _6 J! i
    chdir(dir); 4 [2 d) ~- Y- l
    //切换到用户根目录 ) I' d; Z. k+ S6 `" i' b
    user=NULL; ) ], Q4 B2 u5 s

    : L$ ?6 C" h/ z" O1 s) j4 vexecvp(cmd, argv);
    1 f: f, b/ T$ I* ?/*在配置完用户的相关信息后,执行启动X window操作。注意这里默认执行/usr/X11R6/bin/startx */
    0 I5 R) y+ L' E* Y' @$ b1 V3 Lprintf("ERROR: Couldn't exec %s: %s\n", cmd, strerror(errno)); : `5 V; Y3 _0 v/ m
    return 2; 4 ?7 t! a1 \  H5 G& f
    }
    7 T& f* e. t$ O" e( R0 o# `
    ! m) J' D  ]0 w: ~  e& r  
    : y2 |8 l' W( K& J/ Z5 _- A+ o! R, t# K3 r' H7 \

    ! B& {) @# m6 M9 n运行gcc -o autologin autologin.c,拷贝autologin可执行文件到/usr/sbin/autologin,拷贝autologin配置文件到/etc/sysconfig/autologin。 重新启动系统,会直接进入X window并保留用户原来所有的风格。
    & k" j7 `4 N# p( T: r
    + K0 }6 Z# L) v3 b, o* |如果不需要自动登录的配置文件/etc/sysconfig/autologin,所有的操作都在/usr/sbin/autologin以默认的方式实现(比如,默认登录身份为root,默认执行操作为/usr/X11R6/bin/startx等),那么,/etc/X11/prefdm脚本的自动登录部分可简化如下:
    9 l6 N& U. G% B+ n3 o) i6 m2 s
    ; o# S+ w" q0 C: \) O( w' b8 _
    " ]8 F2 Q$ `" I+ x3 r9 B...... ' q- {8 v* j" H* L3 e) ]
    # 第一步:查看是否为自动登录 * ?, y' [0 T/ T6 V! f$ Z
    if /usr/sbin/autologin; then
    9 C, p( s/ l( t/ y% P- `exit 0
    . s6 n2 g' @+ }3 n' Gfi
    . m6 X2 n8 A3 W( v* R$ \% R9 F//第二步 ...... 3 M5 W* \9 K# w2 X, {
    ......
    , ~* I8 |+ }( C  @' L& P: x
    & l7 s! l, r$ d2 {2 q' P2 |4 p  Z  , M( N  g0 T: a6 X" M$ [
    ' r+ x# N! U7 s8 V; ^
    7 h3 {* g# [* h( n9 T, H
    即在脚本中去掉条件测试开关,直接执行/usr/sbin/autologin,这时,只需要拷贝autologin可执行文件到/usr/sbin/autologin,不再需要拷贝autologin配置文件到/etc/sysconfig/autologin。
    $ Q  D6 P1 x  [* p: N( l! P$ c) o( I4 u4 U! y6 u
    四、选择进入kde或者gnome,并自动启动X window应用程序 1 w: ?4 B3 l. y  ^  ^

    6 y, r6 A" Q* S2 [' `如果重新启动后系统进入了kde,而用户需要进入gnome,只需运行switchdesk gnome在重新启动系统即可,以后每次启动时会自动进入gnome;反之亦然。  , |& y$ P/ L# i% `0 J/ {
    一般系统自动登录的目的是启动X window 后自动运行某个X window程序。如果系统默认的启动级别为3,那么如果要在系统启动后自动运行某些应用程序,只需要在某些脚本中加入相应命令即可,不再详述。在X window启动后自动运行应用程序要复杂一些,幸好,kde和gnome都为此留下了自动启动接口。如果在kde桌面环境下自动启动应用程序,只需要把应用程序名字加入/root/.kde/Autostart/目录下即可(这里注意不同用户的根目录可能不同,如用户zyx的根目录可能为/home/zyx)。如果在gnome桌面环境下自动启动应用程序,只需把应用程序的名字加入/主菜单/程序/设置/会话/会话特性及启动程序的startup programs属性页中即可。  0 f3 }' o8 [# h9 h
    / B1 D: E9 z* i& h0 j! ?

    # }  _8 W" U7 N0 E/ hhttp://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-6-15 03:17 , Processed in 0.441361 second(s), 57 queries .

    回顶部