장바구니 & 주문 데이터 암호화

· 5개월 전 · 805 · 3

기본적으로 영카트의 장바구니(g5_shop_cart)와 주문(g5_shop_order) 테이블에는 가격, 수량 같은 민감 데이터가 그대로 저장됨. 악의적인 사용자가 네트워크 구간을 가로채거나 브라우저 개발자 도구를 조작하면 가격 변조 시도가 가능함. 이를 막으려면 장바구니에 담을 때 **서명값(해시 토큰)**을 생성해서 함께 저장하고, 주문 단계에서 이 토큰을 다시 검증하는 방식이 효과적임. 예시는 다음과 같음.

 

// 장바구니 담을 때 (cartupdate.php)
$token = hash_hmac('sha256', $it_id.$ct_price.$ct_qty, G5_SECRET_KEY);
sql_query("INSERT INTO {$g5['g5_shop_cart_table']} 
(it_id, ct_price, ct_qty, ct_token) 
VALUES ('$it_id', '$ct_price', '$ct_qty', '$token')");
 

// 주문 단계 검증 (orderformupdate.php)
$row = sql_fetch("SELECT * FROM {$g5['g5_shop_cart_table']} WHERE it_id='$it_id'");
$check = hash_hmac('sha256', $row['it_id'].$row['ct_price'].$row['ct_qty'], G5_SECRET_KEY);
if($check !== $row['ct_token']) {
    alert("데이터 위변조가 감지되었습니다.");
    exit;
}
 

이렇게 하면 사용자가 가격이나 수량을 변조해도 해시 토큰 검증 단계에서 차단되므로 보안성과 신뢰도가 크게 올라감.

|

댓글 3개

이거는 따로 제안 게시판에 요청하면 어떨까요? ㅎㅎ

감사합니다^^
좋은정보 감사합니다
댓글을 작성하시려면 로그인이 필요합니다.

영카트5 팁자료실

+
제목 글쓴이 날짜 조회
3주 전 조회 364
2개월 전 조회 706
2개월 전 조회 660
2개월 전 조회 716
3개월 전 조회 902
4개월 전 조회 1,094
4개월 전 조회 681
4개월 전 조회 850
4개월 전 조회 991
4개월 전 조회 806
4개월 전 조회 855
4개월 전 조회 897
5개월 전 조회 1,002
5개월 전 조회 823
5개월 전 조회 806
5개월 전 조회 980
5개월 전 조회 970
5개월 전 조회 844
6개월 전 조회 1,125
6개월 전 조회 1,170
6개월 전 조회 959
6개월 전 조회 1,020
6개월 전 조회 976
7개월 전 조회 1,093
7개월 전 조회 1,032
7개월 전 조회 1,072
7개월 전 조회 890
7개월 전 조회 1,067
7개월 전 조회 1,054
8개월 전 조회 1,106