• 개발자 가이드
  • SDK Integration
  • Web SDK

Web SDK

SDK 설치

패키지 설치

아래 3가지 방법 중 하나를 선택해서 설치해주세요.

옵션1. 직접 로드

아래 코드를 <head> 태그 가장 하단에 추가합니다.

JavaScript
12345678
<script>
(function(a_,i_,r_,_b,_r,_i,_d,_g,_e){if(!a_[_b]){var n=function(){var c=i_.createElement(r_);c.onerror=function(){g.queue.filter(function(a){return 0<=_d.indexOf(a[0])}).forEach(function(a){a=a[1];a=a[a.length-1];"function"===typeof a&&a("error occur when load airbridge")})};c.async=1;c.src=_r;"complete"===i_.readyState?i_.head.appendChild(c):a_.addEventListener("load",function h(){a_.removeEventListener("load",h);i_.head.appendChild(c)})},g={queue:[],get isSDKEnabled(){return!1}};_i.concat(_d).forEach(function(c){var a=c.split("."),h=a.pop();a.reduce(function(p,q){return p[q]=p[q]||{}},g)[h]=function(){g.queue.push([c,arguments])}});a_[_b]=g;0<_g?(_b=new (a_.XDomainRequest||a_.XMLHttpRequest),_i=function(){},_b.open("GET",_r),_b.timeout=_g,_b.onload=function(){n()},_b.onerror=_i,_b.onprogress=_i,_b.ontimeout=_i,_b.send()):n()}})(window,document,"script","airbridge","//static.airbridge.io/sdk/latest/airbridge.min.js","init startTracking stopTracking fetchResource openBanner setBanner setDownload setDownloads openDeeplink setDeeplinks sendWeb setUserAgent setMobileAppData setUserID clearUserID setUserEmail clearUserEmail setUserPhone clearUserPhone setUserAttribute removeUserAttribute clearUserAttributes setUserAlias removeUserAlias clearUserAlias clearUser setUserId setUserAttributes addUserAlias setDeviceAlias removeDeviceAlias clearDeviceAlias setDeviceIFV setDeviceIFA setDeviceGAID events.send events.signIn events.signUp events.signOut events.purchased events.addedToCart events.productDetailsViewEvent events.homeViewEvent events.productListViewEvent events.searchResultViewEvent".split(" "),["events.wait","createTouchpoint"],0);

airbridge.init({
    app: '<YOUR_APP_NAME>',
    webToken: '<YOUR_WEB_TOKEN>',
})
</script>

'앱 이름'과 '웹 SDK 토큰'은 대시보드의 'Settings → Tokens' 에서 확인할 수 있습니다.

Protected Attribution Window 설정

웹투앱 성과를 측정하기 위해서는 프로텍티드 어트리뷰션 윈도우(Protected Attribution Window, PAW) 설정이 필요할 수 있습니다. PAW에 대한 자세한 내용은 에어브릿지 가이드를 참고해 주세요.

옵션2. NPM 모듈 사용

아래의 명령어를 실행하여 airbridge-web-sdk-loader를 설치합니다.

1
npm install airbridge-web-sdk-loader

airbridge-web-sdk-loader에서 airbridge를 불러온 후 init 함수를 실행합니다.

123456
import airbridge from 'airbridge-web-sdk-loader'

airbridge.init({
    app: 'YOUR_APP_NAME',
    webToken: 'YOUR_WEB_TOKEN',
})

Google Tag Manager 사용 (옵션 3)

Google Tag Manager를 이용한 SDK 설치 섹션을 참고해주세요.

지원 브라우저

에어브릿지 Web SDK는 ES5를 지원하는 모든 브라우저에서 동작합니다.

Chrome

Firefox

Safari

Internet Explorer

✔️

✔️

✔️

IE 9 이상

설치 확인

123
button.onclick = () => {
    console.log(airbridge.isSDKEnabled)
}

Web SDK 가 설치된 웹페이지로 이동한 뒤, 개발자 콘솔을 열고 airbridge.isSDKEnabled를 입력하여 true가 출력되는지 확인합니다.

true가 잘 출력된다면 Airbridge 대시보드의 [Raw Data] > [Web Real-time Logs]에서 조회 이벤트(Open)가 잘 수집되는 것을 확인할 수 있습니다.

airbridge.isSDKEnabled 는 Web SDK가 모두 로딩되고, 초기화가 완료되고 나서 false에서 true 로 전환됩니다.

사용자 설정

init시 사용자 식별자 및 속성 설정

init시 사용자 정보를 전달하여, 웹사이트에서 발생하는 모든 이벤트에 사용자 정보를 담을 수 있습니다. 설정한 사용자 정보는 Browser의 Local Storage에 남아 signOut 함수가 호출되기 전까지 모든 이벤트에 함께 전송됩니다.

1234567891011121314151617
airbridge.init({
    app: 'YOUR_APP_NAME',
    webToken: 'YOUR_WEB_TOKEN',
    // ...
    user: {
        externalUserID: 'personID',
        externalUserEmail: 'persondoe@airbridge.io',
        externalUserPhone: '1(123)123-1234',
        attributes: {
            age_group: 30,
            gender: 'Female'
        },
        alias: {
            custom_id: '83587901-2726-4E29-ACEB-A90B0F7E75F6',
        },
    },
})

Attributes

Type

Description

user.externalUserID

String

사용자 ID

user.externalUserEmail

String

사용자 Email

user.externalUserPhone

String

사용자 휴대폰 번호

user.attributes

Object

사용자 속성 (커스텀 Key Value Pair)

user.alias

Object

사용자 ID Alias

사용자 식별자 설정

setUserIDsetUserEmail와 같은 메소드를 사용하여, 사용자 식별자를 설정할 수 있습니다. 설정한 사용자 정보는 Browser의 Local Storage에 남아 clearUser 함수가 호출되기 전까지 모든 이벤트에 함께 전송됩니다.

12
airbridge.setUserID('654321')
airbridge.setUserEmail('user@example.com')

아래와 같은 방법을 사용하여 user.alias를 설정할 수 있으며, 이렇게 설정된 user alias는 3rd Party Tool(ex. Amplitude, Braze)과 Identity Matching에 사용할 수 있습니다.

12
airbridge.setUserAlias('amplitude_id', '12345678')
airbridge.setUserAlias('braze_ext_id', '87654321')

사용자 속성 설정

setUserAttribute 메소드로 사용자 속성을 설정할 수 있습니다.

123
airbridge.setUserAttribute('age', 45)
airbridge.setUserAttribute('gender', 'male')
airbridge.setUserAttribute('name', 'Gildong Hong')

사용자 설정 확인

사용자 설정을 완료한 후, SDK 를 통해 Event 를 전송하고, 해당 Event 에 설정한 사용자 정보가 있는지 확인해주세요.

  1. 사용자 설정을 해주세요.

  2. SDK 를 통해 Event 를 전송해주세요.

  3. Airbridge 대시보드 > Raw Data > Web Real-time Logs 에서 전송한 Event 를 클릭하여 JSON 속 user 부분에 설정한 사용자 정보가 있는지 확인해주세요.

디바이스 설정

디바이스 식별자 설정

SDK에 디바이스 식별자 정보를 설정해 이후 수집되는 모든 이벤트에 디바이스 식별정보를 포함시킬 수 있습니다. 디바이스 식별자가 설정되면 별도로 삭제하지 않을 경우 웹사이트 종료 여부에 관계없이 계속 유지됩니다.

123
airbridge.setDeviceAlias('YOUR_KEY', 'YOUR_VALUE')
airbridge.removeDeviceAlias('YOUR_KEY')
airbridge.clearDeviceAlias()

메소드

설명

setDeviceAlias(key: string, value: string)

전달한 Key와 Value 쌍을 디바이스 식별자에 추가합니다.

removeDeviceAlias(key: string)

전달한 Key에 해당하는 디바이스 식별자를 삭제합니다. 만약 해당하는 식별자가 없을 경우 아무런 동작을 하지 않습니다.

clearDeviceAlias()

모든 디바이스 식별자를 삭제합니다.

주의하세요

iOS 의 경우 쿠키 최대 저장기간에 따라 최대 7일간만 지속됩니다.

이벤트 설정

사용자의 중요한 행동들이 발생할 때, 이벤트를 전송해 유입 경로별 성과를 측정할 수 있습니다. 모든 이벤트에 첨부되는 모든 정보는 선택적으로 추가할 수 있습니다. 이벤트에 대한 많은 정보는 정확한 통계 제공에 도움이 됨으로 추가하는 것을 권장합니다.

이벤트 전송

이벤트 전송을 위해 category 파라미터는 반드시 존재해야 합니다.

이름

필드명

타입

상세 파라미터 필드명

타입

파라미터 상세설명

send

Category

string

-

-

이벤트 이름 (required)

send

Event Attribute

Object

label

string

이벤트 하위 분류 1

send

Event Attribute

Object

action

string

이벤트 하위 분류 2

send

Event Attribute

Object

value

number

이벤트 값

send

Event Attribute

Object

semanticAttributes

Object

이벤트 시멘틱 정보

send

Event Attribute

Object

customAttributes

Object

이벤트 커스텀 정보

1234567891011
airbridge.events.send('category', {
    label: 'label',
    action: 'action',
    value: 10,
    semanticAttributes: {
        transactionID: 'transaction_123',
    },
    customAttributes: {
        key: 'value',
    }
})

스탠다드 이벤트 전송

홈 화면 조회

카테고리

필드명

타입

파라미터 상세설명

airbridge.ecommerce.home.viewed

-

-

-

1
airbridge.events.send('airbridge.ecommerce.home.viewed')

상품 상세 조회

필드명

타입

상세 파라미터 필드명

타입

파라미터 상세설명

products

Array<Object>

-

-

상품 오브젝트 배열

products

Array<Object>

productID

string

상품 ID

products

Array<Object>

name

string

상품 이름

products

Array<Object>

price

number

상품 가격

products

Array<Object>

currency

string

상품 통화

products

Array<Object>

quantity

number

개수

products

Array<Object>

position

number

위치

1234567891011
airbridge.events.send('airbridge.ecommerce.product.viewed', {
    semanticAttributes: {
        products: [{
            productID: 'coke_zero',
            name: 'Coke Zero',
            price: 1.99,
            currency: 'USD',
            position: 1
        }]
    }
})

상품 리스트 조회

필드명

타입

상세 파라미터 필드명

타입

파라미터 상세설명

productListID

string

-

-

상품리스트 ID

products

Array<Product>

-

-

상품 오브젝트 배열

products

Array<Product>

productID

string

상품 ID

products

Array<Product>

name

string

상품 이름

products

Array<Product>

price

number

상품 가격

products

Array<Product>

currency

string

상품 통화

products

Array<Product>

quantity

number

개수

products

Array<Product>

position

number

상품 포지션

123456789101112131415161718192021
airbridge.events.send('airbridge.ecommerce.productList.viewed', {
    semanticAttributes: {
        productListID: 'food',
        products: [
            {
                productID: 'coke_zero',
                name: 'Coke Zero',
                price: 1.99,
                currency: 'USD',
                position: 1
            },
            {
                productID: 'burger_cheese_double',
                name: 'Double Cheeseburger',
                price: 3.99,
                currency: 'USD',
                position: 2
            }
        ]
    }
})

검색 결과 조회

필드명

타입

상세 파라미터 필드명

타입

파라미터 상세설명

query

string

-

-

검색 Query

products

Array<Product>

-

-

상품 배열

products

Array<Product>

productID

string

상품 ID

products

Array<Product>

name

string

상품 이름

products

Array<Product>

price

number

상품 가격

products

Array<Product>

currency

string

상품 통화

products

Array<Product>

quantity

number

개수

products

Array<Product>

position

number

상품 포지션

123456789101112131415161718192021
airbridge.events.send('airbridge.ecommerce.searchResults.viewed', {
    semanticAttributes: {
        products: [
            {
                productID: 'coke_zero',
                name: 'Coke Zero',
                price: 1.99,
                currency: 'USD',
                position: 1
            },
            {
                productID: 'burger_cheese_double',
                name: 'Double Cheeseburger',
                price: 3.99,
                currency: 'USD',
                position: 2
            }
        ],
        query: 'Search Query'
    }
})

장바구니 담기

필드명

타입

상세 파라미터 필드명

타입

파라미터 상세설명

cartID

string

-

-

상품 장바구니 ID

currency

string

-

-

상품 통화

products

Array<Product>

-

-

상품 배열

products

Array<Product>

productID

string

상품 ID

products

Array<Product>

name

string

상품 이름

products

Array<Product>

price

number

상품 가격

products

Array<Product>

currency

string

상품 통화

products

Array<Product>

quantity

number

상품 수량

products

Array<Product>

position

number

상품 포지션

12345678910111213141516171819202122232425
airbridge.events.send('airbridge.ecommerce.product.addedToCart', {
    value: 13.95,
    semanticAttributes: {
        products: [
            {
                productID: 'coke_zero',
                name: 'Coke Zero',
                price: 1.99,
                currency: 'USD',
                quantity: 3,
                position: 1
            },
            {
                productID: 'burger_cheese_double',
                name: 'Double Cheeseburger',
                price: 3.99,
                currency: 'USD',
                quantity: 2,
                position: 2
            }
        ],
        cartID: '73926365',
        currency: 'USD'
    }
})

결제

필드명

타입

상세 파라미터 필드명

타입

파라미터 상세설명

inAppPurchased

boolean

-

-

인앱 결제 여부

currency

string

-

-

상품 통화

transactionID

string

-

-

거래 ID

products

Array<Product>

-

-

상품 배열

products

Array<Product>

productID

string

상품 ID

products

Array<Product>

name

string

상품 이름

products

Array<Product>

price

number

상품 가격

products

Array<Product>

currency

string

상품 통화

products

Array<Product>

quantity

number

상품 수량

products

Array<Product>

position

number

상품 포지션

1234567891011121314151617181920212223242526
airbridge.events.send('airbridge.ecommerce.order.completed', {
    value: 13.95,
    semanticAttributes: {
        products: [
            {
                productID: 'coke_zero',
                name: 'Coke Zero',
                price: 1.99,
                currency: 'USD',
                quantity: 3,
                position: 1
            },
            {
                productID: 'burger_cheese_double',
                name: 'Double Cheeseburger',
                price: 3.99,
                currency: 'USD',
                quantity: 2,
                position: 2
            }
        ],
        inAppPurchased: true,
        currency: 'USD',
        transactionID: '16874326'
    }
})

회원가입

이름

필드명

타입

파라미터 상세설명

signUp

userID

string

사용자 ID

signUp

userEmail

string

사용자 이메일

signUp

userPhone

string

사용자 이메일

signUp

attributes

object

사용자 속성

1234
airbridge.setUserID('ab180')
airbridge.setUserEmail('user@example.com')

airbridge.events.send('airbridge.user.signup')

로그인

이름

필드명

타입

파라미터 상세설명

signIn

userID

string

사용자 ID

signIn

userEmail

string

사용자 이메일

signIn

userPhone

string

사용자 이메일

signIn

attributes

object

사용자 속성

1234
airbridge.setUserID('ab180')
airbridge.setUserEmail('user@example.com')

airbridge.events.send('airbridge.user.signin')

로그아웃

로그아웃 이벤트가 발생시, 기존에 설정되어있던 유저 정보와 속성은 Clear됩니다.

이름

필드명

타입

파라미터 상세설명

signOut

-

-

-

123
airbridge.events.send('airbridge.user.signout')

airbridge.clearUser()

이벤트 전송 확인

SDK 를 통해 Event 를 전송하고, 에어브릿지 대시보드에 해당 Event 가 존재하는지 확인해주세요.

  1. SDK 를 통해 Event 를 전송해주세요.

  2. Airbridge 대시보드 > Raw Data > Web Real-time Logs 에서 전송한 Event 가 존재하는지 확인해주세요.

웹투앱 설정

앱 다운로드 버튼 설정

기존에 html 로 작성한 버튼 태그들의 id 를 입력하여 버튼을 연결하여 앱 다운로드 기능을 추가하고 해당 성과를 트래킹할 수 있습니다.

12345678910111213141516171819
// html
<button id="app_download">Go to app</button>

// javascript
airbridge.setDownloads({
    buttonID: "app_download",
    // or ["app_download_1", "app_download_2", ...]
    defaultParams: {
        campaign: 'example_campaign',
        medium: 'example_medium',
        term: 'example_term',
        content: 'example_content'
    },
    ctaParams: {
        cta_param_1: '1',
        cta_param_2: '2',
        cta_param_3: '3',
    }
});
  • 필수

    • buttonID: 다운로드 기능을 삽입할 버튼 태그의 id또는 id 들로 이루어진 array

  • 옵션

    • defaultParams: 캠페인 파라미터

    • ctaParams: CTA 캠페인 파라미터

