QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4210|回复: 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>6 k1 \. j) g3 J! _( ]  G
    <>本文以redhat 8.0操作系统平台为背景,阐述如何实现启动级别为3时的自动登录,及自动运行相应程序,并简要介绍了如何在redhat 8.0下自动登录X window(系统启动级别为5),并自动运行指定的应用程序。
    & a) C1 c, \5 H3 x# Q. g[b:804aea7097]一、启动级别为3时自动登录的实现[/b:804aea7097] - G4 {; d; I. i4 P8 F/ b
    7 }* b; {% e( f% v
    启动级别为3时自动登录的实现涉及两个软件包:mingetty-1.00-3.src.rpm软件包及util-linux-2.11r-10.src.rpm软件包。 # L6 y; m! @) N2 d5 K5 Q

    7 F) W7 J: y$ [: O8 i4 A(1)mingetty-1.00-3.src.rpm软件包  5 |6 Y! y: n7 Y: s
    对于启动级别为3的自动登录的实现,仍然需要考察/etc/inittab脚本,  / Y7 y% r9 a2 B- s" m* [$ I
    3:123:respawn:/sbin/mingetty tty3 & l7 g, u7 P- d; f

    ( c1 ?$ u* i4 S6 {' {7 o5 \& v; I) q# l' B/ w. x/ s5 s
      
    5 `) y1 s) S' g6 g. r3 `
      [* W5 S1 b' U, R9 R3 J- ?
      |5 M0 [! L, G因此,如果想在启动级别3的情况下实现自动登录,必须要了解mingetty的功能,甚至要修改mingetty的代码。用命令rpm -qf /sbin/mingetty 可知redhat 8.0版本的mingetty包含在mingetty-1.00-3.src.rpm软件包中,下载该软件包,安装源代码,缺省情况下,代码会安装在/usr/src/redhat/下,我们关心的只是mingetty.c源文件。mingetty.c约有五百行代码,主要实现如下功能: ( l% y/ [2 [9 x
    ! D- x7 {8 J4 K" n
    2 e; N) w; F. O4 f( M# n9 W
    打开指定的tty(由参数指定);  / v6 l9 k6 O  M
    提示用户登录(login:);  & k6 S: l& M: M. `8 u$ T
    获得登录用户名;  
    ) m2 I3 n! d* m+ ]# f把用户登录名作为参数,调用/bin/login。  7 R% ]7 r% f9 U: h+ b

    . z; k2 ^8 }' \4 U$ Z我们所关心的部分实质上只有以下三行:
    * c! @7 [% ~7 ]& _3 _9 }1 S. k0 t5 A+ W

    ( |+ z' k, H; }* l: j... ...
    7 u' z; `4 {2 P5 d6 x. V; {% d, n7 @438 while ((logname = get_logname ()) == 0); //mingetty.c文件438行 , L0 ^) _5 v( @# r; @
    439 execl (_PATH_LOGIN, _PATH_LOGIN, "--", logname, NULL);
    2 T- i2 c/ {" ?1 j) l* Y/ {" w7 J440 error ("%s: can't exec " _PATH_LOGIN ": %s", tty, sys_errlist[errno]);
    8 i: F  g1 v$ n: E0 C... ...
    ! v0 f- t! p, j" t* T. y. N. Z. U8 h: t7 b: ]$ w. u
      # u0 V: |0 C( j9 A4 S1 x3 t
    . Y( Y+ W+ g9 Q
    第一行的功能是输出login提示,并获得用户输入的登录用户名,登录用户名由logname返回。因此,可作如下修改
    9 M- q( V; X2 q) G' N1 E. `' r; Z/ _3 ?# s* x" S/ s

    # r  i, C$ x! L& J... ... * b0 o/ T  Z& M. Q& ]8 R6 I
    438 // while ((logname = get_logname ()) == 0); //注释掉本行,不再提示login: ; F. x% Y2 ]# p
    439 logname = "root"; //添加本行代码 ) v. A. ~0 E& v5 e' T; K6 m- ^4 w
    440 execl (_PATH_LOGIN, _PATH_LOGIN, "--", logname, NULL); ; `" D# s* {$ K' A( r
    441 error ("%s: can't exec " _PATH_LOGIN ": %s", tty, sys_errlist[errno]);   X$ F3 n6 P0 ~; r/ m/ X
    ... ...
      I9 ?1 `- O: ~; \% R$ [$ X; [+ l2 ?
    9 d  T9 {- O7 E+ |  ( h0 Q% p8 O* @
    0 Z* v/ w. t( P) S/ V" d4 \4 G
    注意,这里假定用户以超级用户身份登录。 . O: [; v3 y8 H6 S5 U

    8 i2 Y' M5 ?5 [6 U第二行以用户登录名为参数,调用/bin/login程序,进一步实现登录。因此,要想实现自动登录,还应该了解/bin/login的功能,必要时还应修改其源代码。 + Y1 w7 d8 B& u+ c& Q+ G
    , }/ k& [. l; \6 \4 n
    第三行为出错处理。 ( n9 Q3 ^0 x3 Y& q' S' L# ?
    5 r5 I) E* F6 i/ a& c/ i( b
    (2)util-linux-2.11r-10.src.rpm软件包  1 }: E. P8 r$ a9 m' a- B; |7 j
    采用同样的方法,查看/bin/login所属软件包(redhad8.0版本的login包含在util-linux-2.11r-10.src.rpm软件包中),下载并安装util-linux-2.11r-10.src.rpm,login可执行文件有几个源文件编译而成,我们最关心的是login.c源文件(大约1500行的代码)。下面简要分析一下login要实现的功能,并对相应部分作必要的修改。
    * {' V5 l3 ?0 X
    8 H8 S' L! x  X/ t1 p( x" GLogin程序主要可以分为以下几个主要部分: % d5 _1 K! Y/ ~0 r5 \$ K) W

    ) J4 F* h/ l. V+ P" Y1.Login首先检查登录者是否为超级用户,如果不是超级用户,并且存在/etc/nologin文件,则输出该文件内容,并中止登录过程;主要由checknologin()实现;  
    7 ~8 o: ?6 {0 h) N7 B2.如果登录用户是超级用户,那么login必须在/etc/securetty/中指定的tty列表中实现登录,否则将导致登录失败。同样可以不指定/etc/securetty文件,此时,超级用户可以在任何tty上登录。  
    . x* X" J" K& m3.经过前两步测试后,login接下来将提示输入登录密码(由getpass()调用完成,有兴趣的读者可参考其手册页面),并进行验证,如果密码不对,则提示重新登录。  1 s; t: w- u/ Q9 P2 m0 T
    4.顺利经过密码验证后,login还将检查是否存在.hushlogin文件,如果该文件存在,则执行一次"quiet"登录(所谓的quiet登录指的是,登录时不再提示邮件mail,不再显示最后一次登录时间,不输出任何消息。启动级别为3时,正常情况下输出这些信息)  0 F9 ?# Z( D3 N! e' `' [2 Q
    5.login接下来设置登录tty的用户ID和组ID,并设置相应的环境变量,包括HOME、PATH、SHELL、TERM、LOGNAME等。对于普通用户来说,PATH缺省被设置成/usr/local/bin: /bin/usr/bin:;对于超级用户来说,PATH被设置成/sbin: /bin: /usr/sbin: /usr/bin:  0 H' e  |7 G5 N: p! l% M; z
    6.login的最后一步是为用户启动shell。如果在/etc/passwd中没有为用户指定shell,那么将使用/bin/sh,如果在/etc/passwd中没有给出当前工作目录,则使用"/"。  
    1 X2 S: ~0 g5 x1 H" k- _至此,一个完整的登录过程就结束了。 1 u8 G9 a, b  b" Q& m
    + r5 o! q( o! X$ N8 _5 Z* i
    从以上对login源程序分析过程中可发现,如果要实现自动登录,应该在第三步做文章,设法绕过提示输入密码以及对密码进行验证这一过程。实际上很简单,login源程序对是否要求输入密码设置了一个开关控制passwd_req,缺省情况下,其值为1(passwd_req = 1),即要求输入密码进行身份验证。把该行代码改为(passwd_req = 0)后,问题就解决了。即对源文件作如下修改即可: $ v# @+ M+ ^( ~( A8 ]
    . d" R' L1 `' G% P1 A- u
    : N0 {% J, a/ A
    ... ...
    8 {! d" H5 C9 l. n$ V8 C+ x402 fflag = hflag = pflag = 0; //login.c文件402行
    4 O  ]9 p# |' Z& K0 o' b+ V. N403 //passwd_req = 1   //缺省时,要求进行密码验证,注释掉本行
    % K4 |: {. E7 s( f$ [- x* F/ v404 passwd_req = 0 //添加本行 ( O! [) B0 I" |3 P
    ... ...
    0 v( m( k1 D- d8 s+ b: U2 \2 k) s7 D0 c. w: V* z
      ! r9 ?( Z* s/ Z4 H9 J. z
    1 S$ b( R1 [. U2 p
    修改后,可以直接使用util-linux-2.11r-10.src.rpm提供的Makefile进行重新编译,也可以自己对其编译:
    ; j: m" [/ X8 u3 D( D% N0 @7 O! s
    4 B- M/ Q& k) B7 R  G' H) }6 \7 Z8 q8 r; x( a, d4 K. Z
    gcc -o login login.c setproctitle.c checktty.c xstrncpy.c -Wall -lcrypt注意包含后面的编译选项-lcrypt,否则会出问题。 + H0 N# A. z8 T% v( X: ?

    ; j* k3 U+ D$ I9 U
    4 o" V: Q( m- H0 `5 |7 U0 F有了新版的mingetty及login后,拷贝mingetty到/sbin/目录,拷贝login到/bin目录,并将/etc/inittab中的启动级别设置为3,再重新引导系统即可(读者可以自己写一个脚本实现上述过程)。
    7 f+ y) \' {6 H8 j5 y' R( b4 q4 K0 ]. w# u4 _% F+ l# G1 u. F+ {& O# ?
    如果读者对mingetty或login代码的其他部分感兴趣,可以反复修改login.c或mingetty.c的源代码,测试一下代码的功能,这里要注意的是,在拷贝新版mingetty和login之前,一定要把原来的mingetty和login备份,同时还要准备系统引导盘(有系统安装盘亦可,这样读者有机会键入linux rescue),在测试新版程序前更应如此,如果对代码修改稍有不当,系统将不能正常启动。
    * ]1 w2 C- ], R) s0 f) ?
    5 c4 m# B9 _" g4 q5 k5 ^" f如果不想再作进一步的代码测试,只是按本文给出的方法进行代码修改,在系统启动上不会出现什么问题。 * O6 L  ~$ w- A' K6 _

    # v2 Z0 k0 I! q2 @' U( U7 k6 j[b:804aea7097]二、自动登录后,自动运行特定的应用程序[/b:804aea7097] ! {, n- h# b& `! E; L* N: k

    ! q1 {. g$ q! c& S/ W$ L8 }8 U8 {在实现了启动级别3时的自动登录后,自动运行应用程序非常简单,把应用程序添加在/etc/rc.d/rc.local脚本中既可。(读者可以尝试一下把startx加入脚本中,看一看效果如何。在某种意义上,又增加了一种自动登录X window的方法) - d" M2 E4 x5 Z5 v: \

    * e0 f% R0 G4 f7 S  e[b:804aea7097]三、对自动登录X window(系统启动级别为5),并自动运行指定的应用程序的补充[/b:804aea7097]
    : ]( \7 R' v. p) Q1 V9 ]) r
    : l! M. b4 u+ I/ ?! z9 B! g7 m在"如何实现自动登录linux"中,主要以redhat 7.2平台为背景进行阐述的,其中的自动登录部分可以直接用于redhat 8.0中,不需要任何修改。 ' t2 ]7 L4 L6 P2 s
    0 s' T2 i' _! W0 k  D5 H* I
    但是,登录后自动运行应用程序的接口在redhat 8.0中有所不同,主要是登录gnome后,自动运行应用程序的接口有所改变:首先点击面板上的GNOME帮助(那个红色的小帽子),然后选择/其它/首选项/Sessions,在Session对话框的启动程序属性页中添加要启动的程序即可。
    + z. p% [5 y4 ~# a$ i6 M* A* V; D1 s) k: O
    对于登录kde后,自动运行程序的接口没有改变。
    9 z( I4 R6 ^. S
    6 M( J9 q3 o1 |3 n& p( `- R[b:804aea7097]四、结论[/b:804aea7097] 2 Z2 N% W/ C  x* M# Q2 h0 e

      |: ~$ j. m9 S+ E- |本文同"如何实现自动登录linux"一文,基本上解决了如何实现自动登录Linux,并自动运行相应应用程序的问题。对于两个最常见的启动级别(3、5),都给出了各自的方法。
    6 y: I* ^" I) t) ~/ Z1 y8 N8 Y: ]+ F& c, E8 p# B6 E% a. m
    在系统初始化到mingetty及login这一阶段,内核实际上已经完成了引导过程,已经到了系统初始化的最高阶段,与内核没什么关系了。此时,主要是/sbin/init根据/etc/inittab的内容而相机行事。读者可通过(man 8 init)或者(man 5 inittab)了解更多东西。
    % G2 e' ]7 D8 @/ m
    % K; \, Z+ z4 h8 D" _$ {0 J在对文中提到的软件包修改时,请遵守GNU General Public License(GPL)相关标准,另外,替换login通常被视为黑客行为,应当谨慎行事。 + t& J5 I# y% }% I* f
    ( T9 S) u9 y9 P. i4 t

    # S4 }! Q$ H) L5 v. J& g7 r- c$ ~. |
    [b:804aea7097]参考文献[/b:804aea7097]
    ' ~" M7 F( d, U+ ~& h
    + r) x& i$ t( J- g. ^5 i8 F" w0 M! `" w4 P& ~* y! Q
    1.login手册页面  
    * I: o5 ]( y+ w6 _! D& }+ E3 E3 L2.mingetty-1.00-3.src.rpm,在redhat 8.0的发行版本的源代码中,包含该软件包;  0 n% o! u0 Q3 o* q) K$ [
    3.util-linux-2.11r-10.src.rpm,  
    5 Z' h1 C+ T( j1 t1 V; k1 m8 m# u( p7 W1 B& Y
    可在http://rpmfind.net/linux/RPM/redhat/8.0/i386/util-linux-2.11r-10.i386.html处下载,注意下载源代码包(..src.rpm)
    ) ~$ N& J' r; f: N, T* W7 q
      y  X8 l2 c) h+ p[b:804aea7097]关于作者[/b:804aea7097]  
    + a, ~% S- k0 D1 ]% t8 h0 z* Y+ i% d( A6 i
    郑彦兴,男,现攻读国防科大计算机学院博士学位。您可以通过电子邮件 mlinux@163.com和他联系1 L6 U  f. J( i9 A( c  J) ?

    1 F! W. ~2 y8 c+ h</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) % p4 C! [/ v  N5 B7 ?% M* O3 L

    * a' C) e! z3 f; f  a3 T机自动登录linux,并自动运行X window应用程序,有其特殊的应用背景,如基于linux平台的监控系统,linux启动后不需要身份验证,而直接运行监控程序等等。本文以Redhat7.2为平台,结合linux启动过程,介绍了如何避免身份验证自动登录,并直接进入X window自动运行应用程序。 , J4 {: I6 c# T3 M3 k
    一、linux启动的最后阶段的工作 " z! i" @0 _( S' S5 o3 L

    : f) M6 X5 w& S1 Y% Vlinux 在启动过程的最后阶段(具体启动步骤略),init 会根据 /etc/inittab文件的最后一行x:5:respawn:/etc/X11/prefdm -nodaemon运行/etc/X11/prefdm脚本,(Red hat 7.2缺省时是这样的)。prefdm脚本的主要任务是完成X window的启动,可以有几种启动X window的方法,都包含在prefdm脚本中,几种主要方法有:
    1 s  z1 Q  K. i! I
    7 Z0 I6 H; o- ~5 S; m运行xdm启动X window;  
    # u8 N- `! _  M运行gdm,进入gnome桌面环境;  
    * j1 d- W6 z# V7 M4 N2 e运行kdm进入kde桌面环境;  
    ( ^4 c$ g5 L7 U' }% F4 R9 Q: C自动登录进入linux;  ; }7 w; w& b  l* |- O1 F
    prefdm脚本框架大致如下: ( p; n1 j7 k1 B( u6 R& ], ^. h

    : q& M5 S" K2 X& p  u8 z#!/bin/sh
    , o! {* _5 I. qPATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin
    4 [  j" g" T0 y. C9 a. /etc/profile.d/lang.sh
    & t" D/ z) u: [6 o# 第一步:查看是否为自动登录
    9 ^* |* |( V8 q, u' t* P5 s: D1 x+ a1 lif [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
    # P4 Y. e! L! \3 V- L0 @6 ~if /usr/sbin/autologin; then ' k; X7 T( p* R7 C* {
    exit 0 8 ~! {, q* @* v. {  m
    fi 7 ]4 _5 i7 q  ]# u. B
    fi ; t; z4 T  r0 Y; z. y* k8 H

    , |5 M! t' I* y; }  s& a/ e9 i) y0 ~# 第二步:如果不是自动登录方式,就会在/etc/sysconfig/desktop中搜寻用户偏爱的登录方式 $ A# K1 O4 w2 ]6 ^% ~& i$ |
    ...... ( I' U( p, A' w4 K
    # 可以是kdm、gdm以及xdm,并运行相应的kdm、gdm以及xdm。 % t2 Y: B; U- [) j4 F8 \
    ...... ! ?' _4 _2 O- d7 {- }! u0 Q4 M

    0 R$ l1 G7 ]. r% s/ a  R+ E$ I5 M/ U  
    1 W; |) y9 I6 b' p) j- \9 {/ W
    8 v  u% t9 g6 q4 B( B# @6 X/ X8 b+ n) e4 }1 L, ^
    二、自动登录的实现(autologin的实现)
    0 g; k$ J) {2 e' s# ~6 _
    " h: B& M* `8 a3 `0 D$ K在/etc/X11/prefdm脚本中,是否实现自动登录有一个条件测试开关,事实上,可以在这里注释掉测试开关,直接执行启动X window的操作。 - q- M" x5 z. E2 `5 S! h1 n9 p
    ( z# O5 }# M7 A
    自动登录实质上就是绕过身份验证,直接启动X window。X window的启动可以由xinit来完成。 7 c, R, x4 V! [! r- {8 e

    : ]. C# V2 t& g, F  [- z5 hXinit用来启动X window系统服务器以及系统上的第一个客户程序,可以通过为xinit传递命令行参数的形式指定要启动的服务器及客户程序。如果不传递参数给xinit,它将在用户的根目录下寻找并运行 .xinitrc脚本来启动客户程序;在用户的根目录下寻找并运行 .xserverrc脚本来启动服务器。如果xinit在用户的根目录下找不到.xinitrc、.xserverrc,xinit将使用缺省的X :0。  
    % ~1 W: \' q( w* }' ~2 C6 U实际上,用startx来启动X更为方便。对于运行单一会话的X window 系统,startx提供了更为良好的用户接口。同样,startx首先在用户的根目录下寻找 .xinitrc及.xserverrc脚本,如果找不到这两个脚本,startx将使用/etc/X11/xinit/xinitrc以及/etc/X11/xinit/xserverrc脚本。  
    $ t; o1 V4 P- P" E! |4 o: s  [startx脚本的最基本框架是:
    $ q% {; ~( c& _. d( Y  v
    3 Z' v5 j) \: g. V7 `  qa、 寻找.xinitrc,如果没有则使用xinitrc;
    - T( Y/ `* A' I9 O9 hb、 寻找.xserverrc,如果没有则使用xserverrc; $ k! g! e5 K1 v$ C' q- ]
    c、 根据找到的脚本确定xinit的参数; " A$ p3 s# _- h& x) j# X. Q! A
    + _' p3 u+ v6 H# a
    由此可看出,startx在不需要传递任何参数的情况下,可以完成启动X的任务,因此,可以如下修改/etc/X11/prefdm脚本来实现自动登录:
    ) V0 f* u' O' r
    ) ^; _* D6 b4 \; _9 {: c# F! I) Q; n* h& O5 J6 V# q3 U6 h
    #!/bin/sh
    ( |% _& l9 D, V( m# x' K' ?. FPATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin 9 f" M; w- k7 O* z, k, r" r* m
    . /etc/profile.d/lang.sh * s; q( c; ^, T) W1 t9 Y: S
    # 第一步:查看是否为自动登录
    ! q2 }& y( ~! E6 u$ |4 @#if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
    ) w% G9 V' I/ @( S: D" U0 z#注释掉上边的条件测试,直接运行startx
    6 b# h+ b7 B+ J5 |1 T% y6 T$ Yif /usr/X11R6/bin/startx; then 6 Y4 G$ m9 k* G" d4 O
    exit 0 ( j  n6 h4 f$ x) l3 s. f" M
    fi
    6 W- n! t9 F0 \5 F! ]#fi
    8 G4 N$ K( k7 R' B# L! \; p0 B) C: n; A! O- v1 ^& w: c9 B' j8 i
      : W- i5 h8 [3 A8 _
    # N0 S; s. [3 b0 o3 U
    * Y/ U8 W/ e8 O" V
    当然,应确保/etc/inittab中的启动级别为5。 ' z7 I! H5 q7 p/ w8 `' O3 D

    - ^" g# T6 }" g2 h! Z重新启动系统,会发现系统不验证用户身份,直接进入X window,此时的用户身份为root。但是,如果原来root有自己的桌面、默认shell时,上述方法启动X不一定保证还能拥有原来的设置。为了在启动X后,在避免验证身份的同时,又不改变用户原来的设置,那么在运行startx之前,还有工作要做。
    % E6 z) h  w& S
    7 S/ g' Q8 V' O三、自动登录后,保持用户原来的配置(桌面、shell以及其它的一些环境变量)。
    9 V" @+ `9 u3 j) W* s, o8 ~2 S0 ^7 _0 l
    观察原来/etc/X11/prefdm脚本的自动登录部分:
    8 ]% h" f& a' ?) l) `7 D- s9 g9 x# w+ R7 h& P# [8 i; t7 @% Y
    + U4 F1 y) Y1 V: M8 [- ^
    ......
    5 ?7 j# ]1 J2 N8 z% u/ _# 第一步:查看是否为自动登录
    3 |8 z# x1 n, [: [! N9 \if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
    1 h2 e. r6 D: o% c+ ~# m. Kif /usr/sbin/autologin; then
    - u$ f9 q5 ]2 G4 e3 T5 O3 `( O* lexit 0
    + I8 u. ]- o3 f3 S5 o8 `% cfi
    - s  @5 j" P& q& r9 I9 i+ w* afi ; @9 x) `% g9 J  f6 _7 c6 d, t4 H" m
    ...... 8 B  `! V: }" x$ d6 B

    5 R1 x; F" q) o  $ N' B( o0 z. J& D* H  h; K

    8 L7 g( F. R% }- O! s1 ^
    $ W' y& H7 v$ g) R- Y不难看出,脚本中保留了自动登录的接口:一个可执行文件/usr/sbin/autologin以及一个配置文件/etc/sysconfig/autologin。 " M/ G. z1 k, B8 }# }4 I, {" c

    2 r- }; ]' a; o- r0 ?5 S, N1、/etc/sysconfig/autologin配置文件的实现:
    3 `$ p& `0 {! }: @8 p- X# o: d# Y$ R" |# g
    - N7 {$ X# _: r& Y' D
    #config for autologin
    ! {7 G+ N2 c" kUSER=root
    : b  K( [* [4 ?EXEC=/usr/X11R6/bin/startx
    3 s1 k9 I9 r/ i+ x$ ^( o说明,USER指定自动登录时的用户名;EXEC指定启动X要运行的程序。 ' w0 \& k3 ^! x5 M. b. {0 j+ ~' E

    + p0 t8 s; \  D  
    ! c) o# ^$ H8 N# {, A  d, |: q- l6 O2 `( N' ^8 L- c# Y$ l
    & w+ F7 J3 V8 {) T/ r
    2、/usr/sbin/autologin可执行文件的实现:
    . |4 V9 v: l. R  y  I3 M5 n; J/ v, ?" J
    5 t+ Y* i9 T: y3 f
    /*********************
    / p) w2 M! o+ S: G* s6 u. e****  autologin.c  **** ) n/ C  u7 z# W) l2 A
    *********************/ ) d* I8 H9 h% S( Z: f5 I3 Z: r
    #include &lt;stdio.h&gt;
    9 l8 n; }8 b- p6 y6 S#include &lt;unistd.h&gt; 7 \- y" s& ?. c5 ?
    #include &lt;string.h&gt;
    * Y7 v, {9 k. G6 A* _8 a1 \#include &lt;errno.h&gt;
    . I$ F! [8 i3 V4 V#include &lt;sys/types.h&gt;
    $ t( o* N2 `# w. g' ^' U  _7 X#include &lt;sys/stat.h&gt;
    7 W9 s9 \0 L$ s2 |2 v$ r#include &lt;pwd.h&gt;
      z1 ?5 V, B( ^! ?: ~5 y4 j  I- G( ?8 \/ K- u. x. k4 e6 h
    int main(int argc, char **argv) ' [& ^1 z5 |0 O" [" d
    { 9 f% Z' h0 j; W" S6 N) f8 f
    struct stat st;
    : U$ B6 L: G, m7 O( `; VFILE *f; + D( z& _' |* X' K, P3 @5 N' E
    char *cfg;
    7 H; l" n6 H. v/ j& W' l/ ^# u) D5 kstruct passwd *pw; ) F! X9 g6 W8 K8 C
    uid_t uid;
    ) w, T0 x" L% V* ugid_t gid; 3 s2 p% M* e0 O; K$ O% q3 S8 U" W
    char *dir, *shell;
    + ]% q) x% q; \% [9 j# f: Q, n0 Y, Nchar *user=NULL; 3 c% F0 }: D8 i) F: L
    char *cmd=NULL; 9 ~' C! ~0 v7 I0 Q8 [

    5 q8 v8 [9 |* E# Z/ d2 ~  ?1 cuser="root"; 1 V9 J! s- S2 \+ m" g9 L; a- N
    /*为了能说明问题又保持程序简洁,这里默认登录用户为root,实际上,
    & S: O* J) `, n登陆用户名应该从/etc/sysconfig/autologin中得到, # ]* r) {# b2 D% F$ Y$ h
    程序实现时要注意过滤掉/etc/sysconfig/autologin中的无效用户名*/
    3 D) k* |" O( z! F6 m* l) Rcmd="/usr/X11R6/bin/startx";
    3 O/ D, d8 F( I/*同样,这里直接指定启动X window的程序,实际上,该程序应该从/etc/sysconfig/autologin中得到*/ ! r7 @3 X" \( |% [7 i6 O( Y9 o7 Z/ C" @
    ( t$ l3 u" I! y8 a% q
    pw = getpwnam(user); . S& u  ]9 E8 L, A
    //getpwnam返回包含用户信息的passwd结构(该结构在pwd.h中定义)。 9 k$ g& z& `9 Q6 E( ]: ]  l
    if(pw) {
    0 ^8 Q1 F( \$ C( q% k+ x8 Suid=pw-&gt;pw_uid; 9 I2 z: i( F) |; c6 p# m
    gid=pw-&gt;pw_gid; dir=strdup(pw-&gt;pw_dir); & J7 f, S, R2 E$ x3 S+ u
    shell=strdup(pw-&gt;pw_shell);
    ' }  p" S" D; q} ' S; y2 F( |) D9 F
    //获得用户相关信息
    ) p* Q, v/ _% d8 B" L/ J else { / `4 k. m4 G  I: ~. j2 b$ q" s
    printf("ERROR: No such user %s!\n", user);
    $ b( P' W! a3 Y2 m( Greturn 1; 7 ~3 U5 w: z* a5 D  I
    } 8 p% t0 y- q8 v9 Z
    , z& ]- L) p  @2 Q( L
    chown("/dev/console", uid, gid);
    ) c: e; R3 J; \6 E& s  Ochown("/dev/tty", uid, gid);
      Y: K3 x; Q: y/ C  ?! o5 c  a//为控制台和终端设置用户ID及组ID 3 i! w) A% R1 ]/ n' Q2 y, W

    ; B/ I5 |4 {- b. L& O//下面是设置用户相关ID $ i/ G/ j+ r9 e
    setregid(gid, gid);
    ! Y8 O* u* E3 R/ Nsetegid(gid);
    9 w3 t( D+ G9 D  f2 A  Ysetgid(gid);
    3 i+ I6 z9 j( _  g& J* p2 Qsetreuid(uid, uid); 1 m$ y0 w7 u' t/ i. j2 y0 w% C2 t: r
    seteuid(uid);
    1 f( C) m- J" v6 J! @0 W0 P. p! S. Gsetuid(uid);
    3 X7 G/ v$ U) p8 ]* w; ^" A/ }  E% r; D' p- H# m1 H
    setenv("HOME", dir, 1); . A$ U/ ?: K" [$ U2 A5 U% D# S
    setenv("SHELL", shell, 1); & a4 l- N/ Z( e8 o, j
    setenv("USER", user, 1);   N9 R8 m. |: b. a5 _+ H
    setenv("LOGNAME", user, 1);
    5 z. _+ D% ^/ Y//设置用户相关环境变量
    2 A& _7 {1 P* I% [: v/ t. u5 S# S$ V6 E
    chdir(dir);
    8 N+ r, _- P# D7 Z//切换到用户根目录
    0 _# Z1 P7 `8 H; G- cuser=NULL;
    9 q0 U% a6 E) I' z" h( b# u' E) K* f
    $ H4 H0 Q7 z& M2 kexecvp(cmd, argv); 3 B6 H  G2 y, T# @. u6 f$ W
    /*在配置完用户的相关信息后,执行启动X window操作。注意这里默认执行/usr/X11R6/bin/startx */
    3 t8 E( `' h% @7 q1 b1 a8 ~printf("ERROR: Couldn't exec %s: %s\n", cmd, strerror(errno));
    9 ^  s# \) C" _! [$ }- x0 Xreturn 2; 4 L/ @7 [, n. s" X: _5 \( d
    } $ r8 Y- Y  m/ \" K

    4 Y$ [3 W6 _/ Q  z1 [7 ^/ j  % M0 ]/ Y2 P" c8 `
    3 E2 T; ~! [& S5 P2 N& G

    + J) ?( c6 ]! a5 S, [3 h3 r1 V: G1 s! r4 f运行gcc -o autologin autologin.c,拷贝autologin可执行文件到/usr/sbin/autologin,拷贝autologin配置文件到/etc/sysconfig/autologin。 重新启动系统,会直接进入X window并保留用户原来所有的风格。
    / F0 I4 t. m+ ~  h8 I7 b4 T" `% y4 e5 z
    如果不需要自动登录的配置文件/etc/sysconfig/autologin,所有的操作都在/usr/sbin/autologin以默认的方式实现(比如,默认登录身份为root,默认执行操作为/usr/X11R6/bin/startx等),那么,/etc/X11/prefdm脚本的自动登录部分可简化如下:
    + T. @) q1 J* h1 a: z) j9 V6 \% T! {5 W7 B, R6 @
    $ |' A& {5 t- e3 C  E, d9 t! s
    ......
    : z) `( E; n' }6 [% d4 i# 第一步:查看是否为自动登录 " N9 [. S6 |/ i: D% Y1 x
    if /usr/sbin/autologin; then ' N* {4 \; c3 f  U( q$ g. ~, C
    exit 0 - {  G4 I, n3 v0 D4 P3 H
    fi
    . D$ L$ y" R) M; S/ O//第二步 ...... 4 P$ w* @& {, [7 L, a6 Q
    ......
      i0 a. }; J5 [5 c
    ' N* A2 h* D! _& y  $ J' j9 l# r* f0 b/ n( @
    8 P0 R- T! y" P! G9 d' G, g0 T1 a

    + N) g. v7 l; L- a3 O1 x1 i即在脚本中去掉条件测试开关,直接执行/usr/sbin/autologin,这时,只需要拷贝autologin可执行文件到/usr/sbin/autologin,不再需要拷贝autologin配置文件到/etc/sysconfig/autologin。
    1 w+ h5 |* M5 Y) g+ i! K3 Z$ G. D+ Z5 t: \4 Z' p5 ]% A. K
    四、选择进入kde或者gnome,并自动启动X window应用程序 ) o4 u# `3 W/ N6 C- L. W5 f

    3 |( l; T/ K% D  S, F3 o如果重新启动后系统进入了kde,而用户需要进入gnome,只需运行switchdesk gnome在重新启动系统即可,以后每次启动时会自动进入gnome;反之亦然。  
    ; ^; L- |9 y/ ]5 N  f, K. D% X一般系统自动登录的目的是启动X window 后自动运行某个X window程序。如果系统默认的启动级别为3,那么如果要在系统启动后自动运行某些应用程序,只需要在某些脚本中加入相应命令即可,不再详述。在X window启动后自动运行应用程序要复杂一些,幸好,kde和gnome都为此留下了自动启动接口。如果在kde桌面环境下自动启动应用程序,只需要把应用程序名字加入/root/.kde/Autostart/目录下即可(这里注意不同用户的根目录可能不同,如用户zyx的根目录可能为/home/zyx)。如果在gnome桌面环境下自动启动应用程序,只需把应用程序的名字加入/主菜单/程序/设置/会话/会话特性及启动程序的startup programs属性页中即可。  
    7 B" X/ k- X' ^7 O
    + D. X5 P1 d6 u4 b- q. q+ Q( l1 X! j
    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, 2026-4-18 09:12 , Processed in 0.450112 second(s), 57 queries .

    回顶部