테스트 사이트 - 개발 중인 베타 버전입니다

cartupdate.php 질문 드립니다. 채택완료

아이존 6년 전 조회 3,526

100개 이상을 원래가격에 50프로를 할인해주기 위해서 아래와 같은 코드로

cartupdate.php 에 넣어줬습니다.

문제는 바로구매는 잘되는데 장바구니에 넣으면 가격이 이상해지는군요

1개에 10,000원 짜리가 3개사도 15,000원 이렇게 나옵니다. 100개 이상사야 되는 할인률인데도요

 

뭐가 문제인가요 ㅜㅜ

 

 if ($ct_qty >= '100'){
  $it['it_price'] = ceil($it['it_price'] * 0.5 / 100) * 100;
 }

댓글을 작성하려면 로그인이 필요합니다.

답변 3개

채택된 답변
+20 포인트
플래토
6년 전

장바구니에 넣어서 처리를 할때

의심이 가는 부분에서 작동을 멈추시고

해당 시점에서

 

변수값을 출력해보세요

 

$ct_qty 를 비교하려고 하는 직전에서

 

echo $ct_qty;

exit;

이상이 없는경우

 

비교문에서 참/거짓중 어느것으로 작동하는지도 

출력을 해보면 좀더 정확할겁니다.

 

echo (intval($ct_qty) >= '100');

또는

echo (intval($ct_qty) >= 100);

르 찍어보면 참이면 1 거짓이면 0 이 나올겁니다.

로그인 후 평가할 수 있습니다

댓글을 작성하려면 로그인이 필요합니다.

6년 전

cartupdate.php 입니다.

222라인에 소스를 넣었거든요 ㅜㅜ

 

</p>

<p><?php

include_once('./_common.php');</p>

<p>// print_r2($_POST); exit;</p>

<p>// 보관기간이 지난 상품 삭제

cart_item_clean();</p>

<p>// cart id 설정

set_cart_id($sw_direct);</p>

<p>if($sw_direct)

    $tmp_cart_id = get_session('ss_cart_direct');

else

    $tmp_cart_id = get_session('ss_cart_id');</p>

<p>// 브라우저에서 쿠키를 허용하지 않은 경우라고 볼 수 있음.

if (!$tmp_cart_id)

{

    alert('더 이상 작업을 진행할 수 없습니다.\\n\\n브라우저의 쿠키 허용을 사용하지 않음으로 설정한것 같습니다.\\n\\n브라우저의 인터넷 옵션에서 쿠키 허용을 사용으로 설정해 주십시오.\\n\\n그래도 진행이 되지 않는다면 쇼핑몰 운영자에게 문의 바랍니다.');

}</p>

<p>$tmp_cart_id = preg_replace('/[^a-z0-9_\-]/i', '', $tmp_cart_id);</p>

<p>// 레벨(권한)이 상품구입 권한보다 작다면 상품을 구입할 수 없음.

if ($member['mb_level'] < $default['de_level_sell'])

{

    alert('상품을 구입할 수 있는 권한이 없습니다.');

}</p>

<p>if($act == "buy")

{

    if(!count($_POST['ct_chk']))

        alert("주문하실 상품을 하나이상 선택해 주십시오.");</p>

<p>    // 선택필드 초기화

    $sql = " update {$g5['g5_shop_cart_table']} set ct_select = '0' where od_id = '$tmp_cart_id' ";

    sql_query($sql);</p>

<p>    $fldcnt = count($_POST['it_id']);

    for($i=0; $i<$fldcnt; $i++) {

        $ct_chk = $_POST['ct_chk'][$i];

        if($ct_chk) {

            $it_id = $_POST['it_id'][$i];</p>

<p>            // 주문 상품의 재고체크

            $sql = " select ct_qty, it_name, ct_option, io_id, io_type

                        from {$g5['g5_shop_cart_table']}

                        where od_id = '$tmp_cart_id'

                          and it_id = '$it_id' ";

            $result = sql_query($sql);</p>

<p>            for($k=0; $row=sql_fetch_array($result); $k++) {

                $sql = " select SUM(ct_qty) as cnt from {$g5['g5_shop_cart_table']}

                          where od_id <> '$tmp_cart_id'

                            and it_id = '$it_id'

                            and io_id = '{$row['io_id']}'

                            and io_type = '{$row['io_type']}'

                            and ct_stock_use = 0

                            and ct_status = '쇼핑'

                            and ct_select = '1' ";

                $sum = sql_fetch($sql);

                $sum_qty = $sum['cnt'];</p>

<p>                // 재고 구함

                $ct_qty = $row['ct_qty'];

                if(!$row['io_id'])

                    $it_stock_qty = get_it_stock_qty($it_id);

                else

                    $it_stock_qty = get_option_stock_qty($it_id, $row['io_id'], $row['io_type']);</p>

<p>                if ($ct_qty + $sum_qty > $it_stock_qty)

                {

                    $item_option = $row['it_name'];

                    if($row['io_id'])

                        $item_option .= '('.$row['ct_option'].')';</p>

<p>                    alert($item_option." 의 재고수량이 부족합니다.\\n\\n현재 재고수량 : " . number_format($it_stock_qty - $sum_qty) . " 개");

                }

            }</p>

<p>            $sql = " update {$g5['g5_shop_cart_table']}

                        set ct_select = '1',

                            ct_select_time = '".G5_TIME_YMDHIS."'

                        where od_id = '$tmp_cart_id'

                          and it_id = '$it_id' ";

            sql_query($sql);

        }

    }</p>

<p>    if ($is_member) // 회원인 경우

        goto_url(G5_SHOP_URL.'/orderform.php');

    else

        goto_url(G5_BBS_URL.'/login.php?url='.urlencode(G5_SHOP_URL.'/orderform.php'));

}