버튼 클릭시, defaultParams 의 데이터로 이벤트를 전송합니다.

주의하세요

사용자를 마켓으로 보내는 역할은 SDK에서 하기 때문에 다운로드 버튼에 앱마켓으로 보내는 <a> tag 나 onclick 함수 등을 사용하면 안됩니다.

앱으로 보기 버튼 설정

html 로 작성한 버튼 태그들의 id 를 입력하여 버튼에 딥링크 기능을 삽입할 수 있습니다. 아래와 같이 딥링크를 설정해 주세요.

123456789101112131415161718192021222324252627
airbridge.setDeeplinks({
    buttonID: "deeplinking-button-1",
    // or ["deeplink-button-1", "deeplink-button-2", ...]
    deeplinks: {
        ios: "example://detail?id=1",
        android: "example://detail?id=1",
        desktop: "https://example.com/detail?id=1"
    },
    fallbacks: {
        ios: "itunes-appstore",
        // itunes-appstore(default), google-play, url
        android: "google-play"
        // google-play(default), itunes-appstore, url
    },
    defaultParams: {
        campaign: 'example_campaign',
        medium: 'example_medium',
        term: 'example_term',
        content: 'example_content'
    },
    ctaParams: {
        cta_param_1: '1',
        cta_param_2: '2',
        cta_param_3: '3',
    },
    desktopPopUp: true
});
  • 필수

    • deeplinks.ios: iOS 에서 앱이 설치된 상태에서 버튼을 클릭했을 때, 실행할 딥링크입니다. (Scheme 딥링크만 입력 가능)

    • deeplinks.android: Android 에서 앱이 설치된 상태에서 버튼을 클릭했을 때, 실행할 딥링크입니다. (Scheme 딥링크만 입력 가능)

    • deeplinks.desktop: Desktop 에서 버튼을 클릭했을 때, 실행할 링크 입니다.

    • fallbacks.ios: iOS 에서 딥링크에 실패하였을 때(앱 미설치 시), 이동할 위치 or URL 입니다.

    • fallbacks.android : Android 에서 딥링크에 실패했을 때(앱 미설치 시), 이동할 위치 or URL 입니다.

      • itunes-appstore : Airbridge에 등록된 앱의 애플 앱스토어 페이지로 이동시킵니다.

      • google-play : Airbridge에 등록된 앱의 안드로이드 플레이스토어 페이지로 이동시킵니다.

      • url : http or https 형식의 URL로 이동시킵니다.

    • buttonID: 딥링크 기능을 삽입할 버튼 태그의 id또는 id 들로 이루어진 array

      입니다.

  • 옵션

    • defaultParams: 캠페인 파라미터

    • ctaParams: CTA 캠페인 파라미터

    • desktopPopUp: true 이면 Desktop 에서 딥링크를 실행했을 때, 새 창에서 작동합니다

주의하세요

사용자를 마켓으로 보내는 역할은 SDK에서 하기 때문에 다운로드 버튼에 앱마켓으로 보내는 <a> tag 나 onclick 함수 등을 사용하면 안됩니다.

앱 중계 페이지로 사용

setDeeplinks 함수를 호출할 때, redirect: true 옵션을 주시면 웹페이지로 접근하는 모든 요청에 딥링크 기능을 수행합니다.

해당 기능을 사용하여 웹에서 앱으로 넘어가기 전에 보이는 중계 페이지(Bridge Page)를 만들 수 있습니다.

123456789101112131415
airbridge.setDeeplinks({
    buttonID: "deeplinking-button-1",
    deeplinks: {
        ios: "example://detail?id=1",
        android: "example://detail?id=1",
        desktop: "https://example.com/detail?id=1"
    },
    fallbacks: {
        // itunes-appstore(default), google-play, url
        ios: "itunes-appstore",
        // google-play(default), itunes-appstore, url
        android: "google-play"
    },
    redirect: true
});
  • redirect: true 이면 모든 요청에 딥링크 기능을 수행합니다.

함수호출로 앱 열기

openDeeplink 함수호출을 통해 앱을 여는 것도 가능합니다.

123456789101112
airbridge.openDeeplink({
    type: "redirect",
    deeplinks: {
        ios: "example://detail?id=1",
        android: "example://detail?id=1",
        desktop: "https://example.com/detail?id=1"
    },
    fallbacks: {
        ios: "itunes-appstore",
        android: "google-play"
    },
});

onclick 에서와 같이 유저의 제스쳐를 통해 실행되는 함수안에서 호출하는 경우 type: "click" 을, 유저의 제스쳐 없이 바로 앱을 여는 경우에는 type: "redirect" 를 사용해주세요.

웹투앱 배너

웹투앱 배너는 웹 사용자에게 앱 설치를 유도하는 배너입니다. 옵션을 통해 배너의 제목과 설명, 버튼의 색깔과 텍스트 등을 변경할 수 있습니다.

코드 예시

옵션을 통해 배너의 제목과 설명, 버튼의 텍스트와 색상, 동작 방식 등을 설정할 수 있습니다.

웹 이동

1234567891011
airbridge.openBanner({
    title: 'AB180 블로그',
    description: '최신 마테크 정보를 실시간으로 받아볼 수 있습니다.',
    buttonText: '설치',
    color: '#0a69ff',
    position: 'top',
    destination: {
        type: 'web',
        url: 'https://blog.ab180.co'
    }
})

스토어 이동

123456789101112131415161718192021
airbridge.openBanner({
    title: 'AB180 블로그',
    description: '최신 마테크 정보를 실시간으로 받아볼 수 있습니다.',
    buttonText: '설치',
    color: '#0a69ff',
    position: 'top',
    destination: {
        type: 'download',
        defaultParams: {
            campaign: 'example_campaign',
            medium: 'example_medium',
            term: 'example_term',
            content: 'example_content'
        },
        ctaParams: {
            cta_param_1: '1',
            cta_param_2: '2',
            cta_param_3: '3',
        }
    }
})

딥링크 이동

123456789101112131415161718192021222324252627282930
airbridge.openBanner({
    title: 'AB180 블로그',
    description: '최신 마테크 정보를 실시간으로 받아볼 수 있습니다.',
    buttonText: '설치',
    color: '#0a69ff',
    position: 'top',
    destination: {
        type: 'deeplink',
        deeplinks: {
            ios: "example://detail?id=1",
            android: "example://detail?id=1",
            desktop: "https://example.com/detail?id=1"
        },
        fallbacks: {
            ios: "itunes-appstore",
            android: "google-play"
        },
        defaultParams: {
            campaign: 'example_campaign',
            medium: 'example_medium',
            term: 'example_term',
            content: 'example_content'
        },
        ctaParams: {
            cta_param_1: '1',
            cta_param_2: '2',
            cta_param_3: '3',
        }
    }
})

옵션 설명 - 공통

이름

설명

필수

기본값

title

배너 제목입니다.

O

description

배너 설명입니다.

O

buttonText

배너의 앱 다운로드 유도 버튼에 입력할 텍스트입니다.

O

color

배너의 앱 다운로드 유도 버튼에 설정할 색상입니다.

X

#0082FF

position

배너의 위치입니다.

- top을 선택하면 배너가 화면 위에 위치합니다.

- bottom을 선택하면 배너가 화면 아래에 위치합니다.

X

top

destination

배너의 앱 다운로드 유도 버튼이 동작하는 방식입니다. type에 따라 동작 방식이 다릅니다.

O

styles

배너의 설정할 커스텀 스타일입니다.

X

옵션 설명 - destination (웹 이동)

이름

설명

필수

destination.type

web입니다. 변경할 수 없습니다.

O

destination.url

유저를 이동시킬 URL을 입력합니다.

O

옵션 설명 - destination (스토어 이동)

이름

설명

필수

destination.type

download입니다. 변경할 수 없습니다.

O

destination.defaultParams

캠페인 파라미터입니다.

X

destination.ctaParams

CTA 캠페인 파라미터입니다.

X

옵션 설명 - destination (딥링크 이동)

이름

설명

필수

destination.type

deeplink입니다. 변경할 수 없습니다.

O

destination.deeplinks

딥링크 설정입니다.
자세한 내용은 딥링크 설정 가이드를 참고해 주세요.

X

destination.fallbacks

딥링크 폴백 설정입니다.
자세한 내용은 딥링크 설정 가이드를 참고해 주세요.

X

destination.defaultParams

캠페인 파라미터입니다.

X

destination.ctaParams

CTA 캠페인 파라미터입니다.

X

에어브릿지는 아래와 같은 기본 기능을 제공합니다.

고급 설정

캠페인 파라미터 설정

광고를 통해 웹사이트에 랜딩되는 경우에 웹사이트 주소에 파라미터로 정보를 붙여주시면 그 정보를 토대로 웹사이트 유입 트래킹이 가능합니다. 파라미터 분석은 자동 기능과 수동 기능을 지원합니다.

자동 기능 - utmParsing

init 함수 호출시 utmParsing: true 옵션을 주시면 URL 파라미터의 UTM 값을 각각 Airbridge 캠페인 파라미터 값으로 자동 설정되어, Actual Report 등에서 확인할 수 있습니다.

URL 파라미터

Airbridge Campaign Parameter

utm_source

Channel (channel)

utm_campaign

Campaign (campaign)

utm_medium

Sub Publisher (sub_id)

utm_term

Term (term)

utm_content

Content (content)

utm_source 파라미터는 필수입니다. utm_source가 없으면, 다른 utm 파라미터들도 파싱되지 않습니다.

123456
airbridge.init({
    app: 'YOUR_APP_NAME',
    webToken: 'YOUR_WEB_TOKEN',
    // ...
    utmParsing: true,
})

URL 은 window.location.href 값 입니다.

자동 기능 - utmParameterValueReplaceMap

utmParameterValueReplaceMap을 설정하면 utmParsing으로 수집한 UTM 파라미터 값을 원하는 값으로 지정할 수 있습니다. utmParameterValueReplaceMap을 지원하는 파라미터는 utm_source, utm_campaign, utm_medium, utm_term, utm_content입니다.

utmParameterValueReplaceMap로 여러 솔루션을 통해 수집하는 UTM 파라미터를 같은 값으로 설정해 웹에서 발생하는 성과를 에어브릿지에서 원하는 대로 분석할 수 있습니다.

예를 들어 utm_source=blog로 설정하면 에어브릿지는 UTM 파라미터가 발생한 채널(channel)을 blog로 수집합니다. utmParameterValueReplaceMap를 활용하면 blog 대신 my_blog처럼 원하는 값으로 수집되도록 설정할 수 있습니다.

1234567891011
airbridge.init({
    app: 'YOUR_APP_NAME',
    webToken: 'YOUR_WEB_TOKEN',
    // ...
    utmParsing: true,
    utmParameterValueReplaceMap: {
        utm_source: {
            blog: 'my_blog',
        },
    },
})

자동 기능 - urlQueryMapping

