ゲームキーの販売をセットアップする

ゲームキーの直接販売は、ゲームのウェブサイト上でゲームキーを実際通貨または仮想通貨で販売することで、ゲームの収益化を実現します。

ゲームキーは、ダイレクトリンクストアUIウィジェット経由で販売することができます。

アイテム販売方法
ゲームのコピー1つ(ゲームキー)。ダイレクトリンクウィジェット、またはストアインターフェイス。ストアインターフェースで販売する場合は、カートを作成せずにクイック購入の方法をご利用ください。
ゲームのコピー(ゲームキー)が数本、またはカートにゲームが数本入っています。ストアインターフェースサイトビルダーを使用するか、インゲームストア & ゲームキーの直接販売 APIを統合してください。

認証済みのユーザーと認証されていないユーザーにゲームキーを販売できます。

認証により次のことが可能になります:

ログイン製品または独自の認証システムを使用してユーザーを認証できます。詳細な設定情報は、この説明に記載されています。

お知らせ
ユーザーはキーを返金することができます。返金が成功した後、エクソーラメールで影響を受けるキーのリストが届きます。サードパーティのプラットフォーム上では、これらのキーへのアクセスをブロックすることをお勧めします。

以下のリンクは決済UIを開きます:

Copy
Full screen
Small screen
https://purchase.xsolla.com/pages/buy?type={YOUR-ITEM-TYPE}&project_id={YOUR_PROJECT_ID}&sku={YOUR-ITEM-SKU}
お知らせ

ゲームキーの購入は、エクソーラとライセンス契約を締結した後、直接リンクして実際の通貨で購入することが可能です。これを行うには、アドミンページでの「契約&納税 > 契約」セクションに移動し、契約書フォームに記入し、確認を待ちます。契約書の確認には、最大で3営業日かかる場合があります。

決済をテストするには、リンクにmode=sandboxパラメータを追加して、テスト環境を使用することができます。

このリンクに次のデータを追加します:

  • YOUR-ITEM-TYPE — アイテムの種類:
    • game — ゲーム;game_key — 特定のプラットフォームのゲーム。
    • bundle — バンドル。
  • YOUR-PROJECT-IDアドミンページプロジェクト設定 > 一般設定 > ロジェクトIDセクションからのプロジェクトのID。
  • YOUR-ITEM-SKU — ゲームキーパッケージSKU。特定のプラットフォームでゲームを販売するには、ゲームリストを取得する(通常このSKUはunit_name_drm_skuのようなこと)を使ってSKUを取得します。

  • 決済UIスタイル:テーマ(ダークまたはデフォルトのライトテーマ)、サイズ、およびその他のパラメータ。URLでui_settingsパラメーターを指定し、値としてBase64エンコードを持つsettings.uiJSON-objectを渡します。UI設定を含むURLの例:
Copy
Full screen
Small screen
https://purchase.xsolla.com/pages/buy?type={YOUR-ITEM-TYPE}&project_id={YOUR_PROJECT_ID}&sku={YOUR-ITEM-SKU}&ui_settings=ewoJCQkic2l6ZSI6ICJzbWFsbCIsCgkJCSJ0aGVtZSI6ICJkYXJrIgoJCX0=
  • ユーザーデータを受け渡すためのトークン。認証されたユーザーのみにゲームキーを販売する際に使用します。このトークンは認証メソッドに依存します。トークンを含むURLの例:
Copy
Full screen
Small screen
https://purchase.xsolla.com/pages/buy?type={YOUR-ITEM-TYPE}&project_id={YOUR_PROJECT_ID}&sku={YOUR_ITEM_SKU}&xsolla_login_token={ACCESS_TOKEN}
  • 決済テストのmode=sandboxパラメータ。テスト銀行カードを使用して、決済を完了することができます。
お知らせ
決済を行う際、エクソーラサーバーはウェブフックURLにリクエストを送信し、ユーザーがゲーム内に存在することを確認します。決済テスト時にエラーが発生しないように、アドミンページ > プロジェクト設定 > ウェブフックでスイッチをオフにしてください。ウェブフックを使用する場合は、ユーザー検証ウェブフックの正常な処理を実装してください。
  1. テスト用URLの例:
Copy
Full screen
Small screen
https://purchase.xsolla.com/pages/buy?type={YOUR-ITEM-TYPE}&project_id={YOUR_PROJECT_ID}&sku={YOUR-ITEM-SKU}&mode=sandbox

ストアUI経由の販売

ゲームキーの販売は、ストアのインターフェイスから行うことができます。ストアを作成するには:

