Portál AbcLinuxu, 26. července 2025 18:26


Dotaz: PHPMailer

3.1.2013 21:58 omorok | skóre: 2
PHPMailer
Přečteno: 1459×
Odpovědět | Admin
Potřebuji poradit s jedním problémem. Na PC mi jede web server (lighttp) s PHP5 a PHP-CLI. Skript, který právě spouštím v PHP-CLI, mimo jiné, jednou za den odesílá e-mail. Zjistil jsem, že jeden den e-mail odešle a druhý den již ne a skript spadne. Vytvořil jsem si testovací skript a zjistil jsem, že jednou e-mail odešle a pak vypíše Fatal error. Testovací skript:
#!/usr/bin/php -q

IsSMTP();                                      // Set mailer to use SMTP
$mail->Host = 'smtp.seznam.cz'; 					 // Specify main and backup server
$mail->SMTPAuth = true;                               // Enable SMTP authentication
$mail->Username = 'xxx@seznam.cz';                            // SMTP username
$mail->Password = 'xxx';                           // SMTP password
#$mail->SMTPSecure = 'ssh';                            // Enable encryption, 'ssl' also accepted

$mail->From = 'xxx';
$mail->FromName = 'xxx';
$mail->AddAddress('poruchy@xxx', 'Poruchy');  // Add a recipient
$mail->AddAddress('xxx@seznam.cz');               // Name is optional
$mail->AddReplyTo('xxx@xxx.cz', 'Information');
#$mail->AddCC('cc@example.com');
#$mail->AddBCC('bcc@example.com');

$mail->WordWrap = 50;                                 // Set word wrap to 50 characters
#$mail->AddAttachment('/var/tmp/file.tar.gz');         // Add attachments
#$mail->AddAttachment('/tmp/image.jpg', 'new.jpg');    // Optional name
$mail->IsHTML(true);                                  // Set email format to HTML

$mail->Subject = 'Here is the subject';
$mail->Body    = 'This is the HTML message body in bold!';
$mail->AltBody = 'This is the body in plain text for non-HTML mail clients';

if(!$mail->Send()) {
   echo 'Message could not be sent.';
   echo 'Mailer Error: ' . $mail->ErrorInfo;
   exit;
}

echo 'Message has been sent';



	$pocet = ($pocet + 1 );	
	echo $pocet;

sleep(1);
	
endwhile;
?>
Error:
PHP Fatal error:  Cannot redeclare class phpmailerException in /var/www/class.phpmailer.php on line 2816
PHPMailer mám: 5.2.2. Výpis z class.phpmailer.php (řádek 2816 jsem tam označil)
                "\t|$to\r\n".
                "\t|$subject;\r\n".
                "\tbh=" . $DKIMb64 . ";\r\n".
                "\tb=";
    $toSign   = $this->DKIM_HeaderC($from_header . "\r\n" . $to_header . "\r\n" . $subject_header . "\r\n" . $dkimhdrs);
    $signed   = $this->DKIM_Sign($toSign);
    return "X-PHPMAILER-DKIM: code.google.com/a/apache-extras.org/p/phpmailer/\r\n".$dkimhdrs.$signed."\r\n";
  }

  /**
   * Perform callback
   * @param boolean $isSent
   * @param string $to
   * @param string $cc
   * @param string $bcc
   * @param string $subject
   * @param string $body
   * @param string $from
   */
  protected function doCallback($isSent, $to, $cc, $bcc, $subject, $body, $from=null) {
    if (!empty($this->action_function) && is_callable($this->action_function)) {
      $params = array($isSent, $to, $cc, $bcc, $subject, $body, $from);
      call_user_func_array($this->action_function, $params);
    }
  }
}

/**
 * Exception handler for PHPMailer
 * @package PHPMailer
 */