else if ($act == "alldelete") // 모두 삭제이면

{

    $sql = " delete from {$g5['g5_shop_cart_table']}

              where od_id = '$tmp_cart_id' ";

    sql_query($sql);

}

else if ($act == "seldelete") // 선택삭제

{

    if(!count($_POST['ct_chk']))

        alert("삭제하실 상품을 하나이상 선택해 주십시오.");</p>

<p>    $fldcnt = count($_POST['it_id']);

    for($i=0; $i<$fldcnt; $i++) {

        $ct_chk = $_POST['ct_chk'][$i];

        if($ct_chk) {

            $it_id = $_POST['it_id'][$i];

            $sql = " delete from {$g5['g5_shop_cart_table']} where it_id = '$it_id' and od_id = '$tmp_cart_id' ";

            sql_query($sql);

        }

    }

}

else // 장바구니에 담기

{

    $count = count($_POST['it_id']);

    if ($count < 1)

        alert('장바구니에 담을 상품을 선택하여 주십시오.');</p>

<p>    $ct_count = 0;

    for($i=0; $i<$count; $i++) {

        // 보관함의 상품을 담을 때 체크되지 않은 상품 건너뜀

        if($act == 'multi' && !$_POST['chk_it_id'][$i])

            continue;</p>

<p>        $it_id = $_POST['it_id'][$i];

        $opt_count = count($_POST['io_id'][$it_id]);</p>

<p>        if($opt_count && $_POST['io_type'][$it_id][0] != 0)

            alert('상품의 선택옵션을 선택해 주십시오.');</p>

<p>        for($k=0; $k<$opt_count; $k++) {

            if ($_POST['ct_qty'][$it_id][$k] < 1)

                alert('수량은 1 이상 입력해 주십시오.');

        }</p>

<p>        // 상품정보

        $sql = " select * from {$g5['g5_shop_item_table']} where it_id = '$it_id' ";

        $it = sql_fetch($sql);

        if(!$it['it_id'])

            alert('상품정보가 존재하지 않습니다.');</p>

<p>        // 바로구매에 있던 장바구니 자료를 지운다.

        if($i == 0 && $sw_direct)

            sql_query(" delete from {$g5['g5_shop_cart_table']} where od_id = '$tmp_cart_id' and ct_direct = 1 ", false);</p>

<p>        // 최소, 최대 수량 체크

        if($it['it_buy_min_qty'] || $it['it_buy_max_qty']) {

            $sum_qty = 0;

            for($k=0; $k<$opt_count; $k++) {

                if($_POST['io_type'][$it_id][$k] == 0)

                    $sum_qty += (int) $_POST['ct_qty'][$it_id][$k];

            }</p>

<p>            if($it['it_buy_min_qty'] > 0 && $sum_qty < $it['it_buy_min_qty'])

                alert($it['it_name'].'의 선택옵션 개수 총합 '.number_format($it['it_buy_min_qty']).'개 이상 주문해 주십시오.');</p>

<p>            if($it['it_buy_max_qty'] > 0 && $sum_qty > $it['it_buy_max_qty'])

                alert($it['it_name'].'의 선택옵션 개수 총합 '.number_format($it['it_buy_max_qty']).'개 이하로 주문해 주십시오.');</p>

<p>            // 기존에 장바구니에 담긴 상품이 있는 경우에 최대 구매수량 체크

            if($it['it_buy_max_qty'] > 0) {

                $sql4 = " select sum(ct_qty) as ct_sum

                            from {$g5['g5_shop_cart_table']}

                            where od_id = '$tmp_cart_id'

                              and it_id = '$it_id'

                              and io_type = '0'

                              and ct_status = '쇼핑' ";

                $row4 = sql_fetch($sql4);</p>

<p>                if(($sum_qty + $row4['ct_sum']) > $it['it_buy_max_qty'])

                    alert($it['it_name'].'의 선택옵션 개수 총합 '.number_format($it['it_buy_max_qty']).'개 이하로 주문해 주십시오.', './cart.php');

            }

        }</p>

<p>        // 옵션정보를 얻어서 배열에 저장

        $opt_list = array();

        $sql = " select * from {$g5['g5_shop_item_option_table']} where it_id = '$it_id' and io_use = 1 order by io_no asc ";

        $result = sql_query($sql);

        $lst_count = 0;

        for($k=0; $row=sql_fetch_array($result); $k++) {

            $opt_list[$row['io_type']][$row['io_id']]['id'] = $row['io_id'];

            $opt_list[$row['io_type']][$row['io_id']]['use'] = $row['io_use'];

            $opt_list[$row['io_type']][$row['io_id']]['price'] = $row['io_price'];

            $opt_list[$row['io_type']][$row['io_id']]['stock'] = $row['io_stock_qty'];</p>

<p>            // 선택옵션 개수

            if(!$row['io_type'])

                $lst_count++;

        }</p>

<p>        //--------------------------------------------------------

        //  재고 검사, 바로구매일 때만 체크

        //--------------------------------------------------------

        // 이미 주문폼에 있는 같은 상품의 수량합계를 구한다.

        if($sw_direct) {

            for($k=0; $k<$opt_count; $k++) {

                $io_id = preg_replace(G5_OPTION_ID_FILTER, '', $_POST['io_id'][$it_id][$k]);

                $io_type = preg_replace('#[^01]#', '', $_POST['io_type'][$it_id][$k]);

                $io_value = $_POST['io_value'][$it_id][$k];</p>

<p>                $sql = " select SUM(ct_qty) as cnt from {$g5['g5_shop_cart_table']}

                          where od_id <> '$tmp_cart_id'

                            and it_id = '$it_id'

                            and io_id = '$io_id'

                            and io_type = '$io_type'

                            and ct_stock_use = 0

                            and ct_status = '쇼핑'

                            and ct_select = '1' ";

                $row = sql_fetch($sql);

                $sum_qty = $row['cnt'];</p>

<p>                // 재고 구함

                $ct_qty = (int) $_POST['ct_qty'][$it_id][$k];

                if(!$io_id)

                    $it_stock_qty = get_it_stock_qty($it_id);

                else

                    $it_stock_qty = get_option_stock_qty($it_id, $io_id, $io_type);</p>

<p>                if ($ct_qty + $sum_qty > $it_stock_qty)

                {

                    alert($io_value." 의 재고수량이 부족합니다.\\n\\n현재 재고수량 : " . number_format($it_stock_qty - $sum_qty) . " 개");

                }

            }

        }

        //--------------------------------------------------------</p>

<p>        // 옵션수정일 때 기존 장바구니 자료를 먼저 삭제

        if($act == 'optionmod')

            sql_query(" delete from {$g5['g5_shop_cart_table']} where od_id = '$tmp_cart_id' and it_id = '$it_id' ");</p>

<p>        // 장바구니에 Insert

        // 바로구매일 경우 장바구니가 체크된것으로 강제 설정

        if($sw_direct) {

            $ct_select = 1;

            $ct_select_time = G5_TIME_YMDHIS;

        } else {

            $ct_select = 0;

            $ct_select_time = '0000-00-00 00:00:00';

        }</p>

<p>        // 장바구니에 Insert

        $comma = '';

        $sql = " INSERT INTO {$g5['g5_shop_cart_table']}

                        ( od_id, mb_id, it_id, it_name, it_sc_type, it_sc_method, it_sc_price, it_sc_minimum, it_sc_qty, ct_status, ct_price, ct_point, ct_point_use, ct_stock_use, ct_option, ct_qty, ct_notax, io_id, io_type, io_price, ct_time, ct_ip, ct_send_cost, ct_direct, ct_select, ct_select_time )

                    VALUES ";</p>

<p>        for($k=0; $k<$opt_count; $k++) {

            $io_id = preg_replace(G5_OPTION_ID_FILTER, '', $_POST['io_id'][$it_id][$k]);

            $io_type = preg_replace('#[^01]#', '', $_POST['io_type'][$it_id][$k]);

            $io_value = $_POST['io_value'][$it_id][$k];</p>

<p>            // 선택옵션정보가 존재하는데 선택된 옵션이 없으면 건너뜀

            if($lst_count && $io_id == '')

                continue;</p>

<p>            // 구매할 수 없는 옵션은 건너뜀

            if($io_id && !$opt_list[$io_type][$io_id]['use'])

                continue;</p>

<p>/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////</p>

<p> if (intval($ct_qty) >= '100'){

  $it['it_price'] = ceil($it['it_price'] * 0.5 / 100) * 100;

 }</p>

<p>/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////</p>

<p>            $io_price = $opt_list[$io_type][$io_id]['price'];

            $ct_qty = (int) $_POST['ct_qty'][$it_id][$k];</p>

<p>            // 구매가격이 음수인지 체크

            if($io_type) {

                if((int)$io_price < 0)

                    alert('구매금액이 음수인 상품은 구매할 수 없습니다.');

            } else {

                if((int)$it['it_price'] + (int)$io_price < 0)

                    alert('구매금액이 음수인 상품은 구매할 수 없습니다.');

            }</p>

<p>            // 동일옵션의 상품이 있으면 수량 더함

            $sql2 = " select ct_id, io_type, ct_qty

                        from {$g5['g5_shop_cart_table']}

                        where od_id = '$tmp_cart_id'

                          and it_id = '$it_id'

                          and io_id = '$io_id'

                          and ct_status = '쇼핑' ";

            $row2 = sql_fetch($sql2);

            if($row2['ct_id']) {

                // 재고체크

                $tmp_ct_qty = $row2['ct_qty'];

                if(!$io_id)

                    $tmp_it_stock_qty = get_it_stock_qty($it_id);

                else

                    $tmp_it_stock_qty = get_option_stock_qty($it_id, $io_id, $row2['io_type']);</p>

<p>                if ($tmp_ct_qty + $ct_qty > $tmp_it_stock_qty)

                {

                    alert($io_value." 의 재고수량이 부족합니다.\\n\\n현재 재고수량 : " . number_format($tmp_it_stock_qty) . " 개");

                }</p>

<p>                $sql3 = " update {$g5['g5_shop_cart_table']}

                            set ct_qty = ct_qty + '$ct_qty'

                            where ct_id = '{$row2['ct_id']}' ";

                sql_query($sql3);

                continue;

            }</p>

<p>            // 포인트

            $point = 0;

            if($config['cf_use_point']) {

                if($io_type == 0) {

                    $point = get_item_point($it, $io_id);

                } else {

                    $point = $it['it_supply_point'];

                }</p>

<p>                if($point < 0)

                    $point = 0;

            }</p>

<p>            // 배송비결제

            if($it['it_sc_type'] == 1)

                $ct_send_cost = 2; // 무료

            else if($it['it_sc_type'] > 1 && $it['it_sc_method'] == 1)

                $ct_send_cost = 1; // 착불

           

            $io_value = sql_real_escape_string(strip_tags($io_value));

            $remote_addr = get_real_client_ip();</p>

<p>            $sql .= $comma."( '$tmp_cart_id', '{$member['mb_id']}', '{$it['it_id']}', '".addslashes($it['it_name'])."', '{$it['it_sc_type']}', '{$it['it_sc_method']}', '{$it['it_sc_price']}', '{$it['it_sc_minimum']}', '{$it['it_sc_qty']}', '쇼핑', '{$it['it_price']}', '$point', '0', '0', '$io_value', '$ct_qty', '{$it['it_notax']}', '$io_id', '$io_type', '$io_price', '".G5_TIME_YMDHIS."', '$remote_addr', '$ct_send_cost', '$sw_direct', '$ct_select', '$ct_select_time' )";

            $comma = ' , ';

            $ct_count++;

        }</p>

<p>        if($ct_count > 0)

            sql_query($sql);

    }

}</p>