ゲームキーパッケージを販売するには、インゲームストア & ゲームキーの直接販売 APIを使用します:

  1. カタログを表示するには、ゲームリストを取得するメソッドを使用します。
  2. ゲームキーの購入を実装します:

メソッドが正しく機能するように、適切な認証オプションを選択してください。
お知らせ
インゲームストア& ゲームキーの直接販売 APIを通じてゲームを販売する場合、プレーヤーがクライアントで特定のプラットフォームを選択できるようにする機能を実装する必要があります。SKUを取得するには、ゲームのリストを取得するリクエストからitems.unit_items.skuパラメータの値を渡します。

ウィジェット経由の販売

ページにウィジェットを追加してゲームキーを販売し、カスタマイズすることができます。ウィジェットコードをコピーするには、パブリッシャーアカウントでキーパッケージを作成した後、「ウィジェットカスタマイズ」セクションに移動します。

ゲームが単一のプラットフォームで販売されている場合、ウィジェットにはそのプラットフォームに固有のゲーム価格が表示されます。

例:今なら$10でご購入いただけます。

ゲームが複数のプラットフォームで販売されている場合、ウィジェットにはプラットフォーム間の最低価格が表示されます。

例:$10からご購入いただけます。

注文作成ウィンドウでは、ユーザーはすべてのプラットフォームの価格を確認して選択できます。

drmパラメータでプラットフォームSKUを指定することで、ウィジェットに特定のプラットフォームの価格を表示することもできます。

ウィジェットコード例:

