|
  
- UID
- 1
- 帖子
- 738
- 精华
- 28
- 积分
- 14391
- 金币
- 2481
- 威望
- 1647
- 贡献
- 1429
|
[Zend权威认证试题讲解]第八章 - 处理电子邮件
没有了E-Mail,这世界会变成什么样?网络交流把人们拉得更近,让公司能够更有效的开展业务,不幸的是,也带来了垃圾信息。; r$ J- x8 `6 v( t6 U
还好,你不需要成为一个反垃圾邮件专家就能使用PHP处理电子邮件的功能。事实上,不管你是在运营一家在线商店,还是在编写一套论坛程序,你都会发现发送邮件是你工作中很重要的一部分——与用户保持联系这点非常重要。( t" [" x- z! \5 s+ v$ d
用PHP编写邮件管理脚本很简单,但也不失挑战性。如果你只是想发送一封文本邮件,mail函数对你来说就够了。而如果你需要处理更复杂的电子信息——例如HTML邮件和附件时,那么你就需要深入学习一下E-Mail的工作原理了。# Z! G$ z' n9 y% e8 W
l2 ~- h: E: T( Z4 [
+ g' T* f" L% L" `: ~, {* o9 C! g
问题
3 T3 e' j4 y- i8 _+ H4 M, z/ K' e$ \4 R5 W; L, g/ d
1.以下哪个不是合法的电子邮件地址?
/ p! R$ m2 h( I3 p' k3 p; ^& f/ }) [: z
A.john@89w.org% K/ d# U; s# L/ R4 s
B."John Coggeshall" <someone@89w.org>
' \9 T: L9 i, KC.joe @ 89w.org
2 F, u# P$ Q# _( t; ID.jean-cóggeshall@89w.org
. D- t# Y1 \4 `0 u, i; d5 }$ q( GE.john% w6 T( {+ q, C" H8 U6 B0 Q
S0 V/ I) E; ]3 _+ s3 X$ A
5 g d0 P+ _2 u8 }7 [2.在PHP中,使用sendmail程序从Windows或Novell系统中发送邮件的方式,与从类UNIX系统中发送的方式不同。以下哪些选项说明了这个不同?(双选)8 w1 E* W r, Q8 d y4 }
0 A8 r, M1 r5 P \8 i5 s0 @5 BA.Windows/Novell不需要第三方软件的支持就能实现该功能2 p( V1 N4 S7 O" w
B.UNIX中,sendmail_from的配置来决定了邮件头中的From:信息。8 w& `2 y7 f* |7 i
C.在Windows/Novell中,你无法发送有多个收件人的电子邮件,每个收件人都必须单独发送
5 Z- X3 Q1 l( ND.有可能完全相同,这取决于sendmail_path的配置7 Z3 a$ j/ c+ o i3 ^# i3 c
E.不同与Windows/Novell,在UNIX中,你必须用SMTP和smtp_port配置好MTA主机和端口: L* h! M1 |, y6 @$ w8 q
1 ]. C7 D6 p) [
% f2 ^2 l2 o3 a* Z/ z) p1 O- n( g3.通过PHP发送有多个收件人或者MIME兼容的邮件,需要遵循什么步骤?* h7 N- Y2 x/ s* P( v! e
; d' E* \2 |# NA.将必要的头信息(header)通过$message参数(第三个参数)传递给mail函数0 k/ s2 o' [; F6 n& u: h0 S% r
B.用PHP代码,通过SMTP直接与MTA连接。
2 J- S4 B9 R: YC.将附加的头信息传递给mail函数的$additional_headers参数(第四个参数),每个header一行。8 i" V! K4 e U& ~+ w( H
D.向多个收件人发送E-Mail是允许的。PHP不支持发送MIME E-Mail。
3 i5 q0 {: w% s# ?! t8 jE.向mail函数传递$additional_headers参数,每个header一行,行以\r\n结尾1 U& c+ h3 `) S9 n: Z4 i1 D
; C+ [. S- y$ I3 b* x, d7 h6 B d1 ]- \- \- `, \
4.使用MIME发送有附件的邮件时,邮件正文和附件必须靠一个特殊的分隔符分开。MIME E-Mail的头信息里如何定义这个分隔符?# G1 l7 E% R* k) E2 y8 W
2 O0 ~1 l( H% }+ d7 F
答案:____________& z4 ^2 |3 ?$ |. @ c
6 E0 H4 {: N6 S/ I& B& V
# ]7 R1 L3 l$ Q! @/ C5.使用MIME发送HTML邮件时,经常会用到一些经典的HTML标签,比如用<img>嵌入图片。以下那些方法能做到这点?(双选)
8 ? J! K- A$ U- [, H# r! l
/ n6 H+ L( n% Q N1 v3 sA.直接用<img>标签把图片文件嵌入邮件内容中,邮件客户端能自动显示' j) L% x" F, {% G8 U, l) t
B.通过给<img>标签添加一个URL的src属性来调用外部服务器上的图片* A. W5 J: R# L
C.把图片作为MIME内容直接嵌入邮件中,再把<img>标签的src属性指定为内容ID
. x8 f1 r3 W' w& Q6 [6 F! |D.把图片作为附件,再把<img>标签的src属性指定为图片的文件名1 m( v4 ]0 I4 s4 w& M2 [
E.只有一个答案正确 ^* d* ~1 U: P) |1 D% J4 P
/ y: E% x& o& T& ~9 p) U7 y! O4 s, F* s: z3 C2 l# A# [) w+ T) ]
6.以下那种情况会用到mail函数的第五个(最后一个)参数$additional_parameters?
8 J* r2 ?& M5 b/ ]/ o
" W$ ?9 `4 _8 mA.从UNIX或Windows/Novell发送邮件时都会用到' b( h! }4 H$ i# v
B.只有在Windows/Novell平台上用SMTP命令向MTA发送邮件时! P: T; z7 Z" j, f, P$ A- q* t# U
C.只有在和sendmail或一个指定了sendmail_path的打包程序协作发送时
, n U0 h8 I7 z4 X1 fD.PHP里用不到这个参数1 ^, ]1 _$ F8 N9 S) I
% y& g; F$ y9 Q E6 M' k- j
' V/ }3 O2 F$ w6 T' B& E
7.以下那种情况需要在头信息中添加邮件内容编码(Content-Transfer-Encoding)?
- O. X' m! j+ O6 p0 `" X
% r6 R4 [1 _1 p3 C: \/ @A.只有在发送非普通文本(ASCII)数据时
t8 b. H2 h% ~) m& W- J% J( zB.需要指出E-Mail的格式时,例如HTML,普通文本(plain text),富文本(rich text)
: D% u) o* S/ z8 q, [C.任何时候都可以用它来指出MIME的编码类型
% E ~1 `* N8 YD.只能用来指定特殊的编码格式(例如base64)
7 v# b8 `) `- w6 rE.以上都不对0 K; H; C( E- _. l, c6 T
! x( K) Y/ @9 K: t2 r0 H8.以下关于在头信息Content-Type中定义的MIME分隔符的描述,哪些正确?(三选)* S Y' M0 j( p4 y$ S( D
2 j3 q/ \" @" G# V N) E! P, H* YA.分隔符至少要8个字符' D% b1 ]/ ], u6 j4 Y* _; S
B.分隔符必须以两个连字号作为前缀(例如:--abcdefghi)和后缀来表示起止(例如:--abcdefghi--)
( g! Q, G& y2 }: {$ j2 S# o( hC.分隔符在MIME邮件中必须是独一无二的* d" {$ p) r7 M
D.分隔符不能嵌套的其他分隔符中
: a2 E8 `6 v I: N& [9 R: DE.用什么做分隔符都无所谓
/ P3 l" j1 B) _& W+ n- I( }2 \" V7 v4 A" l
. ~0 G% T% _. N l9 c$ v. e3 O
9.考虑如下E-Mail:
6 ]- n8 ?6 g# N& I+ n' s" v" P+ n
$ b% B: S* w% G% K& s% tFrom: John Coggeshall <john@php.net>
% w2 j4 Z3 w7 e" ^# c9 v7 |/ |To: Joe User <joe@example.comt>) l, B7 J5 o( v' ]; v+ j$ |
Subject: Hello from John!/ i2 o. f7 @# A9 G4 b
Date: Wed, 20 Dec 2004 20:18:47 -0400
! D# V! \+ l$ W mMessage-ID: <1234@local.machine.example>
$ U; l+ q" }! v3 `( yHello, How are you?
7 R5 C+ d6 @# P+ T
4 W: c+ F% a1 }1 P5 w! N在头信息里添加什么才能让它成为一份MIME邮件?(不定项选择)9 `: H9 A- V1 [, p4 Y, W7 p9 I
1 ?3 `6 m# U1 N6 j
A.MIME-Version% ^7 B3 m L9 H( s+ {
B.Content-Disposition
: K5 W5 h) h% ]7 d2 q/ wC.Content-Type, z& z* \5 i$ A' G4 F
D.Content-Transfer-Encoding
, K+ J- J6 d( y, b, @* \' f* `E.Content-ID
* Z) p$ u* |' b' [9 M. b" ^' W6 k& q: H6 V" m2 l
% a; z0 t8 S8 L- l10.发送一封包含HTML、富文本和普通文本三个版本的邮件,要想客户端能选择一个合适的版本打开,MIME的content-type应该是什么?
: _, g5 e) Z" o, f9 s
5 Z3 j: _5 S$ v5 R0 b; P0 C: g$ rA.multipart/mixed
% M( E! i' V$ K7 X8 m: z1 P/ LB.multipart/alternative* F0 U" r$ m& {. u' Q: P. e
C.multipart/default
) g" X5 o7 J; U$ ^. v( [D.multipart/related
4 p" v( @6 f/ I' O& U6 v9 GE.不可能用content-type实现& h E# n1 r: S) v% S2 J
) k; P. F8 r7 h- D1 {. ?7 Z! O4 x
11.假设你的机器上没有安装sendmail,要想mail函数能在Windows下使用,需要做什么?
% c0 n9 z2 y! x8 v) A9 w2 \& M2 G! E/ _$ \0 S
A.安装sendmail服务器
! \6 S- A: C; [B.安装Microsoft Exchange
: W" B! Z1 S0 b% w; u7 C& DC.在你的电脑上安装任何一种邮件服务器
; x: Q5 ]! s3 I" X3 Y* T5 `; _6 xD.改变php.ini的设置* y1 H$ v, z! K* M3 v, w
E.写一个连接公共电子邮件服务器的脚本0 A3 ~* Q" f4 ^' ]$ u
+ L3 m. P& T. o! h8 h& x% g+ Y: }2 G
3 P, [, n1 s5 R) `3 x$ s12.有一个向用户提交的地址发送指定内容的文本邮件的表单,以下哪种方法有助于防止通过该表单进行跨站攻击?(双选)1 s* Z! ]& M+ C0 n8 H' u
$ E# {5 O( z7 [/ o; }" v, {! y+ sA.使用GET方式传值
' P1 S. H$ \' j! dB.用htmlentities()处理电子邮件地址
6 ?8 U6 f5 d/ Q" N# \8 @( t: i* iC.使用POST方式传值
* R& G4 g* O3 \9 ^9 D5 f/ x: HD.用htmlentities()处理邮件正文
- d) w" {, `4 `/ s0 H& b& D* qE.确保填写邮件地址的文本域不能有换行符
( v0 x0 x7 O) p! P/ D w) S
& Q3 k8 i4 {, A+ \" Z4 Z& @8 M' ]/ M1 o: i! e3 \" ?) r4 I, X* b* B- }
13.如何将一个数组作为附件发送,并要能在接收后重新组合?5 ]! Z/ f$ h7 O+ d4 C2 j
" X; y. I! F' d2 l" z: G
A.用serialize()把它转换成字符串,再用htmlentities()处理一下- @5 R7 A' g# ~. U- ]0 ]7 h J; Y
B.把它存在文件中,并用base64_encode()进行编码
4 g! k: c5 N1 m& OC.用serialize()把它转换成数组* |5 z# P! R' u6 R/ _! f
D.用serialize()把它转换成数组,再用base64_encode()进行编码
1 H8 C7 ?2 V' T, dE.把它存在文件中,再用convert_uuencode()进行编码
7 }! h: _; w# S8 R" b7 y
+ H# k/ N8 N! X! ~0 |
' L3 {% D( I+ @14.要确定需要嵌入在MIME/multipart 邮件中的文件该使用什么MIME类型,以下那种方法最好?
2 S- M' K. @9 \: e6 p& t. P( H9 X, ?+ x T. G- u
A.堆一个检测脚本出来
: S% p" J! W% PB.创建一个MIME类型和文件后缀名的列表,根据后缀名选定需要的MIME类型0 }; I% |$ M( {) Z$ R* q r+ T
C.写一个识别文件MIME类型与内容是否相符的函数9 j8 ]. c/ @0 j
D.使用mime_content_type函数& a6 Y) @+ d- L+ v) P
E.把文件上传到外部服务器上
! c; c- p$ V1 D6 V% R8 q) d- l, \# P3 y% A$ s
0 ?$ b9 a) \% U5 w, \' `+ b15.在UNIX环境下使用本地安装的sendmail,如何才能随意设置邮件的发件人名字与发件人地址?(三选), L0 ^) M' d, O, a/ K7 R
! Q" X" b. j6 z1 ?' u) w
A.添加一个From头信息( b" x. U4 A* k, P- C- f% O N
B.使用-f参数+ B P1 e( |; D, D$ c
C.添加一个Reply-to的头信息* P0 ^1 w9 ?- ~# O8 B
D.确保运行Apache的用户有修改sendmail设置的权利6 h+ T% A# _7 j, Q$ R% e2 R$ z
E.确保Apache在root用户下运行
9 W1 l. ? o. v答案速查2 Y# {* w- H/ t
1:D2 N' ?% L O7 v, M8 O
2:AD
) x* s- T. s* r7 u5 b& Z+ q3:E
4 U' w9 l9 s$ u4 U# f' N# n" ]4:Content-Type:MIME5 P8 l$ T5 N+ V7 B% D. B2 y
5:BC2 X) g# B1 ^0 x& T; C0 t5 I
6:A
! D6 H/ m6 t: K7:C2 H9 X H6 m% X5 G6 n4 W3 _
8:BCE
6 u/ w, U9 A8 _* n+ Z: u* A: K( o9:ACD! b. O) Y3 P% J, f! t& k
10:B3 {/ b8 u4 p. I, z
11:D9 v/ U4 a+ _+ |( ~$ ~& @
12:CE
; a. D+ y! L% C; ?9 r13:D& F! a* ~) P' ~7 ?. v2 T. x
14:D! m( Q" c) q4 ]* c% Z# R z( N. A3 o
15:ABD! d9 A8 [2 M. S: `# T1 c) d
7 A$ l3 }) C$ E5 n. m7 b% e4 C8 q9 z
u& _& b7 Y8 e$ {2 m/ Q答案详解
4 D. z# ^; r' b0 L W0 \2 l' u$ O7 H: s8 n+ }! _. H: a
1.列出的E-Mail地址中只有D不合法。A和B都是最经典、常用的电子邮件地址。C看起来不合法,但邮件传输代理(MTA)会自动过滤多余的空格。E可以在本地发送时使用。那么就只剩下D了,它里面有一个非法字符。 f2 f( s& f% S6 D) M, }
) o0 K9 {# A8 l6 ~. F5 I+ u2.正确答案是A和D。UNIX版本的PHP需要用sendmail程序(或者功能等同的替代品)通过MTA发送邮件,Windows/Novell版本的则通过SMTP直接用MTA发送。然而,如果允许的话,Windows/Novell上的PHP也可以进行配置,来通过“sendmail封装器”模拟sendmail发信。也就是说PHP在这三个版本上能够以相同的方式实现此功能。注意,在Windows/Novell上使用mail()时,需要配置sendmail_from。而UNIX则把这件事交给sendmail程序自己来处理。
& B" _9 y9 r. `- o8 A. m! M# v& y3 P# t4 \0 z" y% H
3.PHP可以用mail函数发送任何格式合法的电子邮件,于是编写用SMTP发信的PHP脚本成为了下策。要在E-Mail中添加额外的头信息,则必须向函数传递$additional_headers参数,每个头信息以一个回车符和一个换行符结尾(\r\n)。发送复杂的邮件,比如带附件的或者HTML格式的邮件,则不仅需要添加额外的头信息,还要添加MIME类型。所以答案是E。
& T- M2 e; G( E# T1 X) d3 N/ ]& l1 O5 ~) r: Z" } D
4.发送由多个部分组成的MIME邮件时,你必须指定一个分隔符(任何US-ASCII字符串),它必须不同于邮件主题中任何一个部分。分隔符必须与MIME信息中嵌入的任何一部分都不同。分隔符在Content-Type: MIME中定义。
* | o X1 F0 M4 s$ ^9 e. j% r) ?4 Y5 ~/ I9 I
5.有两个选项指出了在HTML邮件中包含图片等资源的正确方法。最快的方法就是直接引用一张远程图片。然而,图片以及其他资源能够以MIME内容块的形式嵌入MIME邮件自身。这些内容块会被赋予ID,可以通过把src属性设置为cid:资源标识加内容ID的方式来调用。因此答案B和C正确。
+ \0 K5 t9 |; [, o o9 D7 q+ E3 r" \' L+ f2 @2 g; x) c% A
6.mail函数的最后一个参数用来向sendmail程序传递参数,不过这只能在安装了sendmail的UNIX系统上进行。如果Windows/Novell系统上配置了sendmail_path,那么这个参数同样也是可用的。' l1 m) l; B# s! `2 f1 @
# C% ]/ k7 ], a. P7.答案是C。MIME头信息里的内容编码(Content-Transfer-Encoding)用来指出MIME邮件中各个片段的编码。头信息中包含一组指出了编码算法的二进制数据。默认情况下,7bit,quoted-printable,base64,8bit和binary是可用的编码类型。不过任何人也可以通过使用x-<unique name for encoding>来声明自己的编码格式。
/ ~; E" Q: {( N- `/ d- d; V* R% f6 o/ [/ P$ u6 ?$ B/ S4 V p
8.正确答案是B,C和E。分隔符是MIME邮件中至关重要的一部分。虽然分隔符的长度没有官方限制,但由于分隔符由文本字符构成,因此它绝对不能出现在邮件主体中,否则就会造成混乱。考虑一种灾难性的情况:假设我们用John做分隔符,那么邮件中提到的人名John就会分隔邮件,导致邮件内容的混乱。8 @4 H9 U2 J; e& ]# @2 |8 h! c
/ q9 d) y* g( t0 A7 H
9.要从给定的文本信息中创建一份合法的MIME邮件,正确的答案是A,C和D。MIME邮件在开头处必须有MIME-Version头信息,而邮件的每个片段(包括“root”片段)都必须有Content-Type和content-transfer-encoding这两个部分。答案中提到的另外两个头信息是可选的:Content-Disposition用来指出片段要如何显示(比如显示为附件),Content-ID是片段中的各个内容的唯一识别符。8 v# ?; P& A( \ N. q# N
+ l3 s+ V& L! K7 R5 ?# N
10.正确答案是B。这种特殊的MIME类型用来定义一个含多个内容相同的子版本片段的母片段。比如说,一个multipart/alternative片段包含一个text/plain和一个text/html版本的片段。然后由电子邮件客户端选择一个最合适的版本来显示给用户。通常情况下,最好放入一个文本格式的版本,这样不支持MIME的邮件客户端也能正常读取。
/ }. ~& v9 n' z9 e" M# j
5 g- r8 H5 f" L: a# o11.在类UNIX系统中,PHP依靠sendmail程序来处理邮件。而在Windows中,除非已有sendmail包装器,否则将使用服务器的SMTP配置来进行。答案是D。
* a' d- J# e+ B9 D( x- ~
& ^2 t7 g$ W6 v" l, c$ N12.在普通文本邮件中使用htmlentities()不能防止跨站攻击,反而可能会让邮件内容变得不可读。强制使用POST传递变量只能让攻击变的困难,但并非绝对安全。确保E-Mail文本域(将变成To:的部分)中没有换行符,能够防止恶意用户把自己的邮件地址添加进收件人地址中。因此答案是C和E。
" h) L8 K8 I% U" ]7 d( i3 ?+ V' R# X, z" ?
13.把数组序列化成一个字符串是传输这个数组的正确方式——第一步先让数组变得可以通过E-Mail网络传输。接下来你需要对它进行编码,以使得它能够安全传输。在PHP4中,最简单的方法是用base64_encode把它编码成每字符7bit的形式。答案是D。( H1 E3 h! W; y4 n" u
: i' H9 L5 z6 [" s, d+ p14.要判断一个文件的MIME类型,最简单的方法是使用mime_content_type函数。答案是D。注意,虽然别的扩展库里有能更好的解决这个问题的函数(译者注:比如PECL的FileInfo),但在这里使用mime_content_type仍然是可以的。
( M% s( H! o I8 C, K; O5 @! `
. d0 a+ z2 I3 ]& b4 J$ D$ r2 p15.在头信息中添加From不能完全保证sendmail不会在邮件中重写你的发件人地址。事实上,你需要通过发送器向sendmail传递-f参数。除此之外,你还必须确保运行Apache的用户有修改头信息中的From内容的权限。因此答案是A,B和D。 |
|