완전한 WooCommerce 사용자 정의 결제 필드 개발 가이드: 입문서부터 실제 사용까지

3분 읽기
2026-03-11
2026-06-03
1,974
아래 링크를 통해 쇼핑하면 추가 비용 없이 수수료를 받을 수 있습니다.

왜 결제 정보 필드를 사용자 정의해야 할까요?

WooCommerce의 기본 결제 페이지에는 이름, 주소, 이메일과 같은 기본 필드들이 제공되지만, 많은 특정 비즈니스 시나리오에서는 이러한 필드들만으로는 충분하지 않습니다. 예를 들어, 맞춤형 케이크를 판매하는 가게는 “케이크에 적힐 메시지”를 수집해야 할 수 있고, B2B 도매 웹사이트는 “회사의 세금 번호”가 필요할 수 있으며, 이벤트 티켓 판매 웹사이트는 참가자의 “신분증 번호”를 확인하는 데 사용해야 할 수 있습니다. 이러한 경우 개발자들은 결제 페이지의 필드를 사용자 정의하여 고유한 비즈니스 데이터 수집 요구사항을 충족시켜야 합니다.

커스텀 필드는 사용자 경험을 향상시키고 결제 프로세스를 비즈니스 요구사항에 더 잘 맞추는 데 도움을 줄 뿐만 아니라, 후속의 고객 관리, 주문 처리, 마케팅 활동에 필수적인 데이터도 제공합니다. 이러한 필드들을 백엔드와 이메일에서 올바르게 표시함으로써 전체 주문 프로세스의 정보 일관성을 보장할 수 있습니다.

핵심 메서드와 훅에 대한 상세 설명

WooCommerce는 강력하고 유연한 훅(Hooks) 시스템을 제공하여, 코어 코드를 수정하지 않고도 결제 페이지를 심층적으로 커스터마이징할 수 있게 해줍니다. 사용자 정의 필드를 구현하는 데에는 주로 세 가지 핵심 단계가 필요합니다: 필드 추가, 필드 검증, 그리고 필드 데이터의 저장 및 표시입니다. 각 단계는 특정한 WooCommerce 액션 훅(Action Hook) 또는 필터 훅(Filter Hook)과 연관되어 있습니다.

필드를 추가하는 데 사용되는 필터

필드를 추가하는 주요 방법은 다음과 같습니다: woocommerce_checkout_fields 이 필터를 사용하면 결제 양식의 각 부분(예: “청구서” 영역, “배송” 영역, 또는 사용자 정의된 “주문 추가 정보” 영역)에 새로운 입력 필드, 드롭다운 메뉴, 또는 체크박스를 삽입할 수 있습니다.

개발자는 콜백 함수를 작성해야 합니다. 이 함수는 기존의 필드 배열을 받아 수정한 후 새로운 배열을 반환합니다. 함수 내부에서는 각 새로운 필드의 유형, 레이블, 필수 여부, 우선순위(정렬용), CSS 클래스 등의 속성을 세밀하게 정의할 수 있습니다.

UltaHost의 WordPress 호스팅 서비스
30일 환불 보장, 무제한 대역폭 및 데이터베이스 이용, 무료 DDoS 보호 서비스 제공. 3년 구매 시 50% 용량이 할인됩니다.

필드를 검증하는 데 사용되는 후크(hook)

사용자가 결제 양식을 제출할 때, 우리는 사용자 정의 필드의 데이터가 모든 요구 사항을 충족하는지 반드시 확인해야 합니다. 이때 사용되는 것이 바로… woocommerce_checkout_process 액션 후크(Action Hook). 이 후크의 콜백 함수 내에서, 우리는 해당 데이터에 접근할 수 있습니다. $_POST 전역 변수를 통해 전송된 데이터를 검증합니다.

예를 들어, 필수 입력 필드가 비어 있는지 확인하거나 전화번호의 형식이 올바른지 검증할 수 있습니다. 검증에 실패한 경우에는 적절한 조치를 취할 수 있습니다. wc_add_notice() 이 함수는 사용자에게 오류 메시지를 표시하여 결제 프로세스가 계속 진행되는 것을 방지합니다.

데이터를 저장하고 표시하는 데 사용되는 훅(hook)

