acl  3.5.3.0
acl::rfc822类 参考

#include <rfc822.hpp>

+ 类 acl::rfc822 继承关系图:
+ acl::rfc822 的协作图:

Public 成员函数

 rfc822 (void)
 
 ~rfc822 (void)
 
time_t parse_date (const char *in)
 
void mkdate (time_t t, char *out, size_t size, tzone_t zone=tzone_cst)
 
void mkdate_cst (time_t t, char *out, size_t size)
 
void mkdate_gmt (time_t t, char *out, size_t size)
 
const std::list< rfc822_addr * > & parse_addrs (const char *in, const char *to_charset="utf-8")
 
const rfc822_addrparse_addr (const char *in, const char *to_charset="utf-8")
 
bool check_addr (const char *in)
 

额外继承的成员函数

- Protected 成员函数 继承自 acl::acl::noncopyable
 noncopyable ()
 
 ~noncopyable ()
 

详细描述

在文件 rfc822.hpp26 行定义.

构造及析构函数说明

◆ rfc822()

acl::rfc822::rfc822 ( void  )

◆ ~rfc822()

acl::rfc822::~rfc822 ( void  )

成员函数说明

◆ check_addr()

bool acl::rfc822::check_addr ( const char *  in)

检查邮件地址是否合法

参数
in{const char*} RFC822 格式的邮件地址
返回
{bool}

◆ mkdate()

void acl::rfc822::mkdate ( time_t  t,
char *  out,
size_t  size,
tzone_t  zone = tzone_cst 
)

生成符合 RFC822 标准的时间格式

参数
t{time_t}
out{char*} 存储转换结果
size{size_t} out 空间大小
zone{tzone_t} 所在时区

◆ mkdate_cst()

void acl::rfc822::mkdate_cst ( time_t  t,
char *  out,
size_t  size 
)

生成东八区的时间格式

参数
t{time_t}
out{char*} 存储转换结果
size{size_t} out 空间大小

◆ mkdate_gmt()

void acl::rfc822::mkdate_gmt ( time_t  t,
char *  out,
size_t  size 
)

生成格林威治时间的时间格式

参数
t{time_t}
out{char*} 存储转换结果
size{size_t} out 空间大小

◆ parse_addr()

const rfc822_addr* acl::rfc822::parse_addr ( const char *  in,
const char *  to_charset = "utf-8" 
)

解析一个符合 RFC822 标准的邮件地址,同时将用户名注释部分按 RFC2047 标准进行解码

参数
in{const char*} RFC822 格式的邮件地址
to_charset{const char*} 目标字符集,例如:gbk, gb18030, utf-8
返回
{const rfc822_addr*} 返回 NULL 表明输入的邮件地址不符合 RFC822 规范

◆ parse_addrs()

const std::list<rfc822_addr*>& acl::rfc822::parse_addrs ( const char *  in,
const char *  to_charset = "utf-8" 
)

解析邮件地址列表,将符合 RFC822 标准的邮件地址列表解析成 人能正常看懂的邮件地址列表,同时将用户名注释部分进行 RFC2047解码

参数
in{const char*} RFC822 格式的邮件地址列表,如: "=?gb2312?B?1dSx+A==?= <zhaobing@51iker.com>;\r\n" "\t\"=?GB2312?B?t+vBosn6?=" fengl.nosp@m.ishe.nosp@m.ng@51.nosp@m.iker.nosp@m..com;\r
" "\t"zhengshuxin3";"zhengshuxin4" zheng.nosp@m.shux.nosp@m.in2@5.nosp@m.1ike.nosp@m.r.com;" "xugan.nosp@m.ghui.nosp@m.@51ik.nosp@m.er.c.nosp@m.om;wangw.nosp@m.enqu.nosp@m.an@51.nosp@m.iker.nosp@m..com;"
to_charset{const char*} 目标字符集,例如:gbk, gb18030, utf-8
返回
{const std::list<rfc822_addr*>&} 解析结果

◆ parse_date()

time_t acl::rfc822::parse_date ( const char *  in)

解析符合 RFC822 标准的时间格式

参数
in{const char*} 时间字符串,如: Wed, 11 May 2011 09:44:37 +0800 (CST) Wed, 11 May 2011 16:17:39 GMT

该类的文档由以下文件生成: