Register Register Member Login Member Login Member Login Forgot Password ??
PHP , ASP , ASP.NET, VB.NET, C#, Java , jQuery , Android , iOS , Windows Phone
 

Registered : 109,038

HOME > PHP > PHP Forum > Invalid argument supplied for foreach() in ช่วยด้วย



 

Invalid argument supplied for foreach() in ช่วยด้วย

 



Topic : 131400



โพสกระทู้ ( 0 )
บทความ ( 0 )



สถานะออฟไลน์




Code (PHP)
<?php

include 'asset/class/functions.php';
include 'asset/class/db.functions.php';

htmlhead();

/*
function getmembername()
{
    # code...
    $result = null;

    try{

        $stm = connectdb()->prepare("SELECT username FROM member WHERE club_type='0'");

        $stm->execute(); 

        if($stm->rowCount() > 0){
            $result = $stm->fetchall(PDO::FETCH_ASSOC);
            //$result = $stm->fetchAll(PDO::FETCH_COLUMN);
            foreach($result as $value){
                $arrays = null;
                foreach($value as $subvalue){
                    $arrays[] .= $subvalue;
                }                
            }
        }

    }catch(PDOException $ex){
        echo $ex->getMessage();
        $result = null;
    }

    return json_encode($arrays);

}

function getproductintype($value)
{
    # code...
    $result = null;

    try{

        $stm = connectdb()->prepare("SELECT id,prod_type,prod_name,prod_price,prod_unit,prod_detail FROM product WHERE prod_type=:type AND status='1'");
        
        $stm->bindparam(":type",$value);

        $stm->execute();

        if($stm->rowCount() > 0){
            
            $result = $stm->fetchAll(PDO::FETCH_ASSOC);

        }   

    }catch(PDOException $ex){
        echo $ex->getMessage();        
    }

    return $result;
}

function checkbooking($value)
{
    # code...
    $result = null;
    
    try{

        $stm = connectdb()->prepare("SELECT prod_id,status FROM orders_detail WHERE order_id=:order_id");
        
        $stm->bindparam(":order_id",$value);

        $stm->execute();

        if($stm->rowCount() > 0){
            $checker = $stm->fetchAll(PDO::FETCH_ASSOC);
            foreach ($checker as $checkvalue) {
                # code...
                if(getprodtype($checkvalue['prod_id']) ==1) {
                    $result = $checkvalue['prod_id'];
                }
            }
        }

    }catch(PDOException $ex){
        echo $ex->getMessage();        
    }

    return $result;
}

function canbooking($id,$starttm,$stoptm)
{
    # code...
    $result = false;
    
    try{

        $stm = connectdb()->prepare("SELECT status FROM booking WHERE book_on=:id AND (book_start=:starttime OR (book_start<:starttime AND :starttime<book_stop) OR book_stop=:stoptime OR (book_start<:stoptime AND :stoptime<book_stop)) AND status!=0");
        
        $stm->bindparam(":id",$id);
        $stm->bindparam(":starttime",$starttm);
        $stm->bindparam(":stoptime",$stoptm);

        $stm->execute();
        
        if($stm->rowCount() == 0){
            $result = true;
        }

    }catch(PDOException $ex){
        echo $ex->getMessage();        
    }

    return $result;
}

*/

function getname($value)
{
    # code...
    $result = null;

    try{

        $stm = connectdb()->prepare("SELECT fname,lname,username FROM member WHERE club_id=:club_id AND status='1' LIMIT 1");           

        $stm->bindparam(":club_id",$value);

        $stm->execute();

        if($stm->rowCount() == 1){
            $result = $stm->fetch(PDO::FETCH_ASSOC);
        }
        
    }catch(PDOException $ex){
        echo $ex->getMessage();
        $result = null;
    }

    return $result;
    
}

function getprodtype($value)
{
    # code...
    $result = null;

    try{

        $stm = connectdb()->prepare("SELECT prod_type FROM product WHERE id=:prod_id AND status='1' LIMIT 1");           

        $stm->bindparam(":prod_id",$value);

        $stm->execute();

        if($stm->rowCount() == 1){
            $result = $stm->fetch(PDO::FETCH_ASSOC)['prod_type'];
        }
        
    }catch(PDOException $ex){
        echo $ex->getMessage();
        $result = null;
    }

    return $result;
    
}

function booking_detail($value)
{
    # code...
    $result = null;
    
    try{

        $stm = connectdb()->prepare("SELECT member_id,book_start,book_stop,book_on,status FROM booking WHERE order_id=:order_id LIMIT 1");
        
        $stm->bindparam(":order_id",$value);

        $stm->execute();

        if($stm->rowCount() > 0){
            
            $result = $stm->fetch(PDO::FETCH_ASSOC);

        }   

    }catch(PDOException $ex){
        echo $ex->getMessage();        
    }

    return $result;
}

