QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4250|回复: 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>
    8 ^) f$ N; }- T" p<>本文以redhat 8.0操作系统平台为背景,阐述如何实现启动级别为3时的自动登录,及自动运行相应程序,并简要介绍了如何在redhat 8.0下自动登录X window(系统启动级别为5),并自动运行指定的应用程序。
    . j* y/ s1 E6 c2 [2 `( i- T/ a[b:804aea7097]一、启动级别为3时自动登录的实现[/b:804aea7097] * e0 U6 K" W6 \( K) s( \- U

    ) v- F! `& c* F9 G3 C; S2 ?启动级别为3时自动登录的实现涉及两个软件包:mingetty-1.00-3.src.rpm软件包及util-linux-2.11r-10.src.rpm软件包。
    $ ^/ ?5 @7 c& A  {( W# N# B1 I( y- z* h4 g
    (1)mingetty-1.00-3.src.rpm软件包  
    ; i& q/ O, c$ b5 N/ l5 N- T; f! |6 Y对于启动级别为3的自动登录的实现,仍然需要考察/etc/inittab脚本,    I) \8 m3 S) y) V
    3:123:respawn:/sbin/mingetty tty3 " m) e' r! r2 t" a

    ' B% E) I/ ?& t9 H5 M% a: t$ m) b% H! ~) d1 ]! N8 h! M4 {8 x& s5 g
      2 |% W" h) h. S7 Y' ^9 [% l
    * w+ P' [8 L, S: r" [/ X: G$ e
    ( p. H( _) O5 i! q4 k. U5 b
    因此,如果想在启动级别3的情况下实现自动登录,必须要了解mingetty的功能,甚至要修改mingetty的代码。用命令rpm -qf /sbin/mingetty 可知redhat 8.0版本的mingetty包含在mingetty-1.00-3.src.rpm软件包中,下载该软件包,安装源代码,缺省情况下,代码会安装在/usr/src/redhat/下,我们关心的只是mingetty.c源文件。mingetty.c约有五百行代码,主要实现如下功能: $ Y0 x. G. U) e" C
    5 w( q. i4 `) [
    3 ?' F2 G. o2 n8 {; L$ C3 Y/ E
    打开指定的tty(由参数指定);  
    8 y- m1 }0 G* i6 N; F6 _提示用户登录(login:);  
    6 i$ |+ ^3 e/ {& z获得登录用户名;  6 S$ B  A0 `& H: l
    把用户登录名作为参数,调用/bin/login。  , m. k4 h4 S7 h4 z/ j

    " n# A9 E8 a" ~( |我们所关心的部分实质上只有以下三行:
    9 ?1 B: i: H8 C; ~& g( O+ X: Q2 u- c; t. \

    # p7 Z; [0 B% p  f6 D% I9 W... ...
    5 Z% D$ p% j7 `- p# a, Q" e438 while ((logname = get_logname ()) == 0); //mingetty.c文件438行 1 I% O4 k/ r1 `  m. E5 d; E
    439 execl (_PATH_LOGIN, _PATH_LOGIN, "--", logname, NULL); & [; I, K) S7 Q7 Y) E+ G" m- K+ z
    440 error ("%s: can't exec " _PATH_LOGIN ": %s", tty, sys_errlist[errno]);
    * F" r+ ^1 m1 ~1 J1 d" F9 B... ...
      c' w0 r. g) B. I, _! p$ ]6 U+ A" [7 u+ V3 z
      ) N1 O2 Q3 V: ]: _* |* n( p
    5 E* ~/ d( Q* r" [
    第一行的功能是输出login提示,并获得用户输入的登录用户名,登录用户名由logname返回。因此,可作如下修改
    - J" W% W2 q5 ?
    7 z, y8 V/ ]9 r& t7 G6 Z% _2 w2 @+ Z& l* T2 g$ l1 U3 ?  J6 F, V
    ... ... 8 z3 O4 H5 e2 v8 Y
    438 // while ((logname = get_logname ()) == 0); //注释掉本行,不再提示login: 0 p- U# H0 n0 {- V" n
    439 logname = "root"; //添加本行代码
    8 v, b1 D1 D& H) |. T- b( K# q440 execl (_PATH_LOGIN, _PATH_LOGIN, "--", logname, NULL);
    ( N5 I" `( Y2 |441 error ("%s: can't exec " _PATH_LOGIN ": %s", tty, sys_errlist[errno]);
    ) l& F8 [8 `+ e... ...
    1 o7 H1 Z9 a8 o" h* Y' ]) v$ C  F# o
      
    & M" B' V& Q, B8 A( x+ l: h3 \7 ?6 }+ [% O$ h) u+ A: V6 E% A
    注意,这里假定用户以超级用户身份登录。
    ( r8 X% N3 c; ?: G" t- w7 R2 B. W4 W- V; y" O) Q( A
    第二行以用户登录名为参数,调用/bin/login程序,进一步实现登录。因此,要想实现自动登录,还应该了解/bin/login的功能,必要时还应修改其源代码。
    ; E1 T  L$ l, e* x5 Q0 Z9 z# f& y+ N' K# e
    第三行为出错处理。 ! b* p' d& T% z3 p% ^
    ' T9 f9 k. I3 U! Z
    (2)util-linux-2.11r-10.src.rpm软件包  ; o: Z8 N7 P1 @0 V, f
    采用同样的方法,查看/bin/login所属软件包(redhad8.0版本的login包含在util-linux-2.11r-10.src.rpm软件包中),下载并安装util-linux-2.11r-10.src.rpm,login可执行文件有几个源文件编译而成,我们最关心的是login.c源文件(大约1500行的代码)。下面简要分析一下login要实现的功能,并对相应部分作必要的修改。 3 `, n) m4 P! b- I9 c( y; ~8 `
    7 ^/ O4 R+ \7 }6 T6 _3 [5 F
    Login程序主要可以分为以下几个主要部分:
    8 G7 R# `& c# T! _
    - }- f  u6 B6 r9 w5 K- _5 h, `1.Login首先检查登录者是否为超级用户,如果不是超级用户,并且存在/etc/nologin文件,则输出该文件内容,并中止登录过程;主要由checknologin()实现;  ( N# w7 a% W2 {
    2.如果登录用户是超级用户,那么login必须在/etc/securetty/中指定的tty列表中实现登录,否则将导致登录失败。同样可以不指定/etc/securetty文件,此时,超级用户可以在任何tty上登录。  
    - E" Y) {3 L5 ]4 q5 D3.经过前两步测试后,login接下来将提示输入登录密码(由getpass()调用完成,有兴趣的读者可参考其手册页面),并进行验证,如果密码不对,则提示重新登录。  
    " U( `& `& E+ b: f  u4.顺利经过密码验证后,login还将检查是否存在.hushlogin文件,如果该文件存在,则执行一次"quiet"登录(所谓的quiet登录指的是,登录时不再提示邮件mail,不再显示最后一次登录时间,不输出任何消息。启动级别为3时,正常情况下输出这些信息)  % d. y% m) v8 x# p# J, k* p
    5.login接下来设置登录tty的用户ID和组ID,并设置相应的环境变量,包括HOME、PATH、SHELL、TERM、LOGNAME等。对于普通用户来说,PATH缺省被设置成/usr/local/bin: /bin/usr/bin:;对于超级用户来说,PATH被设置成/sbin: /bin: /usr/sbin: /usr/bin:  
    6 k  d4 w$ ]5 c7 k1 S( E. H4 W6.login的最后一步是为用户启动shell。如果在/etc/passwd中没有为用户指定shell,那么将使用/bin/sh,如果在/etc/passwd中没有给出当前工作目录,则使用"/"。  ( o1 M% N2 `: S' ?
    至此,一个完整的登录过程就结束了。
    8 Q# Q/ U3 H- B7 }
    2 p, T. b0 S% T3 a7 `从以上对login源程序分析过程中可发现,如果要实现自动登录,应该在第三步做文章,设法绕过提示输入密码以及对密码进行验证这一过程。实际上很简单,login源程序对是否要求输入密码设置了一个开关控制passwd_req,缺省情况下,其值为1(passwd_req = 1),即要求输入密码进行身份验证。把该行代码改为(passwd_req = 0)后,问题就解决了。即对源文件作如下修改即可: , q8 e3 a0 x1 H8 A

    0 _# {  y0 {: F. b0 `- j
    , ~. a) ]* o" H% }... ... & Z0 `/ H3 `- Z
    402 fflag = hflag = pflag = 0; //login.c文件402行 ) v6 ^5 T! }5 q  P
    403 //passwd_req = 1   //缺省时,要求进行密码验证,注释掉本行 & z/ E* f8 Z' d) Z/ n6 z0 m
    404 passwd_req = 0 //添加本行
    6 @7 _/ J3 p- c* Y... ... 3 |( \" {: u. P! a( r% W* n$ o

    * \1 L9 n! f6 C  N+ u$ ~  . Z$ A* Y7 Z7 R
    0 H: P) [" m- @8 r+ r9 [
    修改后,可以直接使用util-linux-2.11r-10.src.rpm提供的Makefile进行重新编译,也可以自己对其编译:
    4 _7 }2 q+ e' x+ f, L/ ~2 W
    # d; O% {; ^9 B* I# m9 f
    8 m0 L6 L/ {: E' y* _gcc -o login login.c setproctitle.c checktty.c xstrncpy.c -Wall -lcrypt注意包含后面的编译选项-lcrypt,否则会出问题。 8 H" P: F7 U- f/ q; n7 T  I

    : j! V5 r) X- r- s4 b9 }2 n0 l+ f# I* s
    有了新版的mingetty及login后,拷贝mingetty到/sbin/目录,拷贝login到/bin目录,并将/etc/inittab中的启动级别设置为3,再重新引导系统即可(读者可以自己写一个脚本实现上述过程)。 9 K+ {: v9 y9 J; s0 c* j- v/ a, \% t

    3 ?! w. i& ~% L如果读者对mingetty或login代码的其他部分感兴趣,可以反复修改login.c或mingetty.c的源代码,测试一下代码的功能,这里要注意的是,在拷贝新版mingetty和login之前,一定要把原来的mingetty和login备份,同时还要准备系统引导盘(有系统安装盘亦可,这样读者有机会键入linux rescue),在测试新版程序前更应如此,如果对代码修改稍有不当,系统将不能正常启动。 8 |2 q7 P% f4 m/ m) K' R( g

    3 [. N( c, _" z. c6 b" k* s如果不想再作进一步的代码测试,只是按本文给出的方法进行代码修改,在系统启动上不会出现什么问题。
    + N% w8 K- B3 C5 y% [# P+ D6 x8 B8 \6 E% J. g2 z( u9 P2 k
    [b:804aea7097]二、自动登录后,自动运行特定的应用程序[/b:804aea7097]
    ; X& l5 w, F; `& k( m- i
    ) s, b/ T$ n: b) ]5 z2 X& G% @/ N3 e在实现了启动级别3时的自动登录后,自动运行应用程序非常简单,把应用程序添加在/etc/rc.d/rc.local脚本中既可。(读者可以尝试一下把startx加入脚本中,看一看效果如何。在某种意义上,又增加了一种自动登录X window的方法) 5 ], N5 u0 i( {7 w3 ^
    1 s7 T' X4 E' \3 D& V& }8 c
    [b:804aea7097]三、对自动登录X window(系统启动级别为5),并自动运行指定的应用程序的补充[/b:804aea7097] ' s! p  ~8 E8 l, M1 o! M* H$ W6 ]

    ' `, C" }. J/ ~/ M+ L$ n在"如何实现自动登录linux"中,主要以redhat 7.2平台为背景进行阐述的,其中的自动登录部分可以直接用于redhat 8.0中,不需要任何修改。
    3 T( ^/ @7 \: y$ a. d  P/ l3 ?$ H& @2 {- t- ]1 _
    但是,登录后自动运行应用程序的接口在redhat 8.0中有所不同,主要是登录gnome后,自动运行应用程序的接口有所改变:首先点击面板上的GNOME帮助(那个红色的小帽子),然后选择/其它/首选项/Sessions,在Session对话框的启动程序属性页中添加要启动的程序即可。 - u/ O7 L6 V% q# D1 t
    , ~( R. H0 @! ?6 c  a% N6 l0 c  n
    对于登录kde后,自动运行程序的接口没有改变。
    ' k, E' ]& h! C9 N% O$ V8 F( w7 E+ d4 x$ m: b& o! o
    [b:804aea7097]四、结论[/b:804aea7097] ; V# b3 _/ p) v0 U: h. z: p
    $ s# a" O5 j$ U$ }) K3 m. ~
    本文同"如何实现自动登录linux"一文,基本上解决了如何实现自动登录Linux,并自动运行相应应用程序的问题。对于两个最常见的启动级别(3、5),都给出了各自的方法。   g" M4 j% B( v9 H* L, h
    % J4 ]4 L; d9 s
    在系统初始化到mingetty及login这一阶段,内核实际上已经完成了引导过程,已经到了系统初始化的最高阶段,与内核没什么关系了。此时,主要是/sbin/init根据/etc/inittab的内容而相机行事。读者可通过(man 8 init)或者(man 5 inittab)了解更多东西。
    1 q4 a& @3 W  t5 J$ t5 e7 y0 i6 [4 T& U1 J& L3 x' [2 T
    在对文中提到的软件包修改时,请遵守GNU General Public License(GPL)相关标准,另外,替换login通常被视为黑客行为,应当谨慎行事。   Z) D2 S. ~9 ~' {3 I+ p

    - ?7 x" S& O5 A6 y% Y; Z5 B
    7 k. k( U1 D  t6 b& o# O" l: P7 f3 q
    * Q6 v& c) a/ V4 K% @[b:804aea7097]参考文献[/b:804aea7097]
    " k/ ?% Z/ u! Y3 [& W4 ~& e
    ( u0 D0 R0 \  K# ^: s0 U* |/ D7 Y- o' r+ I0 s! ~+ U3 I
    1.login手册页面  
    $ G, a+ K! N2 d+ h+ {; G2.mingetty-1.00-3.src.rpm,在redhat 8.0的发行版本的源代码中,包含该软件包;  
    0 `6 V* @7 G& i' F& `2 Q# I8 b* i3.util-linux-2.11r-10.src.rpm,  + w, h- r- j% R8 P( D: ]

    / b, W4 ]  ^; G2 [. t9 {& k; r/ P: P可在http://rpmfind.net/linux/RPM/redhat/8.0/i386/util-linux-2.11r-10.i386.html处下载,注意下载源代码包(..src.rpm) 9 R  f% _0 v3 ]) q: R
    7 K/ M: ?9 Y# E& ~( W5 ?/ ?$ e7 y
    [b:804aea7097]关于作者[/b:804aea7097]  
    . }2 T7 C: T1 s& j6 q2 [3 y/ R0 L" P4 O3 g  B. t3 j
    郑彦兴,男,现攻读国防科大计算机学院博士学位。您可以通过电子邮件 mlinux@163.com和他联系
    * }9 G  ]4 j+ g. a7 r% v: q( x
    ' p9 @8 ]3 N, f( K</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)
    ; H( P. T8 j. Q( o* i) m" T
    ! E- H* i) g0 V& I" c机自动登录linux,并自动运行X window应用程序,有其特殊的应用背景,如基于linux平台的监控系统,linux启动后不需要身份验证,而直接运行监控程序等等。本文以Redhat7.2为平台,结合linux启动过程,介绍了如何避免身份验证自动登录,并直接进入X window自动运行应用程序。
    & P5 ?1 O3 ~& K/ R9 P一、linux启动的最后阶段的工作 8 F0 G& T0 ]3 [5 I: z

    " [4 a; L5 a2 `1 {$ k1 B. ?linux 在启动过程的最后阶段(具体启动步骤略),init 会根据 /etc/inittab文件的最后一行x:5:respawn:/etc/X11/prefdm -nodaemon运行/etc/X11/prefdm脚本,(Red hat 7.2缺省时是这样的)。prefdm脚本的主要任务是完成X window的启动,可以有几种启动X window的方法,都包含在prefdm脚本中,几种主要方法有: 8 f1 Q2 V& G5 y' |, f/ _
    $ i0 ]8 g6 |4 |/ l
    运行xdm启动X window;  
    . o% H2 e# ?3 S" m6 S6 t3 m1 U+ I0 t$ N运行gdm,进入gnome桌面环境;  / k9 q8 o  C$ m" j0 j7 I: R
    运行kdm进入kde桌面环境;  3 r2 F4 L& ?4 t+ x; P% Z
    自动登录进入linux;  
    ' b- v$ p: n1 K* V' V, C7 uprefdm脚本框架大致如下: 8 L) B. w, J- ?* Z" b) }
    8 ~9 \  j, E! [8 q
    #!/bin/sh 4 A' q- {. H+ z+ U5 _- M
    PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin
    , }9 N) B8 T. I& \3 y/ L. /etc/profile.d/lang.sh
    ' `2 M# ]% U3 D) W2 Z) @0 |- J# 第一步:查看是否为自动登录 4 Z. w: q% O8 F9 x8 o- U
    if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then ) V% {1 T4 W- L" G' I) ?7 b8 Z
    if /usr/sbin/autologin; then : L% d2 ~. Q2 Q, ?) [& o
    exit 0
    * z- j5 n: b) ?6 ~0 jfi 8 x) s# l6 x) t  n; v- {
    fi
    * O4 I+ F6 c/ ]& D2 h- ~( @5 z9 n+ V" k; ^; d
    # 第二步:如果不是自动登录方式,就会在/etc/sysconfig/desktop中搜寻用户偏爱的登录方式
    6 i2 L2 X; z# J4 l...... + U% s. `6 `/ a: w( ^
    # 可以是kdm、gdm以及xdm,并运行相应的kdm、gdm以及xdm。
    ' Y! E* b  f% w+ R......
    & ^  W* ?9 u7 G! [9 R5 p7 t
    , I2 Z# X& D% e* g4 {  
    ' E" |% _" j& a7 s+ P% G0 `0 _% a- E7 E6 P1 U+ Z8 K2 x

    1 k5 P* Q$ j, |+ k+ \. i二、自动登录的实现(autologin的实现)
    0 Q1 s6 u( g( ^! G& X6 L8 t+ j- c
    ! H5 W. l. _( @" Y. o在/etc/X11/prefdm脚本中,是否实现自动登录有一个条件测试开关,事实上,可以在这里注释掉测试开关,直接执行启动X window的操作。
    " f. U0 L6 ~, M" [0 Q
    ( J6 x1 U$ E/ K. I0 y5 N  [; r+ I自动登录实质上就是绕过身份验证,直接启动X window。X window的启动可以由xinit来完成。
    4 S5 z, `1 @- m" E4 r
    ( |# A/ j0 r0 O& Y, \# hXinit用来启动X window系统服务器以及系统上的第一个客户程序,可以通过为xinit传递命令行参数的形式指定要启动的服务器及客户程序。如果不传递参数给xinit,它将在用户的根目录下寻找并运行 .xinitrc脚本来启动客户程序;在用户的根目录下寻找并运行 .xserverrc脚本来启动服务器。如果xinit在用户的根目录下找不到.xinitrc、.xserverrc,xinit将使用缺省的X :0。  / A& c- {% N1 n- ~4 \
    实际上,用startx来启动X更为方便。对于运行单一会话的X window 系统,startx提供了更为良好的用户接口。同样,startx首先在用户的根目录下寻找 .xinitrc及.xserverrc脚本,如果找不到这两个脚本,startx将使用/etc/X11/xinit/xinitrc以及/etc/X11/xinit/xserverrc脚本。  
    6 j. Z  L7 B8 P. D+ _! ~: cstartx脚本的最基本框架是: ; l$ `  M3 }3 O6 t

    8 E5 {  p* L2 Z8 V) p  x# ra、 寻找.xinitrc,如果没有则使用xinitrc;
    # |% C9 Z) c3 E& R" n, x8 tb、 寻找.xserverrc,如果没有则使用xserverrc; 0 V/ t  e0 z6 z8 A5 r
    c、 根据找到的脚本确定xinit的参数;
    $ u+ a, K" h. l! C& x: m. {4 ?) R& V" F9 P& V
    由此可看出,startx在不需要传递任何参数的情况下,可以完成启动X的任务,因此,可以如下修改/etc/X11/prefdm脚本来实现自动登录:
    / y* p% X7 r/ u" \+ [, }6 J: i3 R: L$ H8 ~2 k: r
      ]4 V% g& K2 j: a% C
    #!/bin/sh
    9 w+ v! J6 [8 I- q, d- ~0 X+ R5 {PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin
    : X: c1 P' d- ?) X  ?. /etc/profile.d/lang.sh 6 r' V4 X$ [1 w
    # 第一步:查看是否为自动登录
    + v/ Z; K- b+ g8 z$ u+ H! m1 k& ]#if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
    8 r# Y: p5 _: P& |4 ~! b8 C) \. g#注释掉上边的条件测试,直接运行startx
    & L" I' O: B7 M1 [5 Mif /usr/X11R6/bin/startx; then
    * F0 K4 a% a; s7 rexit 0 1 Q: s/ Z& Y' q# j; `: Z& c
    fi - r2 b. C9 R/ A* \* }; b' t* s5 K
    #fi
    , T1 b4 k) |' ?* X3 q  v4 ]+ `$ i
    + R) \0 [1 q8 p( B# O3 y0 [" s  9 j7 D! F& h- s; }$ U' l

    7 t3 x) m; k, r( x: I: X. v3 G4 s; x  X8 N6 B' A- I) H
    当然,应确保/etc/inittab中的启动级别为5。 ' I+ p( @' H2 F8 j3 P
    , R1 j+ ]6 d1 ~1 V- e, T* `
    重新启动系统,会发现系统不验证用户身份,直接进入X window,此时的用户身份为root。但是,如果原来root有自己的桌面、默认shell时,上述方法启动X不一定保证还能拥有原来的设置。为了在启动X后,在避免验证身份的同时,又不改变用户原来的设置,那么在运行startx之前,还有工作要做。 7 ]* ]' X, L( l  @% ^7 h
    7 l. D3 D3 Z' M: T- h" Y1 V
    三、自动登录后,保持用户原来的配置(桌面、shell以及其它的一些环境变量)。 6 ]  A, }3 `9 ?# z

    $ h* T- ^9 g! Y, N# E- y# R) Q观察原来/etc/X11/prefdm脚本的自动登录部分:
    1 [; N9 w6 L/ P, Q& |5 h
    0 p6 L& `4 `& F' N$ g* B* E: p3 A8 q* C7 s+ Z7 _( X
    ......
    - a7 F+ w/ [; c. a" m# 第一步:查看是否为自动登录 : C8 A. o# n& O7 {) w4 R. U) ~: E
    if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
    4 s- N, V( Y! d. A% zif /usr/sbin/autologin; then
    # B8 e( [/ I3 i) o+ wexit 0
    ( s2 Q+ ?$ J' p( B+ lfi " r+ \/ o$ |. Y
    fi
    ' b  Q% @0 e2 j......
      }, J; V/ ^5 o) S* b: [0 r
    7 q9 o2 X  Z8 W0 N  2 T7 ^: {* b2 c# I7 _5 C' U' L
    8 R; c5 |6 D. ~) H$ l
    & h. {! M2 [. H: U- j) B
    不难看出,脚本中保留了自动登录的接口:一个可执行文件/usr/sbin/autologin以及一个配置文件/etc/sysconfig/autologin。 * R. p& X; q; q& q( ]0 |
    / h; j2 [* I8 h
    1、/etc/sysconfig/autologin配置文件的实现: 8 C& [3 z/ L7 @2 r  r

    # f+ u: T9 Q5 E; q- e: ?7 @  e& O; a# h2 |* l6 p* E3 ?* E( {
    #config for autologin
    ! D6 j! H4 [0 e, L& nUSER=root
    0 L9 p1 {5 @: e3 ]6 {+ z$ _5 oEXEC=/usr/X11R6/bin/startx " s( M$ q, A  D4 ]
    说明,USER指定自动登录时的用户名;EXEC指定启动X要运行的程序。
    : ?& C6 z4 }' B  h4 m6 P2 [
    1 o' L$ t5 p$ K0 J  1 a6 n' m3 m8 {% N: l% P# _0 X
    ! b0 @9 `+ i4 w; O. s
    9 A' d. O# b* R9 {" Z1 A1 f: W
    2、/usr/sbin/autologin可执行文件的实现: 7 [, y; f9 N# O

    & }3 l( f- G# k1 {8 G( o" [9 v6 w/ K6 s. I
    /********************* " ]3 X% X$ [8 w  P( p( F
    ****  autologin.c  ****
    ' i5 g5 a- v- {/ w9 ?*********************/ " \5 \  I" |/ z, `" O
    #include &lt;stdio.h&gt;
    ( r/ W) U6 v" t- R, R( q6 X- v3 M6 p#include &lt;unistd.h&gt; . K) ]* q$ ^& r- f7 i3 Z) {. p
    #include &lt;string.h&gt; . n( X% Q9 z0 Z" M5 q/ e
    #include &lt;errno.h&gt; - `& z! ^2 T% M* P% B/ X9 N1 l* r
    #include &lt;sys/types.h&gt;
    ( G/ W! J  I9 w#include &lt;sys/stat.h&gt;
    8 v6 r! i9 G: g- A. T#include &lt;pwd.h&gt;
    0 m3 u$ G2 H6 x% t, m- x! t5 ?2 r& `2 ]$ P- \3 j/ }8 k+ x
    int main(int argc, char **argv) 9 }* D7 x# b7 G- p
    {
    . x, S/ I' @0 D' D; wstruct stat st; ( i  e# x' f* K5 J; u& x( V! `  W; w
    FILE *f; ) r$ [  O/ V& q. I
    char *cfg; 2 g0 [: h6 ~. I2 t
    struct passwd *pw;
    ! w+ \; }4 a1 ]4 _% ~* W; w$ Ruid_t uid; 2 D3 ]0 d2 s: D" A4 o
    gid_t gid; 4 Q0 k1 b3 C" O8 D9 x8 q
    char *dir, *shell;   [: O5 D7 a5 N" y
    char *user=NULL;
    2 O# ]6 U1 M! Y# V# Echar *cmd=NULL; 4 M, O. _& `$ y4 \8 k# j6 ^

    8 o, W+ \2 V1 puser="root";
    $ f) [0 {) X4 U$ V  L/*为了能说明问题又保持程序简洁,这里默认登录用户为root,实际上, 3 k2 |, E7 w0 t1 \! {# P% z0 _
    登陆用户名应该从/etc/sysconfig/autologin中得到,
    3 H" A# b. f) X8 E: p程序实现时要注意过滤掉/etc/sysconfig/autologin中的无效用户名*/ % f; s8 A( B; l/ C. F$ `
    cmd="/usr/X11R6/bin/startx"; : O' D4 [* |% ]% N; d) g
    /*同样,这里直接指定启动X window的程序,实际上,该程序应该从/etc/sysconfig/autologin中得到*/ / l% U- z7 h; \' f3 }

    # N* {7 v0 ^% z' K3 |* R. ]pw = getpwnam(user); 8 j- M7 s& c. L9 A
    //getpwnam返回包含用户信息的passwd结构(该结构在pwd.h中定义)。
    , b1 m6 q' B, V2 F( n) ~4 G% [if(pw) { * }3 g6 e3 n; @6 J+ N6 V" b
    uid=pw-&gt;pw_uid;
    + W# ^: W9 o- y) s( bgid=pw-&gt;pw_gid; dir=strdup(pw-&gt;pw_dir); : R: G0 o" `) v! c6 P
    shell=strdup(pw-&gt;pw_shell); # R' U3 J+ n. a. v4 F2 V; p% B, F6 y
    } 7 w4 Z  F$ N* b; G. w
    //获得用户相关信息
    2 S; ~( m7 u& k4 A- H/ J( Z8 I else { * W1 S6 V; f4 `" b5 J* W2 d. [" X
    printf("ERROR: No such user %s!\n", user); - X& ~+ K7 b1 d0 X- e
    return 1;
    - I2 P. a5 h, `. T}   W: V! L) c8 f8 U# X+ y- K
    7 ^% U' A& }: K4 C
    chown("/dev/console", uid, gid); & Q: t/ U7 H9 R
    chown("/dev/tty", uid, gid); 7 N+ F9 h1 O$ [$ n6 ]4 W3 `
    //为控制台和终端设置用户ID及组ID
    ; x# }, L& g8 g- k$ {
    ! g! R- L9 m3 k: w- K5 V//下面是设置用户相关ID ) z$ U  e' P# y4 W" `8 a
    setregid(gid, gid);
    . O+ H0 S9 \' U' X& B% _4 j# \setegid(gid); 6 I1 _7 \( Q; G8 T' l3 X7 X
    setgid(gid); & v# n3 k% D* R- O1 Q
    setreuid(uid, uid); ( p1 g7 m' z3 D- F4 S+ T
    seteuid(uid); ! C  B1 y0 m* i! k. q
    setuid(uid); - Y( H4 u0 z# C/ P

    / a! P1 y1 M, `setenv("HOME", dir, 1);
    5 f0 L6 C  }2 ssetenv("SHELL", shell, 1); ) [1 H' Y; q* s7 m
    setenv("USER", user, 1);
    # K  t, q( a% b0 `setenv("LOGNAME", user, 1); : ^! [, b$ R# m" d% b+ \
    //设置用户相关环境变量 & l# n0 j! W4 P# v2 T

    6 j5 x7 m: o3 ]! q, Ochdir(dir);
    9 U6 [5 X) ^# U( g//切换到用户根目录
    8 T% c( X; e5 O  J$ F3 yuser=NULL;
    5 M! P) h* K- I) M5 E0 L5 S. H3 W8 X: E! q
    execvp(cmd, argv); * O/ z$ O% J9 ?! Z7 h  j
    /*在配置完用户的相关信息后,执行启动X window操作。注意这里默认执行/usr/X11R6/bin/startx */
    5 I! [( @/ M5 @printf("ERROR: Couldn't exec %s: %s\n", cmd, strerror(errno)); 8 e7 C* }7 Z- O) j$ b* |4 ~/ M8 f* A
    return 2; 6 E2 v% J& l4 _1 }( a5 l, N
    } " b1 s- O- ]& }0 V1 J* _9 X
    ! z- |, G) c* A3 V
      
    ! E. n, l8 c: O$ c; h8 m/ K
    6 P9 K3 L' A, v; N3 ?0 x/ ]3 z/ a( E  ~5 ~
    运行gcc -o autologin autologin.c,拷贝autologin可执行文件到/usr/sbin/autologin,拷贝autologin配置文件到/etc/sysconfig/autologin。 重新启动系统,会直接进入X window并保留用户原来所有的风格。
    1 `- i! t5 o) Y- v5 P$ f; P
    : i' x8 z1 Y2 Z8 U3 b" n4 Q如果不需要自动登录的配置文件/etc/sysconfig/autologin,所有的操作都在/usr/sbin/autologin以默认的方式实现(比如,默认登录身份为root,默认执行操作为/usr/X11R6/bin/startx等),那么,/etc/X11/prefdm脚本的自动登录部分可简化如下: 4 _. |2 d. S) ^8 d8 g% G
    ; r/ X- _- L( s! L: h
    1 S( \4 `* ~6 z  b( r$ l
    ......
    2 X- d: W4 Q% ^4 c# 第一步:查看是否为自动登录 3 L) u4 g# z) i5 |2 ]: h+ N
    if /usr/sbin/autologin; then
    % C5 _; D5 S" v$ g2 A" Mexit 0
    0 `  w3 ~8 _3 ^fi , k+ i2 m8 @( |* a
    //第二步 ...... " \# i8 m1 ^+ `; w8 N$ y
    ...... * K$ l0 x' l  L8 M. y

      q6 p+ _* V! `* Z1 c7 N8 g4 ~  
    ! m3 |( y$ e4 i" F9 c8 p8 {& L5 S$ m$ F8 v4 L% G

    % s/ E% @9 X2 I& d5 H& K即在脚本中去掉条件测试开关,直接执行/usr/sbin/autologin,这时,只需要拷贝autologin可执行文件到/usr/sbin/autologin,不再需要拷贝autologin配置文件到/etc/sysconfig/autologin。
    ! r$ J2 \3 E6 W8 c9 Z2 v% U+ M$ S" I/ L; P3 C! T! X, {( t
    四、选择进入kde或者gnome,并自动启动X window应用程序
    & J; Y/ c# V5 K; p" g: o
    & D, g0 \! A$ M, o. c  C5 V+ v如果重新启动后系统进入了kde,而用户需要进入gnome,只需运行switchdesk gnome在重新启动系统即可,以后每次启动时会自动进入gnome;反之亦然。  & }; S# K& k) Y0 j' L: C
    一般系统自动登录的目的是启动X window 后自动运行某个X window程序。如果系统默认的启动级别为3,那么如果要在系统启动后自动运行某些应用程序,只需要在某些脚本中加入相应命令即可,不再详述。在X window启动后自动运行应用程序要复杂一些,幸好,kde和gnome都为此留下了自动启动接口。如果在kde桌面环境下自动启动应用程序,只需要把应用程序名字加入/root/.kde/Autostart/目录下即可(这里注意不同用户的根目录可能不同,如用户zyx的根目录可能为/home/zyx)。如果在gnome桌面环境下自动启动应用程序,只需把应用程序的名字加入/主菜单/程序/设置/会话/会话特性及启动程序的startup programs属性页中即可。  1 x" ], }# G! _9 Y# p1 x! `

    1 y7 J5 D) a  S: q% i# w- o
    ( J8 P' i( ?; F$ }8 r3 a* Khttp://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-14 04:44 , Processed in 0.418887 second(s), 57 queries .

    回顶部