Mac下使用php的error_log()函数发送邮件

在开发web项目或者其他场景下,有时候我们需要设置“报警”。比如当数据库的某一项指标达到某一个值时,需要通知网站管理员。今天跟大家分享一个比较简单的php报警的功能。

先介绍一个php中用来记录log的一个函数error_log,它用来发送错误到某个地方。函数介绍

bool error_log ( string $message [, int $message_type = 0 
[, string  $destination [, string $extra_headers ]]] 

其中$message表示要记录的信息;$message_type用来设置信息要发往何处。可能的信息类型如下:

0 : message 发送到 PHP 的系统日志,使用 操作系统的日志机制或者一个文件,取决于 error_log 指令设置了什么。 这是个默认的选项。
1 : message 发送到参数 destination 设置的邮件地址。 第四个参数 extra_headers 只有在这个类型里才会被用到。
2 : 不再是一个选项
3 : message 被发送到位置为 destination 的文件里
4 : message 直接发送到 SAPI 的日志处理程序中。

此外,$destination由$message_type所决定;$extra_headers当$message_type为1时使用。

在*nix操作系统下,php发送邮件是通过sendmail组件。所以要先确保已经安装了sendmail组件。可以通过以下命令测试你的服务器上的邮件服务是否正常。未发送成功的邮件默认会退回/var/mail/下。可以自行查看退回的邮件中的详情。

echo "test mail content" | mail -s "test mail subject" {xxx@yy.com}

Start

1.安装sendmail

   Mac正常默认带有sendmail,位于/usr/sbin/下。如果没有,可以自行搜索安装下~

2.找到php所使用的配置文件php.ini

   php -i | grep php.ini

3.打开php.ini,找到sendmail配置行

sendmail_path = "/usr/sbin/sendmail -t -i"

4.如果是在web项目中使用,配置完以后重启服务器方可生效。

5.测试。使用php -a 打开php交互式shell,输入以下代码,然后前往邮箱查看(注:邮箱可能会屏蔽掉此类邮件,请注意添加白名单)。

error_log('hello world',1,'xxx@yy.com');

大致是如上步骤。其他Linux类操作系统关于此的配置大同小异,感兴趣的伙伴可以自行尝试下。本文不足的地方也请大伙们提出批评修改意见~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值