function getbooking($value)
{
    # code...
    $result = null;
    
    try{

        $stm = connectdb()->prepare("SELECT prod_name FROM product WHERE id=:id AND prod_type='1' LIMIT 1");
        
        $stm->bindparam(":id",$value);

        $stm->execute();

        if($stm->rowCount() == 1){
            $result = $stm->fetch(PDO::FETCH_ASSOC)['prod_name'];
        }

    }catch(PDOException $ex){
        echo $ex->getMessage();        
    }

    return $result;
}

function getorderlist($value)
{
    # code...
    $result = null;
    
    try{

        $stm = connectdb()->prepare("SELECT id,prod_id,prod_value,cost,status FROM orders_detail WHERE order_id=:order_id");
        
        $stm->bindparam(":order_id",$value);

        $stm->execute();

        if($stm->rowCount() > 0){
            $result = $stm->fetchAll(PDO::FETCH_ASSOC);
        }

    }catch(PDOException $ex){
        echo $ex->getMessage();        
    }

    return $result;    
}

function getprod_name($value)
{
    # code...
    $result = null;
    
    try{

        $stm = connectdb()->prepare("SELECT prod_name FROM product WHERE id=:id LIMIT 1");
        
        $stm->bindparam(":id",$value);

        $stm->execute();

        if($stm->rowCount() == 1){
            $result = $stm->fetch(PDO::FETCH_ASSOC)['prod_name'];            
        }

    }catch(PDOException $ex){
        echo $ex->getMessage();        
    }

    return $result;
}

function getprod_unit($value)
{
    # code...
    $result = null;
    
    try{

        $stm = connectdb()->prepare("SELECT prod_unit FROM product WHERE id=:id LIMIT 1");
        
        $stm->bindparam(":id",$value);

        $stm->execute();

        if($stm->rowCount() == 1){
            $prod_unit = $stm->fetch(PDO::FETCH_ASSOC)['prod_unit'];
            if($prod_unit == 1){ $result = "หน่วย";}
            if($prod_unit == 2){ $result = "ชั่วโมง";}
        }

    }catch(PDOException $ex){
        echo $ex->getMessage();        
    }

    return $result;
}

function getbilling($value)
{
    # code...
    $result = null;
    
    try{

        $stm = connectdb()->prepare("SELECT pay,cost,status FROM billing WHERE order_id=:order_id");
        
        $stm->bindparam(":order_id",$value);

        $stm->execute();
        
        if($stm->rowCount() > 0){
            $result = $stm->fetchAll(PDO::FETCH_ASSOC);
        }

    }catch(PDOException $ex){
        echo $ex->getMessage();        
    }

    return $result;

}



