sql >> Databáze >  >> RDS >> Mysql

Jak vložit příchozí e-mailovou zprávu do databáze mySQL?

Takže
– máte server
– dostáváte e-maily
– chcete je uložit do databáze mysql

Konfigurace ovládacího panelu
- přejděte na cpnal email forwarder
- přidejte nový
- přesměrujte na PATH -> /home/your_user/whatever/php.script.php

Skript PHP (možná budete muset změnit cestu "/usr/bin/php -q" v závislosti na konfiguraci vašeho serveru)

#!/usr/bin/php -q
<?php
chdir(dirname(__FILE__));
$fd = fopen("php://stdin", "r");
$email = "";
while (!feof($fd)) {
    $email .= fread($fd, 1024);
}
fclose($fd);

if(strlen($email)<1) {
    die(); 
}

// handle email
$lines = explode("\n", $email);

// empty vars
$from = "";
$to="";
$subject = "";
$headers = "";
$message = "";
$splittingheaders = true;

for ($i=0; $i < count($lines); $i++) {
    if ($splittingheaders) {
        // this is a header
        $headers .= $lines[$i]."\n";
        // look out for special headers
        if (preg_match("/^Subject: (.*)/", $lines[$i], $matches)) {
            $subject = $matches[1];
        }
        if (preg_match("/^From: (.*)/", $lines[$i], $matches)) {
            $from = $matches[1];
        }
        if (preg_match("/^To: (.*)/", $lines[$i], $matches)) {
            $to = $matches[1];
        }
    } else {
        // not a header, but message
        $message .= $lines[$i]."\n";
    }
    if (trim($lines[$i])=="") {
        // empty line, header section has ended
        $splittingheaders = false;
    }
}

Funguje i na sdíleném hostingu! :)

Vše, co potřebujete, je přidat mysql insert a použít výše definované proměnné. Víte, jak používat databázi mysql z php? Nebo s tím také potřebujete pomoc?




  1. Použijte TYPEPROPERTY() k vrácení informací o datovém typu na serveru SQL Server

  2. Vytvoření profilu pošty databáze v SQL Server (T-SQL)

  3. Odstraňte duplikáty pomocí funkce Oracle LISTAGG

  4. Jaký je problém roku 2038?