urlQueryMapping을 사용하면, 다른 파라미터들도 커스텀하게 캠페인 파라미터로 매핑하여 통계를 확인할 수 있습니다. airbridge.init 메서드 호출 시, urlQueryMapping 옵션에 Key(에어브릿지 파라미터)-Value(맵핑을 원하는 Key) 쌍으로 값을 넣어줄 수 있으며, 에어브릿지 파라미터로 사용할 수 있는 Key는 아래와 같습니다.

파라미터명

설명

channel (필수)

채널

campaign

캠페인

ad_group

광고 그룹

ad_creative

광고 소재

content

콘텐츠

term

키워드

sub_id

하위매체

sub_id_1

하하위매체1

sub_id_2

하하위매체2

sub_id_3

하하위매체3

campaign_id

캠페인 ID

ad_group_id

광고 그룹 ID

ad_creative_id

광고 소재 ID

term_id

키워드 ID

예를 들어 고객사 내부에서 활용하는 파라미터가 'internal_code'라고 했을 때 랜딩 페이지의 URL은 아래와 같이 구성될 것입니다.

  • https://mybrand.com/?utm_source=google&utm_campaign=jan_ua_campaign&internal_code=ABC

이때 utm_source, utm_campaign과 함께 internal_code를 에어브릿지에서 지원하는 파라미터 중 하하위매체1과 맵핑시켜 대시보드에서 성과를 확인하고자 할 경우 아래와 같이 설정해주시면 됩니다.

12345678910
airbridge.init({
    app: 'YOUR_APP_NAME',
    webToken: 'YOUR_WEB_TOKEN',
    // ...
    urlQueryMapping: {
        channel: 'utm_source',
        campaign: 'utm_campaign', 
        sub_id_1: 'internal_code',
    },
})

만약 위 랜딩페이지에서 전환이벤트(장바구니 담기, 구매)가 발생할 경우 에어브릿지 대시보드 내 [Actual Report] > [테이블 설정]에서 '하하위매체1'을 통계 기준으로 설정하여 internal_code의 값을 기준으로 성과를 확인하실 수 있습니다.

알립니다

URLQueryMapping 기능을 설정할 때, channel은 필수적으로 설정해주셔야 합니다. 설정하지 않으시면 기능이 동작하지 않습니다.

수동 기능

아래와 같은 코드를 작성하여 파라미터를 분석할 수 있습니다.

분석 결과물인 params 객체에서 적절한 정보를 추출하여 init 함수 호출시에 정보를 등록해주세요.

12345678910111213141516171819202122232425262728293031323334
function queryStringToJSON(url) {
    url = url || ''
    var index = url.indexOf('?')
    if (index < 0) {
        index = url.length - 1
    }
    var pairs = url.slice(index + 1).split('&')
    var object = {}
    pairs.forEach(function (string) {
        if (string.length === 0) {
            return
        }
        var pair = string.split('=')
        object[pair[0]] = decodeURIComponent(pair[1] || '')
    })
    return object
}

var url = window.location.href
var params = queryStringToJSON(url)

// initialize
airbridge.init({
    app: 'YOUR_APP_NAME',
    webToken: 'YOUR_WEB_TOKEN',
    // ...
    defaultChannel: params['utm_source'],
    defaultParams: {
        campaign: params['utm_campaign'],
        medium: params['utm_medium'],
        content: params['utm_content'],
        term: params['utm_term'],
    },
})
  • defaultChannel: 웹페이지에서 발생하는 모든 이벤트에 기록 될 매체 이름

  • defaultParams.campaign: 웹페이지에서 발생하는 모든 이벤트에 기록 될 광고 이름

  • defaultParams.medium: 웹페이지에서 발생하는 모든 이벤트에 기록 될 광고 매체

  • defaultParams.content: 웹페이지에서 발생하는 모든 이벤트에 기록 될 광고 내용

  • defaultParams.term: 웹페이지에서 발생하는 모든 이벤트에 기록 될 광고 검색어

사용자 정보 제거

clearUser 메소드를 사용하여, 기존에 설정하였던 사용자 ID, Email, Phone, Alias, Attributes를 제거할 수 있습니다.

1
airbridge.clearUser()

사용자 정보 암호화

user.externalUserEmailuser.externalUserPhone 정보를 Client Level에서 Hash (SHA256) 화 하여 전송합니다. user.externalUserID는 hash 옵션에 적용을 받지 않으므로, hash가 필요한 경우 직접 hash하여 값을 넣어주시기 바랍니다.

123456
airbridge.init({
    app: 'YOUR_APP_NAME',
    webToken: 'YOUR_WEB_TOKEN',
    // ...
    userHash: true, // Default false
})

이벤트 전송 대기 Callback

이벤트가 완전히 전송완료 되기전에 다른 페이지로 redirect 되면(ex. 중계페이지에서 이벤트를 전송하는 경우), 이벤트가 유실 될 수 있습니다. 이 경우 events.wait 을 사용하면 모든 이벤트가 완전히 전송완료 될 때까지 대기할 수 있습니다.

events.wait 메서드

파라미터

타입

파라미터 상세설명

timeout

number

최대 대기시간 (milliseconds)

callback

(error: string) => void

이벤트 전송완료 Callback

1234567891011
airbridge.init({
    app: 'YOUR_APP_NAME',
    webToken: 'YOUR_WEB_TOKEN',
    // ...
})

airbridge.events.send('category')

airbridge.events.wait(3000, function (error) {
    location.href = 'url'
})

어트리뷰션 윈도우 수정 옵션

쿠키 윈도우 수정을 통해 어트리뷰션 윈도우를 수정할 수 있습니다.

123456789101112131415
// Set attribution window to 1 day
airbridge.init({
    app: 'YOUR_APP_NAME',
    webToken: 'YOUR_WEB_TOKEN',
    // ...
    cookieWindow: 1,
})