if(checksignin()){
    
	gen_topdiv();
	
	echo '<link rel="stylesheet" href="asset/style/sidenav.css">
		<div id="maindiv">
			<div id="sidebar" class="sidenav">
			</div>
			<div id="main" class="main">';

    //if(isset($_SESSION['ses01']) && userlevel(base64_decode($_SESSION['ses01']))['club_type'] == 2){
    if(isset($_SESSION['ses01'])){

        gen_linkbar(userlevel(base64_decode($_SESSION['ses01']))['club_type']);

        if(!empty($_GET)) {       

                $data = booking_detail(base64_decode($_GET['oid']));

                $membername = getname($data['member_id']);
                $memberuname = $membername['fname']." ".$membername['lname']." (".$membername['username'].")";

                //$ondate = date('m/d/Y',$data['book_start']);
                $ondate = getthaidate($data['book_start']);
                $starthh = date('H:i',$data['book_start']);
                $stophh = date('H:i',$data['book_stop']);

                $dutytime = ($data['book_stop']-$data['book_start'])/3600;
                $dutyhh = floor($dutytime);
                $dutymm = $dutytime-$dutyhh;
                
                $bookon = getbooking($data['book_on']);

            echo '<form id="billorder" name="billorder" method="post" action="action.order.php" autocomplete="off" class="text-left" enctype="multipart/form-data"><input type="hidden" name="order_id" value="'.base64_decode($_GET['oid']).'"><input type="hidden" name="formin" value="editorder"><input type="hidden" name="from_url" value="'.geturl().'">
                <h3 class="text-center">รายการสั่งซื้อ</h3>            
                    <div class="row">
                        <div class="col-a"><label for="oforid">สมาชิก</label></div>
                        <div class="col-b">'.$memberuname.'</div>     
                    </div>
                    <link rel="stylesheet" href="asset/style/jquery-ui-timepicker-addon.css">
                    <script src="asset/js/jquery-ui-timepicker-addon.js"></script>
                   <div class="row">
                        <div class="col-a"></div>
                        <div class="col-b">
                            </div>
                    </div>
                        <div class="row">
                            <div class="col-a"><label>วันที่ใช้บริการ</label></div>
                            <div class="col-b"><p>'.$ondate.'</div>
                        </div>
                        <div class="row">
                            <div class="col-a"><label>เวลาเริ่ม</label></div>
                            <div class="col-b"><input type="hidden" name="ostarttime" value="'.$data['book_start'].'">'.$starthh.'น.</div>
                        </div>
                        <div class="row">
                            <div class="col-a"><label>เวลาสิ้นสุด</label></div>
                            <div class="col-b"><input type="hidden" name="ostoptime" value="'.$data['book_stop'].'">'.$stophh.'น.</div>
                        </div>
                        <div class="row">
                            <div class="col-a"><label for="oduty">จำนวน(ชั่วโมง)</label></div>
                            <div class="col-b"><div name="oduty"><p>'.$dutyhh.' ชั่วโมง '.str_pad($dutymm,2,"0",STR_PAD_LEFT).' นาที</p></div>
                            </div>
                        </div>
                        <div class="row">
                            <div class="col-a"><label>รายการ</label></div>
                            <div class="col-b">';
            
                                $order_detail = getorderlist(base64_decode($_GET['oid']));
                                if(!empty($order_detail)){
                                    
                                    $bill_detail = getbilling(base64_decode($_GET['oid']));
                                    
                                    echo '<table class="table table-hover table-bordered">
                                    <thead>
                                        <tr>
                                            <td class="trstep2">ลำดับ</td>
                                            <td>รายการ</td>
                                            <td>จำนวน</td>
                                            <td class="trstep2">หน่วย</td>
                                            <td>ราคา</td>                                           
                                        </tr>
                                    </thead>
                                    <tbody>';
                                    
                                    $line = 0;
                                    $cost = 0;
                                    
                                    generatemodal();
                                    
                                    foreach ($order_detail as $value) {
                                        # code...
                                        
                                        $line++;
                                        
                                        echo "<tr>";
                                        echo "<td class=\"trstep2\">{$line}</td>";
                                        echo "<td>".getprod_name($value['prod_id'])."</td>";
                                        echo "<td>".$value['prod_value']."</td>";
                                        echo "<td class=\"trstep2\">".getprod_unit($value['prod_id'])."</td>";
                                        echo "<td>".$value['cost']."</td>";
                                        
                                        $cost = $cost+(int)($value['cost']);
                                
                                    }
                                    
                                    
                                    echo "</tbody></table>";
                                }                    
            
                            echo '</div>
                        </div>
                        <div class="row">
                            <div class="col-a"></div>
                            <div class="col-b">จำนวน '.$line.' รายการ เป็นเงิน <input type="hidden" name="billcost" value="'.$cost.'">'.$cost.' บาท</div>
                        </div>
                        <div class="row">
                            <div class="col-a"></div>
                            <div class="col-b">';
            
                                $pay_value = 0;
            
                                foreach ($bill_detail as $value) { //บรรทัดนี้
                                    # code...
                                    $pay_value = $pay_value+$value['pay'];
                                    
                                }
                                
                                if($pay_value < $cost){                                   
                                    $dep_value = $cost - $pay_value;
                                    
                                    if(!userlevel(base64_decode($_SESSION['ses01']))['club_type'] == 0){
                                    //    $payment = 'หลักฐานการชำระเงิน<input id="pupload" name="pupload" type="file" class="form-control"><br>';
                                    //}
                                    //else{
                                        $payment = 'ชำระเพิ่ม <input type="number" name="pbillpayment"> บาท';
                                    }
                                }
                                else{ 
                                    $dep_value = 0;
                                    $payment = '';
                                }
                                                                    
                            echo '<p id="billpay">ชำระแล้ว '.$pay_value.' บาท</p><input type="hidden" id="pbillpay" name="pbillpay" value="'.$pay_value.'">
                            <p id="billdep">ค้างชำระ '.$dep_value.' บาท</p>
                            </div>
                        </div>
                        <div class="row">
                            <div class="col-a"></div>
                            <div class="col-b">'.@$payment.'</div>
                        </div>
                        <div class="row">
                            <div class="col-a"></div>
                            <div class="col-b">';
                                if($data['book_start'] > time() && $data['book_stop'] > time()){
                                    
                                    if(!userlevel(base64_decode($_SESSION['ses01']))['club_type'] == 0){
                                        echo '<button type="submit" id="submitbtn" name="submitbtn" class="btn btn-block btn-success" value="billorder">ตกลง</button>';
                                    }
                                }
                                echo '<a href="page.order.php" class="btn btn-block btn-danger">ยกเลิก</a><input type="hidden" name="formfor" value="แก้ไขคำสั่งซื้อ"><input type="hidden" id="token" name="token" value="'.gettoken().'">
                            </div>
                        </div>';
        
        }
    }

            echo '</div>
            </div>
        <div id="footdiv">
    </div>';
    
    htmlcontent('#sidebar',userdetail(getprofile(base64_decode($_SESSION['ses01']))));

}
else{
	header('location: action.order.php?error=3');
	die();
}

