php + jquery 利用 smtp 实现发送邮件功能

php + jquery 利用 smtp 实现发送邮件功能

在做一个企业站的小项目,用户不希望登录到后台查看留言,而是希望留言能直接发送到自己的邮箱里,然后这样他就可以在手机上快速的处理这些用户的留言了。不过这个功能我自己开发的 fengcms 并不支持,而且目前没有了解php的朋友在身边。本着自己动手丰衣足食的精神,自己解决这个问题吧。

实现设想

我希望通过ajax来实现这个功能。因为邮件本质来说,只有两个内容字段,一个是标题,一个是正文。而我们网页上通常有很多表单来让用户填写,因此,如果是用php来整合组装这些字段的话,不是不可以,而是比较繁琐,而且不能通用。我是一名前端工程师,因此,当然希望用前端的方法来解决这些问题。我的设想规划如下

文件说明
msn.html提交留言表单html文件
mail.phpphp邮件处理核心文件
send_mail.phphtml和mail.php的沟通文件

通过msn.html构造表单,并利用jqueryajax功能,将信息构造成json信息,postsend_mail.php 文件。send_mail.php处理邮件逻辑,并调用mail.php核心参数,来实现邮件的发送。

逐步实现

mail.php的实现

<?php
// Pear Mail Library
require_once "Mail.php";

const SMTP = 'smtp.163.com';
const PORT = '25';
const USERNAME = 'username@163.com';
const PASSWORD = 'password';


function send_mail($subject, $body) {
    $from = '<username@163.com>';
    $to = '<inbox@163.com.com>';
    $headers = array(
        'From' => $from,
        'To' => $to,
        'Subject' => $subject
    );

    $smtp = Mail::factory('smtp', array(
            'host' => SMTP,
            'port' => PORT,
            'auth' => true,
            'username' => USERNAME,
            'password' => PASSWORD
        ));

    $mail = $smtp->send($to, $headers, $body);

    if (PEAR::isError($mail)) {
        return true;
    } else {
        return false;
    }
}
?>

send_mail.php的实现

<?php
    require_once 'mail.php';

    $raw = file_get_contents('php://input');
    $json = json_decode($raw);
    if (!send_mail($json->subject, $json->body)) {
        echo('{"code":0, "message":"发送成功。"}');
    } else {
        echo('{"code":1, "message":"发送失败。"}');
    }
?>

msn.html的实现

    <section class="msn">
        <input type="text" class="title" name="title" value="title">
        <textarea name="content" class="content">content</textarea>
        <input type="button" class="submit_msn" value="提交">
    </section>
    <script>
    $(function(){
        $(".submit_msn").on("click",function(){
            var url = "/send_mail.php";
            var data = {};
            data.subject = $(".title").val();
            data.body = $(".content").val();
            console.log(data)
            ajaxPost(url,JSON.stringify(data))
        })
    })
    function ajaxPost(url,data){
        $.ajax({
            type:'post',
            dataType: "json",
            data: data,
            url:url,
            success: function (data) {
                if(data.code==0){
                    alert("您的留言已经提交成功,我们将尽快答复您!")
                }else{
                    alert("好像服务器出问题了呢T_T,您还是直接电话联系我们吧!")
                }
            },
            error: function (data) { alert("服务器不支持发送邮件") }
        });
    }
    </script>

小结

核心代码就是这些了。剩下前端需要增加字段,增加验证,send_mail.php也需要增加验证,这个功能才能正式上线。php发送邮件的代码是网上找的。其他都是自己解决的。因此也算是原创吧。

首发地址:http://blog.csdn.net/fungleo/article/details/52995053 允许转载,但转载必须注明首发地址,谢谢。

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值