사용자가 주문을 제출한 후에는 사용자 정의 필드의 데이터를 주문의 메타데이터에 안전하게 저장해야 합니다. 이는 다음과 같은 방법으로 이루어집니다: woocommerce_checkout_update_order_meta 액션 후크(Action Hook)를 사용하여 작업을 완료합니다. 이 후크의 콜백 함수 내에서 필요한 작업을 수행할 수 있습니다. update_post_meta() 이 함수는 검증에 통과한 폼 데이터를 해당 주문에 저장합니다. wp_postmeta 데이터베이스 테이블에.

저장한 후에는 일반적으로 이 데이터를 세 곳에 표시해야 합니다: 관리자 백엔드의 주문 상세 페이지, 사용자가 받는 주문 확인 이메일, 그리고 고객 계정의 주문 정보 페이지입니다. 이는 각각 관리 인터페이스, 이메일 템플릿, 그리고 프론트엔드 계정 페이지의 커스터마이징을 포함합니다.

실전: “선물 메시지” 필드 추가하기

아래에서는 온라인 꽃집에 “선물 메시지” 텍스트 상자를 추가하는 방법을 완전한 예제를 통해 보여드리겠습니다. 이 필드는 주문 정보 영역에 표시되며, 선택 사항입니다. 사용자가 입력한 내용은 백엔드에 저장되고 이메일에도 함께 포함됩니다.

단계 1: 결제 페이지에 필드를 추가하세요.

먼저, 우리는 다음을 사용해야 합니다: woocommerce_checkout_fields 이 새로운 필드를 등록하기 위해 필터를 사용할 것입니다. 이 필드를 “주문 메모” 필드 뒤에 추가할 예정입니다. 다음은 해당 기능을 구현하는 코드로, 서브테마에 추가해야 합니다. functions.php 파일에 직접 추가하거나, 사용자 정의 기능 플러그인을 통해 추가할 수 있습니다.

add_filter( 'woocommerce_checkout_fields', 'add_custom_checkout_field' );
function add_custom_checkout_field( $fields ) {
    $fields['order']['gift_message'] = array(
        'type'        => 'textarea',
        'class'       => array('form-row-wide'),
        'label'       => __('礼品祝福留言', 'your-text-domain'),
        'placeholder' => __('请输入您想写在贺卡上的祝福语(可选)', 'your-text-domain'),
        'required'    => false,
        'priority'    => 25, // 显示在订单备注(priority 21)之后
    );
    return $fields;
}

이 코드는 무언가를 생성합니다. 구체적으로 무엇을 생성하는지는 코드의 내용에 따라 달라집니다. textarea 이 필드는 “선물 축하 메시지’라는 라벨을 가지고 있으며, 해당하는 변수와 CSS 클래스가 설정되어 있습니다.priority 매개변수가 그 표시 위치를 결정합니다.

단계 2: 필드 데이터를 주문 정보에 저장하기

다음으로, 주문을 생성할 때 사용자가 입력한 메시지를 저장해야 합니다. woocommerce_checkout_update_order_meta 그것은 후크를 사용하여 구현됩니다.

호스팅닷컴 공유 호스팅
AMD EPYC CPU, NVMe SSD 스토리지 및 LiteSpeed를 통한 고성능, 연중무휴 24시간 전문가 사내 지원, SSL, 무차별 공격, 멀웨어 및 DDoS 보호를 포함한 고급 보안 조치, 최대 73%의 비용 절감.
add_action( 'woocommerce_checkout_update_order_meta', 'save_custom_checkout_field' );
function save_custom_checkout_field( $order_id ) {
    if ( ! empty( $_POST['gift_message'] ) ) {
        update_post_meta( $order_id, '_gift_message', sanitize_textarea_field( $_POST['gift_message'] ) );
    }
}

여기서, 우리가 확인해 보겠습니다. $_POST['gift_message'] 값이 있는지 확인하십시오. 값이 있다면 그 값을 사용하십시오. sanitize_textarea_field() 함수가 안전한 방식으로 데이터를 정리한 후, 그 데이터를 사용합니다. update_post_meta() 이를 주문 메타데이터로 저장하십시오. 메타키의 이름은… _gift_message

단계 3: 백엔드와 이메일에 데이터를 표시합니다.

