前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >php + jquery 利用 smtp 实现发送邮件功能

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

作者头像
FungLeo
发布2022-05-05 21:33:42
发布2022-05-05 21:33:42
1.3K00
代码可运行
举报
运行总次数:0
代码可运行

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

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

实现设想

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

文件

说明

msn.html

提交留言表单html文件

mail.php

php邮件处理核心文件

send_mail.php

html和mail.php的沟通文件

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

逐步实现

mail.php的实现

代码语言:javascript
代码运行次数:0
运行
复制
<?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的实现

代码语言:javascript
代码运行次数:0
运行
复制
<?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的实现

代码语言:javascript
代码运行次数:0
运行
复制
    <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 允许转载,但转载必须注明首发地址,谢谢。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2016-11-01,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • php + jquery 利用 smtp 实现发送邮件功能
    • 实现设想
    • 逐步实现
    • 小结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档