// Set attribution window to 720 minutes (12 hours)
airbridge.init({
    app: 'YOUR_APP_NAME',
    webToken: 'YOUR_WEB_TOKEN',
    // ...
    cookieWindowInMinutes: 720,
})

만약 cookieWindow 옵션과 cookieWindowInMinutes 옵션 값을 둘 다 설정하면, cookieWindowInMinutes 값을 우선하여 적용합니다.

Subdomain 쿠키 공유 옵션

사용자 추적은 브라우저 쿠키를 통해 이루어지고, 이 정보는 subdomain 간에 공유됩니다.

init 함수 호출시 shareCookieSubdomain: false 옵션을 주시면 subdomain 간 정보공유를 중지합니다.

1234567
// initialize 
airbridge.init({ 
    app: 'YOUR_APP_NAME',
    webToken: 'YOUR_WEB_TOKEN',
    // ...
    shareCookieSubdomain: false,
})

shareCookieSubdomain 의 기본값은 true 입니다.

  • 여러개의 subdomain 들에서 하나의 서비스를 운영하시는 경우, true설정을 권장합니다.

  • 여러개의 subdomain 들에서 서로 다른 서비스를 운영하시는 경우, false설정을 권장합니다.

예시

캠페인 A 트래킹링크 -> https://mybrand.com -> https://shop.mybrand.com 로 접속한 경우,

  • shareCookieSubdomain: true 인 경우

    • https://mybrand.com에서 발생한 이벤트 → 캠페인 A에 기여

    • https://shop.mybrand.com에서 발생한 이벤트 → 캠페인 A에 기여

  • shareCookieSubdomain: false 인 경우

    • https://mybrand.com에서 발생한 이벤트 → 캠페인 A에 기여

    • http://shop.mybrand.com에서 발생한 이벤트 → 기본 설정값에 기여

옵트인(Opt-In) 설정하기

알립니다

필수 설정 기능이 아닙니다. 필요한 기능인지 확인한 후에 설정해 주세요.

옵트인(Opt-In)은 유저가 동의하기 전에 유저 정보를 사용하지 않는 정책입니다.

autoStartTrackingEnabled 설정을 false 로 설정한 후에 이벤트를 수집할 수 있는 시점에 startTracking 함수를 호출합니다. startTracking 함수가 호출된 시점부터 이벤트를 수집합니다.

12345678
airbridge.init({
    app: 'YOUR_APP_NAME',
    webToken: 'YOUR_WEB_TOKEN',
    // ...
    autoStartTrackingEnabled: false,
})

airbridge.startTracking()

autoStartTrackingEnabled 의 기본값은 true 입니다.

옵트아웃(Opt-Out) 설정하기

알립니다

필수 설정 기능이 아닙니다. 필요한 기능인지 확인한 후에 설정해 주세요.

옵트아웃(Opt-Out)은 유저가 거부하기 전에 유저 정보를 사용하는 정책입니다.

autoStartTrackingEnabled 설정을 true 로 설정한 후에 이벤트를 수집할 수 없는 시점에 stopTracking 함수를 호출합니다. stopTracking 함수가 호출된 시점부터 이벤트를 수집하지 않습니다.

12345678
airbridge.init({
	app: 'YOUR_APP_NAME',
	webToken: 'YOUR_WEB_TOKEN',
	// ...
	autoStartTrackingEnabled: true,
})

airbridge.stopTracking()

웹투앱 어트리뷰션의 기여 기간 설정하기

주의하세요

CTA 버튼에 트래킹 링크를 적용하면 setDeeplinks 기능을 활용할 수 없습니다. setDeeplinks 기능을 통해 광고 채널의 성과를 측정한다면 CTA 버튼에 트래킹 링크를 적용하지 말아야 합니다.

‘앱으로 보기’ 같은 CTA(Call to action) 버튼에 setDeeplinks 기능을 활용하면 웹투앱 어트리뷰션의 기여 기간을 프로텍티드 어트리뷰션 윈도우(Protected Attribution Window, PAW)로 설정할 수 있습니다. PAW는 웹 사이트 실행 시점을 기준으로 에어브릿지 웹 SDK가 수집한 터치포인트를 어트리뷰션 분석 대상에서 제외하는 기간입니다. PAW를 설정한 어트리뷰션 시나리오는 에어브릿지 가이드를 참고해 주세요.

PAW 기본 설정은 30분입니다. PAW 설정을 변경하고 싶다면 에어브릿지 웹 SDK의 airbridge.init()에서 useProtectedAttributionWindowtrue로 설정해 주세요. 그리고 protectedAttributionWindowInMinutes에 PAW로 설정하는 기간을 입력합니다. 단위는 분입니다. 최대 설정 기간 3일(4320분)입니다.

PAW를 사용하지 않는다면 에어브릿지 웹 SDK의 airbridge.init()에서 useProtectedAttributionWindow을 false로 설정해 주세요.

1234567
airbridge.init({
    app: 'YOUR_APP_NAME',
    webToken: 'YOUR_WEB_TOKEN',
    // ...
    useProtectedAttributionWindow: true,
    protectedAttributionWindowInMinutes: 60,
});

CTA 파라미터 추적

위에서 설명한 Protected Attribution Window에 의해 기여되는 터치포인트에 Web에서 특정 CTA 버튼을 통해서 이동했다는 추가 파라미터를 부여할 수 있습니다.

위에서 'airbridge.setDeeplinks'가 적용된 앱으로 보기 버튼 설정시에 ctaParams 를 추가해주시면 해당 파라미터들이 추가로 부여됩니다.

#{"style": { "minWidth":"240px" }}

상황