Copy
Full screen
Small screen
    <div id="xsolla-buy-button-widget"></div>
          <script>
              var options = {
                  project_id: "101010",
                  sku: "my_key",
                  user: {
                      auth: "9qs9VyCIQQXBlzJQcfETIKWZDvhi4Sz1"
                  },
                  drm: "steam",
                  item_type: "unit",
                  api_settings: {
                      sandbox: true,
                  },
                  widget_ui: {
                      target_element: "#xsolla-buy-button-widget",
                      theme: {
                          foreground: "green",
                          background: "light"
                      },
                  },
    
                 payment_widget_ui: {
                      lightbox: {
                          height: '700px',
                          spinner: 'round'
                      }
                }
              };
              var s = document.createElement('script');
              s.type = "text/javascript";
              s.async = true;
              s.src = "https://cdn.xsolla.net/embed/buy-button/3.1.8/widget.min.js";
              s.addEventListener('load', function (e) {
                  var widgetInstance = XBuyButtonWidget.create(options);
              }, false);
              var head = document.getElementsByTagName('head')[0];
              head.appendChild(s);
          </script>
          <style>
              #xsolla-buy-button-widget {
    
              /* place code for button positioning here */
                margin: 10px  
              }
    
              /* Styles the button itself */
              .x-buy-button-widget.x-buy-button-widget__tiny
                .x-buy-button-widget-payment-button {
                background-color: #ff005b;
                color: black;
              }     
          </style>
    
    お知らせ
    ウィジェットパラメータ

    パラメータ種類説明文
    project_id
    | integer | ゲームキーまたはゲームキー付きバンドル、ゲーム内アイテムまたはアイテム付きバンドルがアップロードされるプロジェクトのID。
    item_type
    | array | アイテムタイプ。virtual_goodvirtual_currencygame_keyunitの値を取ることができます。unitタイプは、ゲームを配信するプラットフォームが複数ある場合に使用されます。
    sku
    | string | 固有アイテムID。
    drm
    | string | 配信プラットフォームSKU(steamなど)。特定のプラットフォームの価格を表示できます。
    api_settings
    | string | 環境とホストの構成設定:
    • host — リクエストを実行するためのホスト。デフォルト値は — store.xsolla.com
    • api_host — APIリクエストを実行するためのホスト。デフォルト値は — store.xsolla.com/api
    • sandboxtrueの値を設定し、決済プロセスをテストします。sandbox-secure.xsolla.comは、支払いの処理にsecure.xsolla.comの代わりに使用されます(決済プロセスのテストを参照してください)
    user
    | array | ユーザーデータを含む配列。
    user.auth
    | string | ユーザー認証トークン:JSONウェブトークンまたはペイステーションアクセストークン
    user.locale
    | string | ユーザーのロケール。ボタンのテキストと決済インターフェイスの言語を決定します。ISO_639-1に基づいた2文字の言語コードが使用されます。
    widget_ui.theme
    | object | ウィジェットの外観を決定するカラーテーマ。{foreground:[‘blue’,‘red’,‘green’,‘gold’], background:[’light’,‘dark’]}の値を取ることができます。
    widget_ui.template
    | string | テンプレート。可能な値:
    • standard(デフォルト) — ゲーム画像、タイトル、スタイライズされたボタンが含まれます
    • simple — スタイルが適用されていないボタンだけが表示されます
    widget_ui.target_element
    | string | ウィジェットがレンダリングされるべきページの要素(jQueryセレクタが使用されるべきである。例えば、#widget-example)。必須

    決済インターフェイスの外観を決定するパラメータ

    パラメータ種類説明文
    payment_ui
    | object | 決済インターフェースの外観パラメータ。
    payment_widget_ui
    | object | 決済インターフェースの外観を決定するパラメータを持つオブジェクト。
    payment_widget_ui.lightbox
    | object | 決済インターフェイスが開かれるモーダルウィンドウのオプションを持つオブジェクト。
    lightbox.width
    | string | ライトボックスのフレームの高さ。nullの場合、ペイステーションの高さに依存します。既定はnullです。
    lightbox.height
    | string | ライトボックスのフレームの高さ。nullの場合、ペイステーションの高さに依存します。既定は100%です。
    lightbox.zIndex
    | integer | 配置順序を定義します。既定は1000です。
    lightbox.overlayOpacity
    | integer | ウィジェットの背景の不透明度(0 — 完全透明、1 — 完全不透明)。デフォルト値は60%です(.6)。
    lightbox.overlayBackground
    | string | オーバーレイの背景色。既定は#000000
    lightbox.contentBackground
    | string | フレームの背景色。デフォルトは#ffffff。これらの色の変更は、ペイステーションiframe自体には影響を与えず、それを保持するライトボックスの設定のみに影響を与えることに注意してください。
    lightbox.spinner
    | string | ローディングアニメーションのインジケータの種類。xsollaまたはroundに指定できます。既定はxsollaです。
    lightbox.spinnerColor
    | string | スピナーの色。既定値はありません。
    payment_widget_ui.childWindow
    | object | 決済インターフェイスが開かれる子ウィンドウの設定。モバイル版で動作します。
    payment_widget_ui.childWindow.target
    | string | 子ウィンドウを開く場所を決定する属性。_blank_self_parentの値を取ることができます。デフォルト値は — _blank

    ウィジェットメソッド

    • var widgetInstance = XBuyButtonWidget.create(options) — ウィジェットインスタンスを作成し、ページ上にレンダリングします。
    • widgetInstance.on(event, handler) — イベントのイベントハンドラー関数をウィジェットにアタッチします。
      • event (string) — イベントタイプ。
      • handler (function) — イベントがトリガーされたときに実行する関数。
    • widgetInstance.off(event, handler) — イベントハンドラーを削除します。
      • event (string) — イベントタイプ。
      • handler (function) — イベントに以前にアタッチされたハンドラー関数。

    イベントの一覧:

    パラメータ説明文
    initウィジェットが初期化されました。
    openウィジェットが開かれました。
    load決済インターフェース(ペイステーション)が読み込まれました。
    close決済インターフェース(ペイステーション)が閉じられています。
    statusユーザーはステータスページにいます。
    status-invoiceユーザーはステータスページにいます。支払いが進行中です。
    status-deliveringユーザーはステータスページにいます。支払いが完了しました。支払い通知が送信されました。
    status-doneユーザーはステータスページにいます。支払いはユーザーのアカウントに振り込まれます。
    status-troubledユーザーはステータスページにいます。支払いに失敗しました。

    XBuyButtonWidget.eventTypesオブジェクトを使用してイベントのリストにアクセスできます。

    ボタンカスタマイズ

    1. パブリッシャーアカウントであなたのプロジェクトを開きます。
    2. サイドメニューで「、ストア」をクリックします。
    3. ゲームキー」ペインで、「構成する」をクリックします。
    4. ゲームキーを選択し、「ウィジェットカスタマイズ」タブに移動します。
    お知らせ
    ゲームキーがない場合は、新規に作成してください
    1. カスタマイズ」ブロックで、背景色を選択します。
    お知らせ
    また、コード内でthemeオブジェクトを修正し、パラメータbackgroundに空文字列を値として持たせることもできます。
    1. ウィジェットコードをページに追加すると、ウィジェットには継承されたスタイルが含まれます。これらのスタイルを上書きするために、以下のスタイルを追加してください。
    注意
    CSSの継承/優先順位の理由から、ウィジェットカスタマイズタブで取得したscriptタグの下にstyleタグでこれらを追加しました。
    Copy
    Full screen
    Small screen
    /* This should be used for button positioning but note this technically repositions the entire widget */
    #xsolla-buy-button-widget {
      /* place code for button positioning here */
    }
    
    /* Styles the button itself */
    .x-buy-button-widget.x-buy-button-widget__tiny
      .x-buy-button-widget-payment-button {
      background-color: #ff005b;
      color: black;
    }
    
    /* Button on hover */
    .x-buy-button-widget.x-buy-button-widget__tiny
      .x-buy-button-widget-payment-button:hover {
      background-color: #ff005b;
    }
    
    /* The following are style overrides to leave you with just the button */
    
    /* space immediately surrounding button */
    .x-buy-button-widget-button-block.x-buy-button-widget-button-block__light {
      background-color: white;
    }
    
    /* space above button (including game title area) */
    .x-buy-button-widget.x-buy-button-widget__tiny
      .x-buy-button-widget-game-logo {
      height: 200px;
      background-image: none !important;
      background-color: white;
    }
    
     /* Game title (located right above button) */
    .x-buy-button-widget-game-name.x-buy-button-widget-game-name__light {
      display: none !important;
    }
    
    注意
    • 上記のid/class名とコードスニペットは、コピーしたウィジェットのコード(ステップ5の画像)と組み合わせて使用します。このため、コピーしたウィジェットコードを実装することが重要です。
    • 上記のコードをそのまま使用することもできますし、シナリオに応じてコードを変更することもできます。コードコメント(1、3、5、11、16、18、22、29行目)は、各CSSルールが何を対象としているかを判断し、今後のスタイリングに役立てるためのものです。例えば、ボタンだけ(ウィジェット全体ではなく)欲しい場合は、以下のwhiteの場所-20行目と27行目で、ページの背景色を代入する必要があります。

    複数のボタンやSKUを作成する方法

    Pay2Playウィジェットを使用してこれを実現する方法のコード例については、Xsolla Pay2Playウィジェットシンプルな統合4つのボタンを参照してください。

    ゲームキーの直接販売ウィジェットのコードと同様の構造です。移行の例:

    Copy
    Full screen
    Small screen
    <div id="xsolla-buy-button-widget"></div>
    <div id="xsolla-buy-button-widget-2"></div>
        <script>
          var options = {
            project_id: "191204",
            sku: "789",
            item_type: "unit",
            api_settings: {
              sandbox: false,
            },
            widget_ui: {
              target_element: "#xsolla-buy-button-widget",
              theme: {
                foreground: "gold",
                background: "",
              },
            },
            payment_widget_ui: {
              lightbox: {
                height: "700px",
                spinner: "round",
              },
            },
          };
          // options for second buy button - note the different SKU and target_element
          var options2 = {
            project_id: "191204",
            sku: "123",
            item_type: "unit",
            api_settings: {
              sandbox: false,
            },
            widget_ui: {
              target_element: "#xsolla-buy-button-widget-2",
              theme: {
                foreground: "gold",
                background: "",
              },
            },
            payment_widget_ui: {
              lightbox: {
                height: "700px",
                spinner: "round",
              },
            },
          };
          var s = document.createElement("script");
          s.type = "text/javascript";
          s.async = true;
          s.src = "https://cdn.xsolla.net/embed/buy-button/3.1.4/widget.min.js";
    
    // one event listener per widget instance. repeat for more buttons, passing in different SKUs
          s.addEventListener(
            "load",
            function (e) {
              var widgetInstance = XBuyButtonWidget.create(options);
            },
            false
          );
          s.addEventListener(
            "load",
            function (e) {
              var widgetInstance2 = XBuyButtonWidget.create(options2);
            },
            false
          );
          var head = document.getElementsByTagName("head")[0];
          head.appendChild(s);
        </script>
    
    注意
    • 1行目と2行目 — ボタンごとに1つのdivがあり、それぞれに一意のIDがあります。
    • 26行目から始まるのは、2番目のボタンのオプションです(options2オブジェクトにレイアウトされます)。各購入ボタンには、上記のようなoptionsのセットが必要です。sku28行目)とtarget_element(34行目、2行目のdivを対象)が異なることに注意してください。
    この記事は役に立ちましたか?
    ありがとうございます!
    改善できることはありますか? メッセージ
    申し訳ありません
    この記事が参考にならなかった理由を説明してください。 メッセージ
    ご意見ありがとうございました!
    あなたのメッセージを確認し、体験を向上させるために利用させていただきます。
    このページを評価する
    このページを評価する
    改善できることはありますか?

    答えたくない

    ご意見ありがとうございました!

    続きを読む

    最終更新日: 2024年7月31日

    誤字脱字などのテキストエラーを見つけましたか? テキストを選択し、Ctrl+Enterを押します。

    問題を報告する
    当社は常にコンテンツを見直しています。お客様のご意見は改善に役立ちます。
    フォローアップ用のメールをご提供してください
    ご意見ありがとうございました!