0

我最近在这里发布了在 PHP 中使用 file_get_contents 时访问 $_SESSION关于我遇到的一个问题,普遍的共识是我没有做对......虽然我通常认为“只要它有效......”我想我会得到一些关于如何做得更好的反馈...

我要从多个不同区域以完全相同的格式发送完全相同的电子邮件。

  1. 输入作业时(自动作为 POST 的一部分)
  2. 在检查作业以重新分配给另一个安装程序时手动

原始脚本是一个使用 AJAX 调用以发送工作订单请求的 php 页面 - 这通过简单地调用标准 php 页面、返回成功或错误消息然后显示在调用页面中来工作。

现在,我尝试在自动作业条目中使用同一页面,以便它通过表单接受作业,记录并邮寄。

我的问题是(正如您从原始帖子中看到的那样)函数 file_get_contents() 在自动化脚本中不适合这个原因......

我的问题是,从 AJAX 调用中,我需要做一些事情,比如包含数据库连接初始化程序、启动会话并在独立页面中做任何其他需要做的事情......如果它是一个包括所以它使文件只适用于一个目的......

如何使文件对这两个目的都有效?我想我正在寻找适合这两种情况的最佳文件布局和结构的建议......

当前文件如下所示:

<?php
session_start();

$order_id = $_GET['order_id'];

include('include/database.php');

function getLineItems($order_id) {

    $query = mysql_query("SELECT ...lineItems...");

    //Print rows with data
    while($row = mysql_fetch_object($query)) {  

        $lineItems .= '...Build Line Item String...';

    }

    return $lineItems;
}

function send_email($order_id) {

    //Get data for current job to display
    $query = mysql_query("SELECT ...Job Details...");

    $row = mysql_fetch_object($query);

    $subject = 'Work Order Request';

    $email_message = '...Build Email...
                      ...Include Job Details...
                      '.getLineItems($order_id).'
                      ...Finish Email...';

    $headers  = '...Create Email Headers...';

    if (mail($row->primary_email, $subject, $email_message, $headers)) {

        $query = mysql_query("...log successful send...");

        if (mysql_error()!="") {
            $message .= '...display mysqlerror()..';
        }

        $message .= '...create success message...';

    } else {

        $query = mysql_query("...log failed send...");

        if (mysql_error()!="") {
            $message .= '...display mysqlerror()..';
        }
        $message .= '...create failed message...';
    }

    return $message;

} // END send_email() function

//Check supplier info 
$query = mysql_query("...get suppliers info attached to order_id...");

if (mysql_num_rows($query) > 0) {

    while($row = mysql_fetch_object($query)) {  
        if ($row->primary_email=="") { 

            $message .= '...no email message...';

        } else if ($row->notification_email=="") {

            $message .= '...no notifications message...';

        } else {

            $message .= send_email($order_id);

        }

    }

} else {

    $message .= '...no supplier matched message...';
}

print $message;

?>
4

1 回答 1

0

制作一个函数并包含它
单独的函数。来自邮件发送(不需要)的身份验证(需要会话)
然后将邮件发送功能包含到两个任务中。

于 2010-04-14T06:50:09.977 回答