#{"style": { "minWidth":"160px" }}

기본 기여 채널

Protected Attribution Window 사용시 기여 채널

Protected Attribution Window 사용시 기여 파라미터

1. 매체 클릭

naver.searchad

naver.searchad

{ keyword: 'app' }

2. 웹 오픈

naver.searchad

naver.searchad

{ keyword: 'app' }

3. 앱으로보기 버튼 클릭 (airbridge.setDeeplinks 사용)

airbridge.websdk

airbridge.websdk

{ cta_param_1: 'page1' }

4. 앱 딥링크 오픈

airbridge.websdk

naver.searchad

{ keyword: 'app', cta_param_1: 'page1' }

ctaParams 에는 아래 3가지 key 값만 허용됩니다.

  • cta_param_1

  • cta_param_2

  • cta_param_3

웹사이트 이동 트래킹

사용자를 다른 도메인의 웹사이트로 이동시키고자 할때 sendWeb 메소드를 사용할 수 있습니다. 이동한 웹사이트에도 Airbridge Web SDK가 설치되어있다면 사용자 Journey를 연결하여 Attribution 성과를 분석할 수 있습니다.

Attribution 연결을 위해 sendWeb을 호출하는 웹사이트에서 Web SDK init시 프로텍티드 어트리뷰션 윈도우(Protected Attribution Window, PAW) 설정이 필요할 수 있습니다. PAW에 대한 자세한 내용은 에어브릿지 가이드를 확인해 주세요.

1234567
// 현재 창에서 웹사이트 이동
airbridge.sendWeb("https://blog.ab180.co")

// 새 창을 열어 웹사이트 이동
airbridge.sendWeb("https://blog.ab180.co", function(err, res) {
  window.open(res.targetUrl)
})

Google Tag Manager를 이용한 SDK 설치

Google Tag Manager 를 통해 SDK 를 활용합니다.

설치와 이벤트 추적에 관련된 설명은 설치 항목이벤트 항목 을 참고해주세요.

SDK 설치

아래와 같은 단계를 거쳐 Google Tag Manager를 활용한 SDK 설치를 하실 수 있습니다.

  1. '작업공간 개요'에서 새 태그를 클릭합니다. 또는 컨테이너에 태그 > 새로 만들기를 선택합니다.

  2. '태그 구성'을 클릭하고, '맞춤설정'의 '맞춤 HTML'을 선택합니다.

  3. 아래 사진과 같이 'HTML' 부분에 설치 코드를 작성해 주세요.

  4. init 함수는 이벤트 함수보다 먼저 실행되어야 하기 때문에, '태그 구성'의 '고급 설정'에서 '태그 실행 우선순위'을 선택하여 0보다 큰 숫자(예:9999)를 입력해 줍니다.

  5. '태그 구성'의 '고급 설정'에서 '태그 실행 옵션'을 선택하여 '페이지당 한 번'을 선택해 줍니다.

  6. '트리거'를 클릭하고 '페이지뷰 - DOM 사용 가능(Pageview - DOM Ready)' 유형의 트리거를 선택합니다.

  7. 태그 생성을 완료하고 제출 버튼을 누릅니다.

  8. 대시보드에서 WEB SDK 로그가 기록되는지 확인합니다.

이벤트 추적

아래와 같은 단계를 거쳐 Google Tag Manager를 활용한 이벤트 추적을 하실 수 있습니다.

  1. '작업공간 개요'에서 새 태그를 클릭합니다. 또는 컨테이너에 태그 > 새로 만들기를 선택합니다.

  2. '태그 구성'을 클릭하고, '맞춤설정'의 '맞춤 HTML'을 선택합니다.

  3. 아래 사진과 같이 'HTML' 부분에 이벤트 추적 스크립트를 작성해 주세요.

  4. '고급 설정'의 '태그 실행 옵션'에서 이벤트가 발생하는 상황에 따라 '무제한', '이벤트당 한 번' 또는 '페이지당 한 번'을 선택할 수 있습니다.

  5. 트리거를 이벤트에 맞게 설정해주세요.

  6. 태그 생성을 완료하고 제출 버튼을 누릅니다.

  7. 대시보드에서 WEB SDK 로그가 기록되는지 확인합니다.

앱 데이터 저장 공간 분리

에어브릿지 웹 SDK는 기본적으로 도메인 1개당 앱 1개의 어트리뷰션 데이터만 저장할 수 있도록 설계됐습니다. useStoragePerApp 옵션을 사용하면, 저장 공간을 분리하여 같은 루트 도메인을 공유하는 서브 도메인에서 사용 중인 여러 앱의 어트리뷰션 데이터를 앱별로 확인할 수 있습니다.

예를 들어 example.com의 루트 도메인을 공유하는 서브 도메인 a.example.comb.example.com에서 여러 앱을 사용할 경우, 데이터 저장 공간을 분리할 수 있습니다.

123456789101112131415
// 서브 도메인 #1: a.example.com
airbridge.init({
    app: 'YOUR_APP_NAME',
    webToken: 'YOUR_WEB_TOKEN',
    // ...
    useStoragePerApp: true,
})

// 서브 도메인 #2: b.example.com
airbridge.init({
    app: 'YOUR_ANOTHER_APP_NAME',
    webToken: 'YOUR_ANOTHER_WEB_TOKEN',
    // ...
    useStoragePerApp: true,
})

useStoragePerApp 의 기본값은 false 입니다.

주의하세요

useStoragePerApp 옵션을 변경하면 변경 직후에 유저가 사용하는 각 브라우저에서 발생한 첫 번째 이벤트가 미기여(unattributed)로 처리될 수 있습니다.

도움이 되었나요?

더 필요한 내용이 있나요?