데이터가 저장된 후에는 이를 사용자가 볼 수 있도록 해야 합니다. 다음 코드는 관리자 후면의 주문 상세 페이지와 고객 이메일에 해당 필드를 어떻게 표시하는지를 보여줍니다.

// 在管理员订单详情页显示
add_action( 'woocommerce_admin_order_data_after_billing_address', 'display_custom_field_admin' );
function display_custom_field_admin( $order ) {
    $gift_message = get_post_meta( $order->get_id(), '_gift_message', true );
    if ( $gift_message ) {
        echo '<p><strong>' . __( '礼品留言:', 'your-text-domain' ) . '</strong><br />'`. esc_html($gift_message).`'</p>';
    }
}

// 在订单确认邮件中显示
add_filter( 'woocommerce_email_order_meta_fields', 'display_custom_field_in_email', 10, 3 );
function display_custom_field_in_email( $fields, $sent_to_admin, $order ) {
    $gift_message = get_post_meta( $order-&gt;get_id(), '_gift_message', true );
    if ( $gift_message ) {
        $fields['gift_message'] = array(
            'label' =&gt; __( '礼品留言', 'your-text-domain' ),
            'value' =&gt; wptexturize( $gift_message ),
        );
    }
    return $fields;
}

첫 번째 함수는 메시지를 백엔드 주문의 청구 주소 아래에 표시합니다. 두 번째 함수는 메시지를 새로운 데이터 행으로 추가하여 WooCommerce가 보내는 주문 확인 이메일에 포함시킵니다.

고급 기술 및 주의 사항

기본적인 방법들을 익힌 후에는 더 복잡한 사용 시나리오와 최적화 방안을 탐구할 수 있으며, 이를 통해 사용자 정의 필드를 더 강력하고 사용하기 편리하게 만들 수 있습니다.

조건에 따라 필드를 표시하도록 설정합니다.

때로는 특정 필드가 표시되는지 여부가 다른 필드의 값에 따라 결정됩니다. 예를 들어, 사용자가 “인보이스 필요”를 선택했을 때만 “인보이스 발신자 정보” 필드가 표시되는 경우가 있습니다. 이러한 기능은 프론트엔드 상호작용을 구현하기 위해 JavaScript가 필요합니다. 체크박스와 같은 트리거 필드에 해당 기능을 추가할 수 있습니다. change 이벤트 리스너를 사용하여 대상 필드의 표시 또는 숨김을 동적으로 제어합니다. 또한, 서버 측의 검증 로직에서도 이에 맞는 처리를 수행해야 합니다.

필드 데이터의 보안 및 정리

보안은 매우 중요합니다. 사용자가 입력한 데이터를 처리할 때는 항상 검증과 정제 과정을 거쳐야 합니다. 텍스트 상자의 경우, 적절한 검증 및 정제 방법을 사용해야 합니다. sanitize_text_field() 또는 sanitize_textarea_field()이메일의 경우, 다음과 같이 사용하십시오: sanitize_email()데이터를 프론트엔드에 출력할 때는 반드시 적절한 방법을 사용해야 합니다. esc_html() 또는 wp_kses_post() 등의 함수를 사용하여 문자를 이스케이프 처리함으로써 크로스사이트 스크립팅(XSS) 공격을 방지할 수 있습니다.

InterServer 공유 호스팅
공유 호스팅 월 $2.50 USD, 첫 달 $0.1 USD 프로모션 코드 tryinterserver, 461개 클라우드 앱 스크립트, 원클릭 설치.

제3자 플러그인 및 테마와의 호환성

커스텀 필드를 추가할 때는 특정 테마나 다른 플러그인(특히 결제 관련 최적화 플러그인)의 스타일이나 스크립트와 충돌이 발생할 수 있습니다. 따라서 항상 서브테마(sub-theme)에서 개발을 진행하고, 커스텀 필드를 포함하는 컨테이너 요소에 고유한 CSS 클래스명을 부여하는 것이 좋습니다. 정식으로 배포하기 전에는 다양한 테마와 일반적으로 사용되는 플러그인이 활성화된 상태에서도 충분히 테스트를 해보아야 합니다. 브라우저 개발자 도구를 사용하여 요소와 스크립트의 오류를 확인하는 것은 호환성 문제를 디버깅하는 데 매우 중요한 방법입니다.

요약