class phpmailerException extends Exception {
  /**
   * Prettify error message output
   * @return string
   */
  public function errorMessage() {
    $errorMsg = '' . $this->getMessage() . "
\n"; return $errorMsg; } } //toto je řádka 2816 ?>
Děkuji předem za radu

Řešení dotazu:


Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

Josef Kufner avatar 3.1.2013 22:38 Josef Kufner | skóre: 70
Rozbalit Rozbalit vše Re: PHPMailer
Odpovědět | | Sbalit | Link | Blokovat | Admin
Kde tam vyrábíš novou instanci Maileru pro každé odeslání mailu?
Hello world ! Segmentation fault (core dumped)
4.1.2013 13:55 omorok | skóre: 2
Rozbalit Rozbalit vše Re: PHPMailer
Můžu se zeptat, co je tímto myšleno?
Josef Kufner avatar 4.1.2013 14:53 Josef Kufner | skóre: 70
Rozbalit Rozbalit vše Re: PHPMailer
Kde máš $mail = new Mailer(); ?
Hello world ! Segmentation fault (core dumped)
4.1.2013 21:48 omorok | skóre: 2
Rozbalit Rozbalit vše Re: PHPMailer
To se omlouvám, ale asi jsem to sáznul při mazání jmen a hesla. ve skriptu tento řádek mám...
Josef Kufner avatar 4.1.2013 22:14 Josef Kufner | skóre: 70
Rozbalit Rozbalit vše Re: PHPMailer
A máš ho tam i před druhým odesíláním mailu?
Hello world ! Segmentation fault (core dumped)
3.1.2013 23:57 depka | skóre: 20 | blog: eterity
Rozbalit Rozbalit vše Re: PHPMailer
Odpovědět | | Sbalit | Link | Blokovat | Admin
kde vubec vznika promena $mail?
4.1.2013 13:50 omorok | skóre: 2
Rozbalit Rozbalit vše Re: PHPMailer
To jsem si taky říkal, že po prvním odeslání, se "nevyprázdní $mail. Ale i když jsem zadal po odeslání e-mailu tuto proměnnou aby se vynulovala, tak to stejně dělá.
4.1.2013 00:06 Kit
Rozbalit Rozbalit vše Re: PHPMailer
Odpovědět | | Sbalit | Link | Blokovat | Admin
To vypadá na duplicitní include nebo require
4.1.2013 00:35 depka | skóre: 20 | blog: eterity
Rozbalit Rozbalit vše Re: PHPMailer
duplicitni require imo nejde
4.1.2013 00:51 Kit
Rozbalit Rozbalit vše Re: PHPMailer
Jde :-)
4.1.2013 00:53 depka | skóre: 20 | blog: eterity
Rozbalit Rozbalit vše Re: PHPMailer
ok, pletu si s _once ...
4.1.2013 13:52 omorok | skóre: 2
Rozbalit Rozbalit vše Re: PHPMailer
Tak to mám co dělat,než to najdu- jestli to najdu...
4.1.2013 14:10 Kit
Rozbalit Rozbalit vše Re: PHPMailer
Zkus nahradit všechny include za include_once a require za require_once. Ono se to najde samo.

Je to jeden z důvodů, proč používám jen __autoload().
4.1.2013 18:14 depka | skóre: 20 | blog: eterity
Rozbalit Rozbalit vše Re: PHPMailer
kdyz neco nevis, zadej www.php.net a napis to do "search for" je tam vsechno
4.1.2013 18:29 Kit
Rozbalit Rozbalit vše Re: PHPMailer
Najde to i googlovský dotaz "php include" apod.
4.1.2013 21:51 omorok | skóre: 2
Rozbalit Rozbalit vše Re: PHPMailer
Nahradil jsem include za include_once a require za require_once. Moc jich tam není (spíš v komentářích). Bohužel výsledek je stejný. Tak to vidím, že se asi budu muset poohlédnout po něčem jiném-podobném (např: SwiftMailer, Zend_Mail, eZcomponents).
4.1.2013 22:08 Kit
Rozbalit Rozbalit vše Re: PHPMailer
Prostě je 2× deklarována třída phpmailerException. Může to být i v jiném souboru. Zkus grepnout zdrojáky:
grep -i 'class.*phpmailerException' *.php
4.1.2013 22:18 Kit
Rozbalit Rozbalit vše Re: PHPMailer
Je také možné, že tu třídu phpmailerException deklaruješ uvnitř nějakého cyklu. Nemáš náhodou nějaký include v cyklu? Někdy stačí tu knihovnu dát do cyklu a průšvih je na světě.
5.1.2013 20:19 omorok | skóre: 2
Rozbalit Rozbalit vše Re: PHPMailer
To bylo ono. V cyklu opakuji celý skript pro posílání e-mailu. V prvním dotazu jsem použil pro vložení ukázky ciklu "pre" a on omazal zrovna to důležité.

Jen začátek cyklu jak byl:
#!/usr/bin/php -q

?php



$pocet = "0";


while(true):
	
require 'class.phpmailer.php';

$mail = new PHPMailer();
$mail->IsSMTP();                                      // Set mailer to use SMTP
$mail->Host = 'smtp.seznam.cz'; 					 // Specify main and backup server
$mail->SMTPAuth = true;                               // Enable SMTP authentication
$mail->Username = 'xxx@seznam.cz';                            // SMTP username
$mail->Password = 'xxx;                           // SMTP password
#$mail->SMTPSecure = 'ssh';                            // Enable encryption, 'ssl' also accepted
A nyní jak má být:
#!/usr/bin/php -q

?php



$pocet = "0";


while(true):
	
require_once 'class.phpmailer.php';

$mail = new PHPMailer();
$mail->IsSMTP();                                      // Set mailer to use SMTP
$mail->Host = 'smtp.seznam.cz'; 					 // Specify main and backup server
$mail->SMTPAuth = true;                               // Enable SMTP authentication
$mail->Username = 'xxx@seznam.cz';                            // SMTP username
$mail->Password = 'xxx;                           // SMTP password
#$mail->SMTPSecure = 'ssh';                            // Enable encryption, 'ssl' also accepted
Děkuji za pomoc. A tento problém je tímto vyřešen. Přesto doteď nechápu, jak z nic neříkající hlášky může někdo tak přesně určit kde může být chyba... Nyní ještě musím zjistit jak vytvořím sloupovitý graf a umístím ho do e-mailu. Přeji hodně zdaru..
5.1.2013 20:36 Kit
Rozbalit Rozbalit vše Re: PHPMailer
Těch indicií tam bylo víc. Stačilo si jich všimnout a poskládat
sleep(1);
endwhile;
Konec cyklu, který nikde nezačíná. Asi jsi ho ustřihl.
Cannot redeclare class phpmailerException
je jasná hláška, že tu třídu deklaruješ podruhé.

Není to tvá knihovna, stáhl sis ji. Tedy ji includuješ.

Když si to dáš dohromady, vyjde ti z toho include s deklarací třídy phpmailerException uvnitř cyklu.

Ještě můžeš ten
require_once 'class.phpmailer.php';
hodit před while.

Skutečně má ten skript běžet nonstop? Můžeš ho opakovaně spouštět cronem.
5.1.2013 22:38 omorok | skóre: 2
Rozbalit Rozbalit vše Re: PHPMailer
toto je jen testovací skript. Odesílání e-mailu je součást skriptu, který jede nonstop a načítá data z RS485, počítá je ukládá... a jednou za den se odešle souhrnný e-mail a nebo chybový e-mail.
5.1.2013 23:14 Kit
Rozbalit Rozbalit vše Re: PHPMailer
To je lepší udělat jako dva nezávislé skripty. Každý může být v jiném jazyku. Tomu monitorovacímu bych hlavně udělal schopnost respawn, odesílací ani nemusí být v PHP. Bash s několika nástroji to zvládne také a lépe. Ten bych volal z cronu.

Zpracování grafu bych klidně nechal na klientovi, ale pokud je to nutné dělat na serveru, tak R-project je skvělý nástroj.
7.1.2013 21:01 omorok | skóre: 2
Rozbalit Rozbalit vše Re: PHPMailer
Původně jsem tento skript psal v Bash, ale potřeboval jsem pár rad a tam jsem se dozvěděl, že lepší bude PHP-CLI.

Tady je první dotaz: Zde Tady je druhý odkaz: Zde

Já jako totální laik, pokud posoudím Bash a PHP, tak Bash je lehčí-má méně příkazů. Ale hodně mi dělaly problémy mezery, čárky... a hlavně neumí desetinnou čárku (pokud pominu awk...). V PHP sice potřebuji více příkazů, ale jinak se mi v něm píše lepe a již mám tento skript téměř hotov. Graf potřebuji pro vložení do e-malu, zatím to lámu s tímto: Hned první. No a respawn budu řešit na konec, jednak z důvodu spadnutí skriptu a jednak se již stalo, že USB se odpojilo a tím se vynulovalo nastavení RS485 a skript vytížil Raspberry na 100% - což musím podchytnout...
Josef Kufner avatar 7.1.2013 22:55 Josef Kufner | skóre: 70
Rozbalit Rozbalit vše Re: PHPMailer
Ukaž kompletní zdrojáky. Při různém zkracování tam akorát ještě nasekáš další chyby.
Hello world ! Segmentation fault (core dumped)

Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.