それぞれの商品欄にチェックボックスがあり、複数の商品の受け取りをしても各店舗に1回しかメールが届かないようにしたいのですが上手くいきません。ご教授のほどよろしくお願い致します。
product_list (id) (product) (give_shop) 1 product1 shop1 2 product2 shop1 3 product3 shop2 4 product4 shop2 5 product5 shop2
user_list (name) (email) shop1 email1 shop2 email2
list1.php <form method="post" action="list2.php"> <input type="checkbox" name="ids[]" > <input type="submit" value="チェックした商品を受け取る">'; </form>
list2.php <?php if($_SERVER["REQUEST_METHOD"] == 'POST' ) { $ids==$_POST['ids']; for($i=0; $i<count($ids); $i++) { $pdo = new PDO("mysql:host=xxx; dbname=xxx; charset=utf8", "xxx", "xxx", array( PDO::ATTR_EMULATE_PREPARES => false ) ); $sql = "select * from product_list where id = '".$_POST['ids'][ $i]."'"; $statement = $pdo->prepare( $sql ); $statement->execute( ); $results = $statement->fetchAll(); foreach( $results as $result ){ $name=$result['give_shop']; try { $dsn='mysql:dbname=xxx;host=xxx;charset=utf8'; $user='xxx'; $password='xxx'; $dbh=new PDO($dsn,$user,$password); $dbh->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION); $sql="SELECT * FROM user_list where name='".$name."'"; $stmt=$dbh->prepare($sql); $stmt->execute(); $rec=$stmt->fetch(PDO::FETCH_ASSOC); $email=$rec['email']; $dbh=null; } catch(Exception $e) { print'ただいま障害により大変ご迷惑をお掛けしております1。'; exit(); } $mail_sub = '登録した商品の引き取り先が見つかりました'; $mail_body = $result["name"]."様\n\n発送準備が完了したら、以下のURLに飛んでください。"; $mail_body = html_entity_decode($mail_body,ENT_QUOTES,"UTF-8"); $mail_head = 'From:xxx'; mb_language('Japanese'); mb_internal_encoding("UTF-8"); mb_send_mail($email, $mail_sub, $mail_body,$mail_head); } } ?>
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2017/04/29 04:28
2017/04/29 04:38
2017/04/29 04:45
2017/04/29 04:48 編集
2017/04/29 04:49
2017/04/29 04:55