?>




Tag : PHP







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2018-07-01 13:45:16 By : toi2539 View : 619 Reply : 3
 

 

No. 1



โพสกระทู้ ( 0 )
บทความ ( 0 )



สถานะออฟไลน์


foreach ($bill_detail as $value) { //บรรทัดนี้

นี้ครับ ที่คิดปัญหา
Invalid argument supplied for foreach() in








ประวัติการแก้ไข
2018-07-01 13:51:44
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2018-07-01 13:46:14 By : toi2539
 


 

No. 2



โพสกระทู้ ( 23 )
บทความ ( 0 )



สถานะออฟไลน์


ลองตรวจสอบดูครับ ว่าตัวแปล $bill_detail มีค่าข้อมูลหรือเปล่า



if(count($bill_detail)>0){
foreach ($bill_detail as $value){
............
}
}

ลองดูครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2018-07-08 01:39:13 By : knzkidz
 

 

No. 3



โพสกระทู้ ( 4,759 )
บทความ ( 8 )



สถานะออฟไลน์


http://php.net/manual/en/control-structures.foreach.php
Quote:
foreach works only on arrays and objects

ทำงานเฉพาะ array หรือ object.

ก็ตรวจก่อนใช้

Code (PHP)
if (is_array($bill_detail)) {
     // foreach
}



หรือ


Code (PHP)
if (is_object($bill_detail)) {
    // foreach
}



ขึ้นอยู่กับว่าค่านั้นควรเป็นอะไร
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2018-07-08 11:27:48 By : mr.v
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : Invalid argument supplied for foreach() in ช่วยด้วย
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ FTP| ใส่แถวของตาราง ใส่คอลัมน์ตาราง| ตัวยก ตัวห้อย ตัวพิมพ์ดีด| ใส่โค้ด ใส่การอ้างถึงคำพูด| ใส่ลีสต์
smiley for :lol: smiley for :ken: smiley for :D smiley for :) smiley for ;) smiley for :eek: smiley for :geek: smiley for :roll: smiley for :erm: smiley for :cool: smiley for :blank: smiley for :idea: smiley for :ehh: smiley for :aargh: smiley for :evil:
Insert PHP Code
Insert ASP Code
Insert VB.NET Code Insert C#.NET Code Insert JavaScript Code Insert C#.NET Code
Insert Java Code
Insert Android Code
Insert Objective-C Code
Insert XML Code
Insert SQL Code
Insert Code
เพื่อความเรียบร้อยของข้อความ ควรจัดรูปแบบให้พอดีกับขนาดของหน้าจอ เพื่อง่ายต่อการอ่านและสบายตา และตรวจสอบภาษาไทยให้ถูกต้อง

อัพโหลดแทรกรูปภาพ

Notice

เพื่อความปลอดภัยของเว็บบอร์ด ไม่อนุญาติให้แทรก แท็ก [img]....[/img] โดยการอัพโหลดไฟล์รูปจากที่อื่น เช่นเว็บไซต์ ฟรีอัพโหลดต่าง ๆ
อัพโหลดแทรกรูปภาพ ให้ใช้บริการอัพโหลดไฟล์ของไทยครีเอท และตัดรูปภาพให้พอดีกับสกรีน เพื่อความโหลดเร็วและไฟล์ไม่ถูกลบทิ้ง

   
  เพื่อความปลอดภัยและการตรวจสอบ กระทู้ที่แทรกไฟล์อัพโหลดไฟล์จากที่อื่น อาจจะถูกลบทิ้ง
 
โดย
อีเมล์
บวกค่าให้ถูก
<= ตัวเลขฮินดูอารบิก เช่น 123 (หรือล็อกอินเข้าระบบสมาชิกเพื่อไม่ต้องกรอก)







Exchange: นำเข้าสินค้าจากจีน, Taobao, เฟอร์นิเจอร์, ของพรีเมี่ยม, ร่ม, ปากกา, power bank, แฟลชไดร์ฟ, กระบอกน้ำ

Load balance : Server 02
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2025 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
[Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 อัตราราคา คลิกที่นี่