麻辣家族討論版版's Archiver

小誌 發表於 2011-4-24 14:39

12-2-3 自動送信程式

[color=DarkRed][size=4][b]12-2-3   自動送信程式[/b][/size][/color]
當問卷填寫者在in.php程式網頁中按下『送出問卷』按鈕後,表單中的資料就會送交自動送信程式sentmsg.php處理,sentmsg.php程式將會把問卷填寫結果與填寫者的資料以E-Mail自動傳送的方式寄送至管理者或是問卷調查主持人的手中。

在信件傳送之前,我們必須先設定mail()函數的收件人(To)、寄件人(From)、信件主旨(Subject)與信件內容(Body)等四項屬性,信件主旨我們可以自行設定為固定文字,收件者則為管理者或是問卷調查主持人的E-Mail帳號(這也是固定的),信件傳送的寄件者與信件內容(問卷結果)則是隨著問卷填寫者所填寫的內容而變動。[code]//建立郵件基本項目       
    //以問卷程式網頁中所填寫的E-mail為寄件者
    $From= "From: " . $_REQUEST["Email"];
    //收件者為管理員或問卷調查主持人的E-Mail
    $To= $_REQUEST["Email"];
    //信件主題,通常為問卷的主題
    $Subject="網路問卷調查";
    //信件內容
    $Body = "網友" . $_REQUEST["Name"] . "問卷意見:" . "\r\n"; //以下略….[/code]請觀察上列這段程式敘述,您可以清楚的看到我們From(寄件者郵件信箱)屬性值是設定為:問卷填寫者在in.php程式網頁中Email欄位中所填寫的郵件信箱,這麼做最主要的目的是為了讓管理者或是問卷調查主持人能夠即時的以E-Mail方式回應問卷填寫者所提出的意見。



[color=Red]提示!![/color]
本範例中From(寄件者郵件信箱)與To(收件者郵件信箱)屬性值設定是相同的,也就是自己寄信給自己,在實際應用時請自行更改To(收件者郵件信箱)屬性值設定。

小誌 發表於 2011-4-24 14:40

在信件內容的部分,除了要有問卷填寫者所選擇的答案與意見外,本範例中還加上相對應的問卷題目本文,如果不加上原始題目的內容,我們怎能知道答案的意義?[code]//列出問卷題目及問卷填寫者的答案
     $I=1;
    while (($fielddatas=mysql_fetch_array($datalist)))
    {
     //列出問卷題目
     $Body = $Body . $I . ". " . $fielddatas["題目"] . "\r\n";
     //取得相對應於題目的問卷答案
     $Ans=$_REQUEST["No" . $fielddatas["題號"]];
     //列出答案
     $Body = $Body . $Ans . "\r\n";
     $I++;
    }
   
// 寄出信件
    mail($To ,$Subject ,$Body ,$From);[/code]1.使用While迴圈敘述配合改變作用中資料錄位置與提取資料的mysql_fetch_array()函數,將所有的問卷題目自資料庫資料表中讀取出來。
2.利用$_REQUEST[“表單欄位”]敘述取得來自問卷程式網頁中相對於題目的答案欄位屬性值(Value)。
3.呼叫mail()函數將信件寄出。



[color=Red]提示!![/color]
程式碼中的「\r\n」為一換行符號,其作用就是將我們的信件內容分段顯示!若未加上此換行符號,則我們的信件內容將會全部串接成一個段落。

小誌 發表於 2011-4-24 14:40

sentmsg.php[code]<?
//連結MySQL Server
    $conn = mysql_connect("localhost", "root", "12345a");
//選擇資料庫
    mysql_select_db("QUESTION", $conn);
//指定提取資料的校對字元表
    mysql_query("set character set big5");  
//建立查詢字串
$SQL="Select * From question Order By 題號";
//將回傳結果存放於變數中
$datalist=mysql_query($SQL);
                        
//建立郵件基本項目       
    //以問卷程式網頁中所填寫的E-mail為寄件者
    $From= "From: " . $_REQUEST["Email"];
    //收件者為管理員或問卷調查主持人的E-Mail
    $To= $_REQUEST["Email"];
    //信件主題,通常為問卷的主題
    $Subject="網路問卷調查";
    //信件內容
    $Body = "網友" . $_REQUEST["Name"] . "問卷意見:" . "\r\n";
   
//列出問卷題目及問卷填寫者的答案
     $I=1;
    while (($fielddatas=mysql_fetch_array($datalist)))
    {
     //列出問卷題目
     $Body = $Body . $I . ". " . $fielddatas["題目"] . "\r\n";
     //取得相對應於題目的問卷答案
     $Ans=$_REQUEST["No" . $fielddatas["題號"]];
     //列出答案
     $Body = $Body . $Ans . "\r\n";
     $I++;
    }
   
// 寄出信件
    mail($To ,$Subject ,$Body ,$From);
?>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; chaRSet=big5">
<title>感謝您的意見!!</title>
</head>
<body>
感謝您的意見
</body>
</html>[/code]

小誌 發表於 2011-4-24 14:41

[color=RoyalBlue][size=3][b]使用CDONTS物件寄送問卷結果[/b][/size][/color]
為了不顧此薄彼,筆者也寫了利用CDONTS_NewMail物件寄送問卷結果的範例程式:「sentmsg_cdonts.php」,程式設計原理與sentmsg.php相同,因此就不多言了,此範例程式請配合「in_cdonts.php」使用。[code]<?
//連結MySQL Server
    $conn = mysql_connect("localhost", "root", "12345a");
//選擇資料庫
    mysql_select_db("QUESTION", $conn);
//指定提取資料的校對字元表
    mysql_query("set character set big5");  
//建立查詢字串
$SQL="Select * From question Order By 題號";
//將回傳結果存放於變數中
$datalist=mysql_query($SQL);

//建立信件傳送物件
$CDONTS = new COM("CDONTS.NewMail");

//建立郵件基本項目       
    //以問卷程式網頁中所填寫的E-mail為寄件者
    $CDONTS->From=$_REQUEST["Email"];
    //收件者為管理員或問卷調查主持人的E-Mail
    $CDONTS->To= $_REQUEST["Email"];
    //信件主題,通常為問卷的主題
    $CDONTS->Subject="網路問卷調查";
    //信件內容
    $Body = "網友" . $_REQUEST["Name"] . "問卷意見:";
   
//列出問卷題目及問卷填寫者的答案
     $I=1;
    while (($fielddatas=mysql_fetch_array($datalist)))
    {
     //列出問卷題目
     $Body =$Body . "\r\n" . $I . ". " . $fielddatas["題目"] . "\r\n";
     //取得相對應於題目的問卷答案
     $Ans=$_REQUEST["No" . $fielddatas["題號"]];
     //列出答案
     $Body = $Body . $Ans ;
     $I++;
    }

    $CDONTS->Body=$Body;
// 寄出信件
    $CDONTS->Send();
?>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; chaRSet=big5">
<title>感謝您的意見!!</title>
</head>
<body>
感謝您的意見
</body>
</html>[/code]

頁: [1]

麻辣家族討論版版為 麻辣學園 網站成員  由 昱得資訊工作室 © Since 1993 所提供