QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4209|回复: 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>
    ) e3 {- ?' K: J: M4 J  \+ n2 S<>本文以redhat 8.0操作系统平台为背景,阐述如何实现启动级别为3时的自动登录,及自动运行相应程序,并简要介绍了如何在redhat 8.0下自动登录X window(系统启动级别为5),并自动运行指定的应用程序。
    , ?: a* ?* |5 x5 b[b:804aea7097]一、启动级别为3时自动登录的实现[/b:804aea7097] % q9 {' K3 X5 r2 _( g

    - I% [3 y, W. Y' P1 b+ ^& L  Y启动级别为3时自动登录的实现涉及两个软件包:mingetty-1.00-3.src.rpm软件包及util-linux-2.11r-10.src.rpm软件包。 1 U9 d' o" @4 l4 j
    ! N  ]% ^. B  Z! H8 }
    (1)mingetty-1.00-3.src.rpm软件包  " y8 h3 D* a$ U& P0 U
    对于启动级别为3的自动登录的实现,仍然需要考察/etc/inittab脚本,  " M" C/ V0 j4 r, H  y0 G! I  O
    3:123:respawn:/sbin/mingetty tty3
    & r; |6 J3 {8 v: ~. _
    6 Q& |9 ]/ X: N' f9 [' [  f+ p0 I/ u! L# v7 D
      - F. v" p' ?: x: u/ P2 @" b7 m% f
    2 v3 M8 [3 F6 ^+ w. A

    8 q" }$ Y- I! K因此,如果想在启动级别3的情况下实现自动登录,必须要了解mingetty的功能,甚至要修改mingetty的代码。用命令rpm -qf /sbin/mingetty 可知redhat 8.0版本的mingetty包含在mingetty-1.00-3.src.rpm软件包中,下载该软件包,安装源代码,缺省情况下,代码会安装在/usr/src/redhat/下,我们关心的只是mingetty.c源文件。mingetty.c约有五百行代码,主要实现如下功能: 6 n! ]1 W' i1 @; R4 u% B2 ]" \
    + B9 \/ b2 j, o
    ) ]  D" k3 A$ ?7 l2 q
    打开指定的tty(由参数指定);  / e  |& e' m) c- V" }& P4 `
    提示用户登录(login:);  3 @; m- S2 ]; q% `' ]# _4 w
    获得登录用户名;  1 }5 L6 O+ `  v3 w0 N" ~1 `+ B
    把用户登录名作为参数,调用/bin/login。  
    # B/ o8 j" D8 g) p
    ( w5 T6 b# n3 B- f# O8 a$ s我们所关心的部分实质上只有以下三行:
    , ~. c4 m, @  g3 X6 e. l' v
    ' Z8 {3 G8 K' F! ]: U+ V. M( l$ _0 M; |% n- }
    ... ...
    5 b6 ^3 A) }1 y+ n* y: i" h438 while ((logname = get_logname ()) == 0); //mingetty.c文件438行 8 Q/ s$ k8 ?) |/ U  e9 ?& @1 g
    439 execl (_PATH_LOGIN, _PATH_LOGIN, "--", logname, NULL);
    ) d( q% _& o* H9 B; X440 error ("%s: can't exec " _PATH_LOGIN ": %s", tty, sys_errlist[errno]);
    $ }% x" P1 b, {$ c4 G6 c" Z4 t- t1 S... ...
    2 a4 d8 s4 ~, a+ Q
    ' B  {# N- t) q8 K  
    6 y$ J# {% R: K' [" Y/ s5 I  R: `; |# x6 h+ a1 M2 l) z! o& Y
    第一行的功能是输出login提示,并获得用户输入的登录用户名,登录用户名由logname返回。因此,可作如下修改
    + D- k: p- n5 r6 }! p9 Z8 l" L' |
    " g8 R) L& m' d( U, M$ O9 Y; z2 I3 U, g* y+ t- \+ z
    ... ... # r( p/ b% W* m  V, ^2 X
    438 // while ((logname = get_logname ()) == 0); //注释掉本行,不再提示login: ! h% s2 z- f1 O6 x
    439 logname = "root"; //添加本行代码 5 S6 M/ W0 {# U( o- f3 ?
    440 execl (_PATH_LOGIN, _PATH_LOGIN, "--", logname, NULL); " M9 I( e, p5 p: ^- }9 I5 F
    441 error ("%s: can't exec " _PATH_LOGIN ": %s", tty, sys_errlist[errno]);
    4 ~8 L& o! l* i% I... ... ' m0 P1 ~! X2 `3 f

    " P6 Z" V9 y# |  
    4 u' j" n5 n% `, n9 f; h. p# H
    * b5 ]& a+ {" X注意,这里假定用户以超级用户身份登录。 : G- f$ u% P2 W
    1 m1 U3 [4 y7 Y
    第二行以用户登录名为参数,调用/bin/login程序,进一步实现登录。因此,要想实现自动登录,还应该了解/bin/login的功能,必要时还应修改其源代码。
    0 E+ L: e  c4 o* O2 I0 u% Z3 d+ p' n3 n/ B" ^8 T" K
    第三行为出错处理。
    7 g$ u  |. Z# m/ J$ K; |! R1 P* k2 f
    (2)util-linux-2.11r-10.src.rpm软件包  
    ) M0 c) Y, q& z: w  q$ k采用同样的方法,查看/bin/login所属软件包(redhad8.0版本的login包含在util-linux-2.11r-10.src.rpm软件包中),下载并安装util-linux-2.11r-10.src.rpm,login可执行文件有几个源文件编译而成,我们最关心的是login.c源文件(大约1500行的代码)。下面简要分析一下login要实现的功能,并对相应部分作必要的修改。
    0 U6 w5 @* q; Y! ^! ?, [% k* s$ A& ^  q: k
    Login程序主要可以分为以下几个主要部分: # Y1 f/ W5 i4 I( N  _
    ( P  W0 Y" v, [% c; W/ l! l
    1.Login首先检查登录者是否为超级用户,如果不是超级用户,并且存在/etc/nologin文件,则输出该文件内容,并中止登录过程;主要由checknologin()实现;  % q1 K( I  B: ]. Y* ?  g2 k! ~4 [
    2.如果登录用户是超级用户,那么login必须在/etc/securetty/中指定的tty列表中实现登录,否则将导致登录失败。同样可以不指定/etc/securetty文件,此时,超级用户可以在任何tty上登录。  % R# `" Y/ V; y0 Y; ~
    3.经过前两步测试后,login接下来将提示输入登录密码(由getpass()调用完成,有兴趣的读者可参考其手册页面),并进行验证,如果密码不对,则提示重新登录。  
    7 v3 [- o5 i: j( h2 Q3 H( o2 g4.顺利经过密码验证后,login还将检查是否存在.hushlogin文件,如果该文件存在,则执行一次"quiet"登录(所谓的quiet登录指的是,登录时不再提示邮件mail,不再显示最后一次登录时间,不输出任何消息。启动级别为3时,正常情况下输出这些信息)  
    ; z( L8 o# q, X) b, y# Y: }5.login接下来设置登录tty的用户ID和组ID,并设置相应的环境变量,包括HOME、PATH、SHELL、TERM、LOGNAME等。对于普通用户来说,PATH缺省被设置成/usr/local/bin: /bin/usr/bin:;对于超级用户来说,PATH被设置成/sbin: /bin: /usr/sbin: /usr/bin:  
    * S) J3 L$ X3 n) k" a6.login的最后一步是为用户启动shell。如果在/etc/passwd中没有为用户指定shell,那么将使用/bin/sh,如果在/etc/passwd中没有给出当前工作目录,则使用"/"。  0 @8 U5 D6 v; S: B& V$ i5 Z- v
    至此,一个完整的登录过程就结束了。
    " N) A, W6 q+ {, p
    7 G  p# d$ e( c* k8 p) H) l- e' G从以上对login源程序分析过程中可发现,如果要实现自动登录,应该在第三步做文章,设法绕过提示输入密码以及对密码进行验证这一过程。实际上很简单,login源程序对是否要求输入密码设置了一个开关控制passwd_req,缺省情况下,其值为1(passwd_req = 1),即要求输入密码进行身份验证。把该行代码改为(passwd_req = 0)后,问题就解决了。即对源文件作如下修改即可:
    2 d8 H( s! u4 c$ s& I* {2 V( w9 X! ~  K' _* r, W

    " `# w' k6 a7 X! V( G... ... 3 n) {% l2 O) ^* J9 ~; [
    402 fflag = hflag = pflag = 0; //login.c文件402行
    ) r7 y7 o, L# R2 D6 I( Q403 //passwd_req = 1   //缺省时,要求进行密码验证,注释掉本行
    3 J, y/ K* C* M4 l8 T404 passwd_req = 0 //添加本行 $ |8 e! r/ `2 y/ y4 X0 ^  p  v0 m) I
    ... ...
    & [4 z. J4 C8 a! }$ ]8 j! `, Z/ K! z! `! P$ ~: h
      
    $ Y6 z3 l) ~- P5 a! i0 H/ ~4 P( J9 B, i, ?
    修改后,可以直接使用util-linux-2.11r-10.src.rpm提供的Makefile进行重新编译,也可以自己对其编译:
    ! _6 k! r9 K& p5 L
    ; F. q3 R" [$ |8 x8 r- R7 {+ R2 {' m6 N! {
    gcc -o login login.c setproctitle.c checktty.c xstrncpy.c -Wall -lcrypt注意包含后面的编译选项-lcrypt,否则会出问题。 - e% P, ]5 W# c* e

    . n8 a3 A& u) n' I0 t
    8 B/ l) |# W: ^& Y5 b- N6 a有了新版的mingetty及login后,拷贝mingetty到/sbin/目录,拷贝login到/bin目录,并将/etc/inittab中的启动级别设置为3,再重新引导系统即可(读者可以自己写一个脚本实现上述过程)。
    ! y/ f( x+ ^" c7 g; t* l2 N
    ) Y: d5 j1 C+ y; A$ i如果读者对mingetty或login代码的其他部分感兴趣,可以反复修改login.c或mingetty.c的源代码,测试一下代码的功能,这里要注意的是,在拷贝新版mingetty和login之前,一定要把原来的mingetty和login备份,同时还要准备系统引导盘(有系统安装盘亦可,这样读者有机会键入linux rescue),在测试新版程序前更应如此,如果对代码修改稍有不当,系统将不能正常启动。
    + F" y6 d; E3 u5 n% q# A, Z* j) H0 Q, W# v% ?. ~% d: N, y! x. K5 Y. U
    如果不想再作进一步的代码测试,只是按本文给出的方法进行代码修改,在系统启动上不会出现什么问题。
    # C( W, I3 y8 V3 j3 w. f' B; D
    $ K5 Q3 |( K: D3 A# I, t[b:804aea7097]二、自动登录后,自动运行特定的应用程序[/b:804aea7097]
    $ y7 b/ s6 F" N
    9 b2 Q1 X1 U5 Z  I7 P  A; [在实现了启动级别3时的自动登录后,自动运行应用程序非常简单,把应用程序添加在/etc/rc.d/rc.local脚本中既可。(读者可以尝试一下把startx加入脚本中,看一看效果如何。在某种意义上,又增加了一种自动登录X window的方法)
    - ]8 o1 r! _1 b5 n
    # |9 c0 b7 b; v9 ^[b:804aea7097]三、对自动登录X window(系统启动级别为5),并自动运行指定的应用程序的补充[/b:804aea7097] * J! z: |1 x6 s* }1 C5 S
    % c, v, O1 L& o& D3 m
    在"如何实现自动登录linux"中,主要以redhat 7.2平台为背景进行阐述的,其中的自动登录部分可以直接用于redhat 8.0中,不需要任何修改。
    . r% A, K: X7 p7 S( X& @( J8 C( P& G
    但是,登录后自动运行应用程序的接口在redhat 8.0中有所不同,主要是登录gnome后,自动运行应用程序的接口有所改变:首先点击面板上的GNOME帮助(那个红色的小帽子),然后选择/其它/首选项/Sessions,在Session对话框的启动程序属性页中添加要启动的程序即可。   m: D# ^  P# G4 x
    4 A* s: l6 Z9 n3 F! a7 [
    对于登录kde后,自动运行程序的接口没有改变。
    ) `+ p) W1 J8 p$ b: t& [$ b! |8 M4 \. i) z; y
    [b:804aea7097]四、结论[/b:804aea7097]   F9 C& ^: T( a7 |3 t
    8 s" @4 F2 v( U" q) f/ D2 e3 F
    本文同"如何实现自动登录linux"一文,基本上解决了如何实现自动登录Linux,并自动运行相应应用程序的问题。对于两个最常见的启动级别(3、5),都给出了各自的方法。
    2 I1 f, C" F( e' d7 r
    ) Y% s  W5 b% C2 J在系统初始化到mingetty及login这一阶段,内核实际上已经完成了引导过程,已经到了系统初始化的最高阶段,与内核没什么关系了。此时,主要是/sbin/init根据/etc/inittab的内容而相机行事。读者可通过(man 8 init)或者(man 5 inittab)了解更多东西。
    / B+ _  Y: I3 h4 A  n& M1 a6 T
    5 L+ v- S! @, {1 i/ B3 W在对文中提到的软件包修改时,请遵守GNU General Public License(GPL)相关标准,另外,替换login通常被视为黑客行为,应当谨慎行事。 ; _% r9 F; k1 X2 ~6 [
    & s7 q) w6 R3 e, K! w( q0 l6 E

    / V: J% X5 w/ s. A- f* M, y
    2 G- I' Y/ W( e, N" A! G( G+ `[b:804aea7097]参考文献[/b:804aea7097]
    ; S* _/ e  t; F) v- X% G6 J1 W) p. S8 r2 p# o& m) F

    9 `/ n! {! b* s" t$ T1.login手册页面  5 a2 ~9 @+ {1 T
    2.mingetty-1.00-3.src.rpm,在redhat 8.0的发行版本的源代码中,包含该软件包;  1 i# z" O9 s& Q
    3.util-linux-2.11r-10.src.rpm,  
    * Z5 x6 J: m) G  K1 ]8 i: a# _4 P/ i
    可在http://rpmfind.net/linux/RPM/redhat/8.0/i386/util-linux-2.11r-10.i386.html处下载,注意下载源代码包(..src.rpm)
    4 g7 Y; `. f4 i' z: i- r8 s
    : O4 I3 i$ s2 f4 Q# \[b:804aea7097]关于作者[/b:804aea7097]  
    4 p! T1 q4 |; N* p7 `1 m* z1 r( r: b% F
    郑彦兴,男,现攻读国防科大计算机学院博士学位。您可以通过电子邮件 mlinux@163.com和他联系
    ( b, y5 T" }) A+ a5 P
    / ^% R; u; A! O</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 N4 N" G- f# V, ^4 F* j. z# L6 I

    ; `7 s# [% n6 @7 s* i机自动登录linux,并自动运行X window应用程序,有其特殊的应用背景,如基于linux平台的监控系统,linux启动后不需要身份验证,而直接运行监控程序等等。本文以Redhat7.2为平台,结合linux启动过程,介绍了如何避免身份验证自动登录,并直接进入X window自动运行应用程序。
    & ?3 A7 ?) P* R( q# E( L一、linux启动的最后阶段的工作 ' L7 _, N4 e9 ?
    4 ?0 m2 f6 y0 q5 @
    linux 在启动过程的最后阶段(具体启动步骤略),init 会根据 /etc/inittab文件的最后一行x:5:respawn:/etc/X11/prefdm -nodaemon运行/etc/X11/prefdm脚本,(Red hat 7.2缺省时是这样的)。prefdm脚本的主要任务是完成X window的启动,可以有几种启动X window的方法,都包含在prefdm脚本中,几种主要方法有:
    5 l2 N% D* E! N' D5 d0 C% H- l5 _
    ( _/ t9 m3 o) o, i6 k运行xdm启动X window;  9 X- }4 f8 x4 K$ P
    运行gdm,进入gnome桌面环境;  
    " `: `# m/ n' R- b- q$ Y运行kdm进入kde桌面环境;  ( j* P7 Z2 A( f- h! @' A5 X9 |
    自动登录进入linux;  ! O; z- _' Y- ^2 w8 @1 A+ _
    prefdm脚本框架大致如下: 6 U( h& R4 [  H$ q8 \
    1 a6 d+ @, r# G- Q4 a7 _" F
    #!/bin/sh : p0 {# E- l7 Y/ ?. t
    PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin
    + f& B; f  W/ ]0 Z( `" _+ R6 ~. /etc/profile.d/lang.sh
    : }; V0 |. X" G# 第一步:查看是否为自动登录 4 D8 f& H3 t4 G4 n7 e
    if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then / Z* F% G( q% ^3 V/ E
    if /usr/sbin/autologin; then 5 f9 V7 K7 q5 M, r' W6 [
    exit 0
    1 A2 V' L5 [7 l# B) k# Bfi
    2 i- Z  Z( l, f* D! B  Z8 Bfi
    % q4 f; }. I3 w7 V9 ^) I; Z
    8 T; F! X$ [: d: B+ ?& C1 a# 第二步:如果不是自动登录方式,就会在/etc/sysconfig/desktop中搜寻用户偏爱的登录方式 : I% M# t7 x' j8 Q
    ......
    & h) v: N6 j0 {9 w- g$ ]# 可以是kdm、gdm以及xdm,并运行相应的kdm、gdm以及xdm。 9 E/ |# v6 p7 S) r& Z" e* @/ ~
    ...... 0 A% E& v# F4 s
    0 C: Q" [% j- G6 ?% _
      
    ! N. H8 _9 Y* M5 o1 R3 m, b% J6 d8 c, @: `0 m% o  \

    % `& |1 r  {7 _二、自动登录的实现(autologin的实现)
    5 |; S3 A; S( X; f2 @2 I/ A5 D. R- S3 |3 k0 q% E* D, p
    在/etc/X11/prefdm脚本中,是否实现自动登录有一个条件测试开关,事实上,可以在这里注释掉测试开关,直接执行启动X window的操作。 1 c+ E& ]3 q/ t: z
    ! w( Q! z7 j' I2 f
    自动登录实质上就是绕过身份验证,直接启动X window。X window的启动可以由xinit来完成。 + p% @0 }2 b% \% H

    $ ~4 o+ h* R( R6 H8 C7 |0 Z. [Xinit用来启动X window系统服务器以及系统上的第一个客户程序,可以通过为xinit传递命令行参数的形式指定要启动的服务器及客户程序。如果不传递参数给xinit,它将在用户的根目录下寻找并运行 .xinitrc脚本来启动客户程序;在用户的根目录下寻找并运行 .xserverrc脚本来启动服务器。如果xinit在用户的根目录下找不到.xinitrc、.xserverrc,xinit将使用缺省的X :0。  3 ~! w+ W  z( _4 S3 ~
    实际上,用startx来启动X更为方便。对于运行单一会话的X window 系统,startx提供了更为良好的用户接口。同样,startx首先在用户的根目录下寻找 .xinitrc及.xserverrc脚本,如果找不到这两个脚本,startx将使用/etc/X11/xinit/xinitrc以及/etc/X11/xinit/xserverrc脚本。  # X* L: L( D1 _
    startx脚本的最基本框架是: 8 Y2 @) J7 f1 y' }9 G6 `

    ) w+ H+ s1 Y# A* C- w, F1 k" Na、 寻找.xinitrc,如果没有则使用xinitrc; " p2 @" `6 v3 D* {% a
    b、 寻找.xserverrc,如果没有则使用xserverrc;
    0 a6 B$ K! ]( e* }  ^8 Xc、 根据找到的脚本确定xinit的参数;
    " H. Q* J7 G1 w0 U, {
    $ D) r# v) X0 \* D) D: N$ F! \由此可看出,startx在不需要传递任何参数的情况下,可以完成启动X的任务,因此,可以如下修改/etc/X11/prefdm脚本来实现自动登录: # w! G- ?' U( ]3 @' Q+ ?% A
    9 ]# ?) i1 p. T6 L8 C

    % H, @2 Y7 S% q0 @#!/bin/sh
    3 w4 t! H9 L. Y: R/ {% WPATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin
    8 D! u" a/ v  j+ }. H% Q$ X; G. /etc/profile.d/lang.sh
      S. G, G7 e( d5 l# 第一步:查看是否为自动登录 $ s  K, P0 i2 V0 f0 `+ E! @
    #if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
    $ V. O! j; h- Q#注释掉上边的条件测试,直接运行startx 2 l3 j& t2 K# e+ @$ F9 x, A
    if /usr/X11R6/bin/startx; then
    : O9 @) p' {% m  A  nexit 0 ! F- S  Q) W+ S8 r4 Q  x& O
    fi
    0 R8 r4 V" y$ T; b/ f. V#fi * h+ J6 Z# Y' e% `8 j3 E

    9 S; c2 d, N$ _, G  j  
    2 g! o* y. k/ q2 c+ u; z; d
    ) R. j4 t. Z, b! h
    ; m9 h8 n" n6 z( B0 E6 `当然,应确保/etc/inittab中的启动级别为5。 0 @  a5 R4 v7 C5 G1 D/ f$ t

    ) o& K7 w+ L1 r: s+ r重新启动系统,会发现系统不验证用户身份,直接进入X window,此时的用户身份为root。但是,如果原来root有自己的桌面、默认shell时,上述方法启动X不一定保证还能拥有原来的设置。为了在启动X后,在避免验证身份的同时,又不改变用户原来的设置,那么在运行startx之前,还有工作要做。
    & ~6 ]6 q5 e7 R7 j) L0 d. Q" V& _" [) W& t( L, V/ N% }3 c* e* X
    三、自动登录后,保持用户原来的配置(桌面、shell以及其它的一些环境变量)。
    ! a2 F/ R! [% F6 M. o
    $ x8 J; p" p# O' S1 h  g观察原来/etc/X11/prefdm脚本的自动登录部分:
    0 H. O, D, \( r
    2 O3 M8 [# Z6 g5 u! ^
    7 K: q7 S' U6 z( P7 E...... + Y! O, q% h" v" P
    # 第一步:查看是否为自动登录
    7 G# B, e3 M7 b$ y* Q1 Dif [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
    # I# U9 P4 c7 s2 C- Z2 n# jif /usr/sbin/autologin; then 3 @3 J5 Q* X/ e* b: r6 r
    exit 0 0 t: ~1 X& [! H+ L) r
    fi ! r# }* P  G% i" K
    fi # R5 w: K0 ?' j" H
    ......
    0 ]+ \$ H0 [( k# V1 ]; }$ k  |
    / e0 j" N" L5 |  
    ' T; ?# y# {( B! J# M4 O; D& s
    1 H+ _* t9 E1 s0 W
    - p: r" N2 F: n9 ]不难看出,脚本中保留了自动登录的接口:一个可执行文件/usr/sbin/autologin以及一个配置文件/etc/sysconfig/autologin。
    4 D+ t( }- ?$ O0 v3 M/ L; M  t
    * g2 ]" \+ G: h) j2 @& c8 _# Z1、/etc/sysconfig/autologin配置文件的实现: 9 h6 L; R( |  c: I% ~
    ! @' _1 Y7 c0 e1 R% W. J
    6 k6 ~  |$ B4 `0 {. t1 P
    #config for autologin
    : q0 |* S" J: h: Y, Z, qUSER=root / l/ a+ ^2 u& U* i8 }
    EXEC=/usr/X11R6/bin/startx & [! W5 Q2 G& H$ y) A- Z$ @
    说明,USER指定自动登录时的用户名;EXEC指定启动X要运行的程序。
    9 \2 d' ~  s% ~) w$ W! z! }4 p% _& F2 G# l, {
      " K" y( _. ~! g5 `8 D

    & d/ `& E) k+ ?0 e* b0 D1 d9 E2 s- g. U; f+ ]6 p
    2、/usr/sbin/autologin可执行文件的实现:
    & ^1 D7 S2 ~3 u  u: }
    % m# z$ ~; A" q6 j, [1 ~
    , n; k* |7 m0 m* |6 M/********************* $ W# J2 M* [% O3 ?, ]1 g7 \+ x) N
    ****  autologin.c  ****
    8 C! g! M& \, q. h*********************/ $ Z- T; |' U2 ^
    #include &lt;stdio.h&gt; , N" F: q$ x6 u
    #include &lt;unistd.h&gt; 9 V* ^' [8 \" y1 U
    #include &lt;string.h&gt; 2 s2 l; _, F5 M# V9 _$ u
    #include &lt;errno.h&gt; 5 V+ L0 Q5 ~2 F( Z
    #include &lt;sys/types.h&gt; ( G3 L! s  [; O8 `4 z' @
    #include &lt;sys/stat.h&gt; ! [& m3 o6 M: e* f
    #include &lt;pwd.h&gt; 3 ~) m& L# a$ t5 L9 c4 {
    : v* y7 R" u% \* z( e, L' ^
    int main(int argc, char **argv) 4 i8 n& ]! o9 `; E
    {
    - Q. J6 M, V" ?6 tstruct stat st;
    6 p. d' @# N/ ?8 ?  oFILE *f; + [' y1 Z9 x5 n
    char *cfg; * S. {) t: f6 }5 y
    struct passwd *pw; ! X/ i" ]9 P' R1 t
    uid_t uid;
    2 O& j; `7 r0 c+ p# egid_t gid;
    5 i8 ~5 s0 V! U" k3 P( }1 k2 Y' c0 zchar *dir, *shell;
    9 s8 _0 f# l" q8 ]$ H) I" Tchar *user=NULL;
    . X; s* s/ R  I$ Gchar *cmd=NULL; $ x0 A) s' E. i1 ]/ e( i
    3 o4 a$ ^; ^3 d% A0 P. N; Z. N, P& l
    user="root";
    " G) _2 `, u' _; d/*为了能说明问题又保持程序简洁,这里默认登录用户为root,实际上, 1 O/ w! _# m5 p% B; C  T
    登陆用户名应该从/etc/sysconfig/autologin中得到, % J! i( W' n  y; |
    程序实现时要注意过滤掉/etc/sysconfig/autologin中的无效用户名*/ , Z/ ^' P) \3 @  t; |
    cmd="/usr/X11R6/bin/startx";
    1 H! O4 {& _& y8 z/*同样,这里直接指定启动X window的程序,实际上,该程序应该从/etc/sysconfig/autologin中得到*/ / E* e  ]% i, L- b0 R
    / E: c9 w* D# Q7 }5 i2 m: I* B
    pw = getpwnam(user);
    & x/ m( s) W0 c% e, [2 P: `//getpwnam返回包含用户信息的passwd结构(该结构在pwd.h中定义)。
    $ X, V7 ]9 B/ F) j  r% W3 _if(pw) {
    6 _& H* N7 N* j! }9 e  q% Nuid=pw-&gt;pw_uid; . j. a8 Y3 k1 y! z+ w' L; \
    gid=pw-&gt;pw_gid; dir=strdup(pw-&gt;pw_dir);
    ; \* P. a3 ^$ e" E6 ashell=strdup(pw-&gt;pw_shell); 1 G  [, B. j# W/ q
    }
    7 q9 x6 }# v& U2 X* ~4 b& |//获得用户相关信息
    1 v+ Z& g1 |- O- P2 d else { 0 H& l  m3 u% l. B
    printf("ERROR: No such user %s!\n", user); ! s+ B) @% U, ^8 |5 h8 B
    return 1;
    " {& w$ ]5 T, d7 S$ t} 1 X! y$ B* ?1 @  ^. o

    $ j) @$ O" L7 `/ _$ ichown("/dev/console", uid, gid);
    * S9 C) _, x$ A* W9 i+ V' t1 `. o' Gchown("/dev/tty", uid, gid);
    , \7 F( [, N$ m' U& C//为控制台和终端设置用户ID及组ID
    " ]/ k% ~2 B- `) \& d
    # B5 c5 ~/ N5 F3 J- o/ T//下面是设置用户相关ID
    5 N( V; T* b& g+ F$ e$ Z4 ysetregid(gid, gid); $ C7 y* f  E3 X
    setegid(gid); + n0 n) w0 f" E( e/ |  s
    setgid(gid); 7 u1 `' |, F) F$ }( I% F
    setreuid(uid, uid); / Y& B" W7 W+ `( c/ J& q" m1 X
    seteuid(uid); - J5 N7 }+ c+ c/ @7 J
    setuid(uid);
    # n: L4 T- ]& Z; P1 L2 j; M( R1 B; X6 w5 V/ N
    setenv("HOME", dir, 1);
    + y$ I$ X5 u( T. [( asetenv("SHELL", shell, 1); ( J5 u9 M6 k9 s: n$ h+ k$ D' k" E
    setenv("USER", user, 1);
    # }2 Q  l; E$ R8 g8 lsetenv("LOGNAME", user, 1); & Z0 L- W" @5 I
    //设置用户相关环境变量
    . j/ X6 {" G1 N, F& e
    4 O9 v# I: r( a" }& m) m5 mchdir(dir);
    8 B# F9 M8 I' N//切换到用户根目录
    $ c3 F0 r& ^5 a( G+ U1 l! N. b1 ?user=NULL; * S: _) c6 |% T" A# u$ ]% i& J+ W
    - x+ r4 X; h& e
    execvp(cmd, argv); 1 ~6 ?2 N9 c( K9 |+ i  J
    /*在配置完用户的相关信息后,执行启动X window操作。注意这里默认执行/usr/X11R6/bin/startx */
    / C6 o; ~+ g& j1 ~5 h: H4 Wprintf("ERROR: Couldn't exec %s: %s\n", cmd, strerror(errno)); / v1 g% C1 p4 S" V4 s
    return 2; 6 ~! t$ [( l  ~% \7 w/ ~0 D
    } * q& q( m7 ?; _" A- c/ d9 h

    2 f+ T5 N# B7 j7 a2 d0 H! i  / j7 t, i5 \/ M. k6 N

    2 m# z1 Y! k& C+ b9 C/ K: _
    4 B" ]! R2 Q/ h% S运行gcc -o autologin autologin.c,拷贝autologin可执行文件到/usr/sbin/autologin,拷贝autologin配置文件到/etc/sysconfig/autologin。 重新启动系统,会直接进入X window并保留用户原来所有的风格。
    4 A4 N8 g  D& A, \% n! W, J( H8 R  E- W( o8 s* }1 l
    如果不需要自动登录的配置文件/etc/sysconfig/autologin,所有的操作都在/usr/sbin/autologin以默认的方式实现(比如,默认登录身份为root,默认执行操作为/usr/X11R6/bin/startx等),那么,/etc/X11/prefdm脚本的自动登录部分可简化如下: 1 ~) E* s1 m8 ^2 l; }1 ~9 m9 D
    $ d7 V1 N2 b4 N5 ?3 g
    4 B, ~! h/ A4 F! d  e4 P3 [# x
    ......
    + i" P* E6 u' I5 f/ {# 第一步:查看是否为自动登录
    . F3 G7 P( o- t7 y3 R+ Dif /usr/sbin/autologin; then ! Z3 f  [  p# X. V% i. q6 n
    exit 0 * e5 d% m+ [( _& c5 m1 E
    fi % ]! ^: S7 K$ N( C! C* n% Q( s/ A
    //第二步 ......
    ; V4 G$ Q! W$ j; @+ ~...... 3 |, f% }  N1 d: }
    : e( i, ]8 J, J9 p1 T9 w+ |3 @
      
      A6 x/ d& |; m
    1 E) s- _. m6 k0 c
    . g1 e: I' r1 F即在脚本中去掉条件测试开关,直接执行/usr/sbin/autologin,这时,只需要拷贝autologin可执行文件到/usr/sbin/autologin,不再需要拷贝autologin配置文件到/etc/sysconfig/autologin。
    ( S& K- y6 {0 R0 W% D: {+ `1 @( x9 b0 ~- v4 w9 z2 K+ ]7 t
    四、选择进入kde或者gnome,并自动启动X window应用程序 0 F9 t5 L% f* A) A- R  l
    ' z9 ~7 c7 K7 ]5 U: ?- j: k
    如果重新启动后系统进入了kde,而用户需要进入gnome,只需运行switchdesk gnome在重新启动系统即可,以后每次启动时会自动进入gnome;反之亦然。  $ e& W3 Z8 x* Y# |  N# d" t
    一般系统自动登录的目的是启动X window 后自动运行某个X window程序。如果系统默认的启动级别为3,那么如果要在系统启动后自动运行某些应用程序,只需要在某些脚本中加入相应命令即可,不再详述。在X window启动后自动运行应用程序要复杂一些,幸好,kde和gnome都为此留下了自动启动接口。如果在kde桌面环境下自动启动应用程序,只需要把应用程序名字加入/root/.kde/Autostart/目录下即可(这里注意不同用户的根目录可能不同,如用户zyx的根目录可能为/home/zyx)。如果在gnome桌面环境下自动启动应用程序,只需把应用程序的名字加入/主菜单/程序/设置/会话/会话特性及启动程序的startup programs属性页中即可。  / }+ Q5 a- q; b

    6 S7 O, U- G8 J4 \, K! S/ G' [# h) C$ t
    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 03:11 , Processed in 0.424337 second(s), 57 queries .

    回顶部