I have an email system, where user write a message and it will send the message. The main problem which I just found, consider this code
$findEmail = $this->Data->field('body', array('id' => 1610));
//$getUserEmailTemplate will take frm dbase and e.g:
//Hi, @@MESSAGE@@. From: StackOverflow
//It should change @@MESSAGE@@ part to data from $findEmail (in this example is the $74.97 ...)
$getUserEmailTemplate = $findUser['User']['email_template'];
$emailMessage = preg_replace('/\B@@MESSAGE@@\B/u', $findEmail, $getUserEmailTemplate);
debug($findEmail);
debug($emailMessage);
and consider this input for the email for $findemail result:
$74.97
$735.00s
$email Message will result in:
.97
5.00s
How can I fix this? I feel like there's problem with my preg_replace pattern.
User template can be anything, as long as there is @@MESSAGE@@ which, that part will be changed to the user message input.
Thank you
Pre-parse the replacement text to escape the
$
when followed by a number (remember that$n
has special meaning when using in the replacement text). See the comment on the php.net docs page:Guess your template just includes "pure" PHP and tries to use $74 as variable, which does not exist and does not hold any data. So change the quotes in the template to single quotes
'
.guessed template:
corrected template:
If (ever) an template hast been in
$getUserEmailTemplate
, you did overwrite (destroy) it with this line;So just remove this line and make sure,
$getUserEmailTemplate
really contains anything and best of all a template.Here is the reason:
The
$1
portion of a replacement text stands for the first group/match found. So if you haveabc 123
and you trypreg_match('/([\w]+)-([\d]+)/')
, regex will store internally something like$1 = abc
and$2 = 123
. Those variables are going to exists, even if they have no value.So, for example:
As the match group
$10
is empty is going to be replaced by a null string.That's why you need to scape any
$NN
from your REPLACEMENT text before running thepreg_replace
function.Happy coding.