이 문서의 가이드를 통해 우리는 요구사항을 이해하는 것부터 시작하여 WooCommerce의 사용자 정의 결제 정보 필드를 개발하는 전체 과정을 단계별로 살펴보았습니다. 우리는 어떻게 이러한 사용자 정의 필드들을 활용할 수 있는지도 배웠습니다. woocommerce_checkout_fieldswoocommerce_checkout_process 그리고 woocommerce_checkout_update_order_meta 이 세 가지 핵심 기능(핵심 “훅”)을 사용하여 필드를 추가하고, 검증하며, 저장합니다. 또한 “선물 메시지”라는 실제 사례를 통해 필드 생성부터 데이터 표시에 이르는 전 과정을 완벽하게 시연합니다. 마지막으로, 조건부 필드, 보안 처리, 호환성과 같은 고급 주제에 대해서도 논의합니다.

이러한 기술들을 숙달하면 다양한 전자상거래 비즈니스에서 요구되는 독특한 데이터 수집 요구사항에 유연하게 대응할 수 있으며, 더 전문적이고 개인화된 WooCommerce 상점을 만들 수 있습니다. 이를 통해 전환율과 고객 만족도를 향상시킬 수 있습니다.

자주 묻는 질문

커스텀 필드의 데이터는 어디에 저장되나요?

커스텀 필드의 데이터는 일반적으로 “주문 메타데이터”로서 WordPress 데이터베이스에 저장됩니다. wp_postmeta 표 안에는 각 데이터마다 해당하는 주문 ID가 포함되어 있습니다.post_id), 그리고 당신이 정의한 메타키(예: _gift_message) 및 메타값을 설정할 수 있습니다. 이를 위해 WooCommerce의 주문 객체(Order object)에 제공되는 메서드들을 사용할 수 있습니다. $order->get_meta(‘_gift_message’) 또는 WordPress 함수 get_post_meta() 이 데이터를 얻기 위해…

커스텀 필드에 프론트엔드 검증(예: 형식 검증)을 추가하는 방법은 무엇인가요?

사용하는 것 외에도, woocommerce_checkout_process 서버 측에서 검증을 수행하는 것 외에도, 필드에 HTML5의 원본 속성을 추가하여 기본적인 검증을 할 수 있습니다. 예를 들어… pattern 정규 표현식에 사용됩니다.type=”email” 이것은 이메일 형식을 위한 것입니다. 더 복잡한 실시간 검증을 위해서는 JavaScript/jQuery 코드를 작성하여 해당 필드의 변경 사항을 감지해야 합니다. blur 또는 input 이벤트가 발생하면 해당 값이 규칙에 부합하는지 확인하고 즉시 피드백을 제공합니다.

사용자 등록 페이지에 사용자 정의 필드를 추가할 수 있을까요?

네, 가능하지만 프로세스가 약간 다릅니다. WooCommerce의 결제 정보 관련 훅은 결제 페이지에서만 사용됩니다. “내 계정” 등록 페이지에 필드를 추가하려면 WordPress와 WooCommerce가 제공하는 다른 훅들을 사용해야 합니다. woocommerce_register_form 필드를 추가하려면…woocommerce_created_customer 이 기능은 필드 데이터를 사용자 메타데이터에 저장하는 데 사용됩니다. 원리는 결제 관련 필드와 유사하지만, 대상이 되는 핸들러(handler)와 데이터가 저장되는 위치(사용자 메타데이터)가 다릅니다.

왜 제 사용자 정의 필드가 표시되지 않나요?

먼저, 코드가 올바르게 추가되었는지 확인해 주세요. functions.php 또한 문법 오류도 없습니다. 다음으로, 필드 배열의 키가 올바른지 확인해 주세요. 예를 들어, 해당 키를 배열에 추가했는지 확인해 보세요. $fields[‘order’] 그럼에도 불구하고 $fields[‘billing’] 일부 경우에는 다른 플러그인이나 테마의 코드가 사용자의 설정된 필드들을 덮어쓰거나 삭제했을 수 있습니다. 다시 한 번 확인해 보세요. 마지막으로, 웹사이트와 브라우저의 캐시를 삭제해 보세요. 오래된 CSS/JS 파일이 페이지 렌더링에 영향을 미칠 수 있기 때문입니다.