<p>// 바로 구매일 경우

if ($sw_direct)

{

    if ($is_member)

    {

     goto_url(G5_SHOP_URL."/orderform.php?sw_direct=$sw_direct");

    }

    else

    {

     goto_url(G5_BBS_URL."/login.php?url=".urlencode(G5_SHOP_URL."/orderform.php?sw_direct=$sw_direct"));

    }

}

else

{

    goto_url(G5_SHOP_URL.'/cart.php');

}

?></p>

<p>

로그인 후 평가할 수 있습니다

답변에 대한 댓글 1개

플래토
6년 전
100을 문자로 넣으셨네요
''를제거하세요

댓글을 작성하려면 로그인이 필요합니다.

플래토
6년 전

$ct_qty 는 문자로 비교하시면 안됩니다.

 

(int)$ct_qty >= 100 

또는

intval($ct_qty) >= 100 

으로 되어야 비교문이 제대로 작동할겁니다.

문자로는 1보다 2나 3이 크게 인식됩니다.

로그인 후 평가할 수 있습니다

답변에 대한 댓글 2개

아이존
6년 전
바로구매는 할인률이 잘 적용이 되는데
장바구니는 할인률이 적용이 안되네요
소스를 올리려니 글자 제한이 있나봐요
답변글로 소스 올려볼께요 ㅜㅜ
아이존
6년 전
'' 지워도 똑같네요 ㅜㅜ

댓글을 작성하려면 로그인이 필요합니다.

답변을 작성하려면 로그인이 필요합니다.

로그인