次の方法で共有


ハウツー: ポータル Web API を使用する

このガイドでは、Web API を使用して連絡先テーブルのレコードの読み取り、書き込み、更新、および削除を行う Web ページとカスタム Web テンプレートを設定します。

注意

この例の手順に従って、列名を変更したり、別のテーブルを使用したりできます。

ステップ 1: サイトの設定の作成

ポータル WebAPI を使用する前に、ポータル管理アプリで必要なサイト設定を有効にする必要があります。 サイト設定は、Web API を操作する場合に使用するテーブルによって異なります。

  1. ポータル管理アプリ を起動します。

  2. ポータル管理 アプリの左側のウィンドウで、サイト設定 を選択します。

    ポータル管理アプリでサイト設定を開きます。

  3. 新規 を選択します。

  4. 名前 ボックスに、Webapi/contact/enabled と入力します。

  5. Web サイト リストで、Web サイト レコードを選択します。

  6. 数値 ボックスに、true と入力します。

    Web API サイト設定の連絡先テーブルを有効にします。

  7. 保存して閉じるを選択します。

  8. 新規 を選択します。

  9. 名前 ボックスに、Webapi/contact/fields と入力します。

  10. Web サイト リストで、Web サイト レコードを選択します。

  11. ボックスで、次を入力します
    firstname,lastname,fullname,emailaddress1,telephone1

    Web API の連絡先テーブル フィールド サイト設定を有効にします。

  12. 保存して閉じるを選択します。

  13. 新規 を選択します。

  14. 名前 ボックスに、Webapi/error/innererror と入力します。

    Web API 内部エラー サイト設定を有効にします。

  15. Web サイト リストで、Web サイト レコードを選択します。

  16. 数値 ボックスに、true と入力します。

  17. 保存して閉じるを選択します。

  18. Web API のサイト設定を検証します。

ステップ 2. アクセス許可の構成

ユーザーが WebAPI 機能を使用できるように、アクセス許可を構成する必要があります。 この例では、Web API を使用する新しい Web ロールをセットアップまたは作成し、連絡先 テーブルのテーブル アクセス許可を追加し、テーブル アクセス許可をこの Web ロールに関連付けられて、最後にユーザーが Web API を使用できるように Web ロールをユーザーに割り当てます。

注意

Web API は、認証済みユーザーまたは匿名 Web ロールの Web ロール コンテキストから来るテーブルのアクセス許可に従います。 Web API が必要とする Web サイト内の特定のテーブルにアクセスできる Web ロールがユーザーに既にあるかどうかを確認してください。 Web API を使用するためだけに追加の Web ロールを作成する必要はありません。

Web ロールを作成する

現在、Web API を介してアクセスしているテーブルへのアクセス許可を持つ Web ロールがない場合、またはデータへのアクセスに別のコンテキストが必要な場合は、次の手順に従って、新しい Web ロールを作成し、テーブルのアクセス許可を割り当てます。

  1. ポータル管理アプリ を起動します。

  2. 左ペインの セキュリティ セクションで、Web ロール を選択します。

  3. 新規 を選択します。

  4. 名前 ボックスで、Web API ユーザー (または、この機能にアクセスするユーザーの役割を最もよく反映する任意の名前) を入力します。

  5. Web サイト リストで、Web サイト レコードを選択します。

    Web API ユーザー Web ロールを追加します。

  6. 保存 を選びます。

テーブルのアクセス許可の作成

  1. Power Pagesデザイン スタジオを起動します。

  2. セキュリティワークスペースを選択します。

  3. 保護 セクション配下で、テーブルのアクセス許可 を選択します。

  4. 新しいアクセス許可を選択します。

  5. 名前ボックスで取引先担当者テーブルのアクセス許可を入力します。

  6. テーブル名リストで、取引先担当者 (取引先担当者) を選択します。

  7. アクセスの種類リストで、グローバルを選択します。

  8. 読み取り書き込み作成削除 の特権を選択します。

  9. + 役割を追加 を選択し、前もって選択して作成した Web ロール を選択します。

  10. 保存して閉じる を選択します。

    連絡先テーブルへのアクセス許可。

取引先担当者を Web ロールに追加する

  1. ポータル管理アプリ を起動します。

  2. 左ペインの セキュリティ セクションで、取引先担当者 を選択します。

  3. Web API に対してこの例を使用する取引先担当者を選択します。

    注意

    この取引先担当者は、この例で WebAPI をテストするために使用されるユーザー アカウントです。 必ずポータルで正しい連絡先を選択してください。

  4. 関連>Web ロール を選択します。

    関連した Web ロールの選択。

  5. 既存の Web ロールの追加を選択します。

  6. 以前に作成した、WebAPI ユーザー ロールを選択します。

  7. 追加 を選択します。

    Web ロール関連ビュー。

  8. 保存して閉じるを選択します。

ステップ 3. Web ページの作成

Web API を有効にし、ユーザー権限を構成したので、レコードを表示、編集、作成、および削除するためのサンプルコードを使用して Web ページを作成します。

  1. Power Pagesデザイン スタジオを起動します。

  2. Pages ワークスペースで、+ Page を選択します。

  3. ページの追加 ダイアログで、以下を行います:

  4. 名前 ボックスで、WebAPI を入力して、ブランクから開始 レイアウトを選択します。

  5. 追加 を選択します。

  6. 右上隅の コードの編集 オプションを選択します。

  7. Visual Studio Code を開く を選択します。

  8. 次のサンプル コード スニペットをコピーして、ページ セクションの <div></div> タグ間に貼り付けます。

        <!-- Sample code for Web API demonstration -->
    <style>
        #processingMsg {
            width: 150px;
            text-align: center;
            padding: 6px 10px;
            z-index: 9999;
            top: 0;
            left: 40%;
            position: fixed;
            -webkit-border-radius: 0 0 2px 2px;
            border-radius: 0 0 2px 2px;
            -webkit-box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
            box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
            display: none;
        }
    
        table td[data-attribute] .glyphicon-pencil {
            margin-left: 5px;
            opacity: 0;
        }
    
        table td[data-attribute]:hover .glyphicon-pencil {
            opacity: 0.7;
        }
    </style>
    
    <script>
      $(function() {
        //Web API ajax wrapper
        (function(webapi, $) {
          function safeAjax(ajaxOptions) {
            var deferredAjax = $.Deferred();
            shell.getTokenDeferred().done(function(token) {
              // Add headers for ajax
              if (!ajaxOptions.headers) {
                $.extend(ajaxOptions, {
                  headers: {
                    "__RequestVerificationToken": token
                  }
                });
              } else {
                ajaxOptions.headers["__RequestVerificationToken"] = token;
              }
              $.ajax(ajaxOptions)
                .done(function(data, textStatus, jqXHR) {
                  validateLoginSession(data, textStatus, jqXHR, deferredAjax.resolve);
                }).fail(deferredAjax.reject); //ajax
            }).fail(function() {
              deferredAjax.rejectWith(this, arguments); // On token failure pass the token ajax and args
            });
            return deferredAjax.promise();
          }
          webapi.safeAjax = safeAjax;
        })(window.webapi = window.webapi || {}, jQuery)
        // Notification component
        var notificationMsg = (function() {
          var $processingMsgEl = $('#processingMsg'),
            _msg = 'Processing...',
            _stack = 0,
            _endTimeout;
          return {
            show: function(msg) {
              $processingMsgEl.text(msg || _msg);
              if (_stack === 0) {
                clearTimeout(_endTimeout);
                $processingMsgEl.show();
              }
              _stack++;
            },
            hide: function() {
              _stack--;
              if (_stack <= 0) {
                _stack = 0;
                clearTimeout(_endTimeout);
                _endTimeout = setTimeout(function() {
                  $processingMsgEl.hide();
                }, 500);
              }
            }
          }
        })();
        // Inline editable table component
        var webAPIExampleTable = (function() {
          var trTpl = '<% _.forEach(data, function(data){ %>' +
            '<tr data-id="<%=data.id%>" data-name="<%=data.fullname%>">' +
            '<% _.forEach(columns, function(col){ %>' +
            '<td data-attribute="<%=col.name%>" data-label="<%=col.label%>" data-value="<%=data[col.name]%>">' +
            '<%-data[col.name]%><i class="glyphicon glyphicon-pencil"></i>' +
            '</td>' +
            '<% }) %>' +
            '<td>' +
            '<button class="btn btn-default delete" type="submit"><i class="glyphicon glyphicon-trash" aria-hidden="true"></i></button>' +
            '</td>' +
            '</tr>' +
            '<% }) %>';
          var tableTpl = '<table class="table table-hover">' +
            '<thead>' +
            '<tr>' +
            '<% _.forEach(columns, function(col){ %>' +
            '<th><%=col.label%></th>' +
            '<% }) %>' +
            '<th>' +
            '<button class="btn btn-default add" type="submit">' +
            '<i class="glyphicon glyphicon-plus" aria-hidden="true"></i> Add Sample Record' +
            '</button>' +
            '</th>' +
            '</tr>' +
            '</thead>' +
            '<tbody>' + trTpl + '</tbody>' +
            '</table>';
          function getDataObject(rowEl) {
            var $rowEl = $(rowEl),
              attrObj = {
                id: $rowEl.attr('data-id'),
                name: $rowEl.attr('data-name')
              };
            $rowEl.find('td').each(function(i, el) {
              var $el = $(el),
                key = $el.attr('data-attribute');
              if (key) {
                attrObj[key] = $el.attr('data-value');
              }
            })
            return attrObj;
          }
          function bindRowEvents(tr, config) {
            var $row = $(tr),
              $deleteButton = $row.find('button.delete'),
              dataObj = getDataObject($row);
            $.each(config.columns, function(i, col) {
              var $el = $row.find('td[data-attribute="' + col.name + '"]');
              $el.on('click', $.proxy(col.handler, $el, col, dataObj));
            });
            //User can delete record using this button
            $deleteButton.on('click', $.proxy(config.deleteHandler, $row, dataObj));
          }
          function bindTableEvents($table, config) {
            $table.find('tbody tr').each(function(i, tr) {
              bindRowEvents(tr, config);
            });
            $table.find('thead button.add').on('click', $.proxy(config.addHandler, $table));
          }
          return function(config) {
            var me = this,
              columns = config.columns,
              addHandler = config.addHandler,
              deleteHandler = config.deleteHandler,
              $table;
            me.render = function(el) {
              $table = $(el).html(_.template(tableTpl)({
                columns: columns,
                data: me.data
              })).find('table');
              bindTableEvents($table, {
                columns: columns,
                addHandler: addHandler,
                deleteHandler: deleteHandler
              });
            }
            me.addRecord = function(record) {
              $table.find('tbody tr:first').before(_.template(trTpl)({
                columns: columns,
                data: [record]
              }));
              bindRowEvents($table.find('tbody tr:first'), config);
            }
            me.updateRecord = function(attributeName, newValue, record) {
              $table.find('tr[data-id="' + record.id + '"] td[data-attribute="' + attributeName + '"]').text(newValue);
            }
            me.removeRecord = function(record) {
              $table.find('tr[data-id="' + record.id + '"]').fadeTo("slow", 0.7, function() {
                $(this).remove();
              });
            }
          };
        })();
        //Applicaton ajax wrapper 
        function appAjax(processingMsg, ajaxOptions) {
          notificationMsg.show(processingMsg);
          return webapi.safeAjax(ajaxOptions)
            .fail(function(response) {
              if (response.responseJSON) {
                alert("Error: " + response.responseJSON.error.message)
              } else {
                alert("Error: Web API is not available... ")
              }
            }).always(notificationMsg.hide);
        }
        function loadRecords() {
          return appAjax('Loading...', {
            type: "GET",
            url: "/_api/contacts?$select=fullname,firstname,lastname,emailaddress1,telephone1",
            contentType: "application/json"
          });
        }
        function addSampleRecord() {
          //Sample data to create a record - change as appropriate
          var recordObj = {
            firstname: "Willie",
            lastname: "Huff" + _.random(100, 999),
            emailaddress1: "Willie.Huff@contoso.com",
            telephone1: "555-123-4567"
          };
          appAjax('Adding...', {
            type: "POST",
            url: "/_api/contacts",
            contentType: "application/json",
            data: JSON.stringify(recordObj),
            success: function(res, status, xhr) {
              recordObj.id = xhr.getResponseHeader("entityid");
              recordObj.fullname = recordObj.firstname + " " + recordObj.lastname;
              table.addRecord(recordObj);
            }
          });
          return false;
        }
        function deleteRecord(recordObj) {
          var response = confirm("Are you sure, you want to delete \"" + recordObj.name + "\" ?");
          if (response == true) {
            appAjax('Deleting...', {
              type: "DELETE",
              url: "/_api/contacts(" + recordObj.id + ")",
              contentType: "application/json",
              success: function(res) {
                table.removeRecord(recordObj);
              }
            });
          }
          return false;
        }
        function updateRecordAttribute(col, recordObj) {
          var attributeName = col.name,
            value = recordObj[attributeName],
            newValue = prompt("Please enter \"" + col.label + "\"", value);
          if (newValue != null && newValue !== value) {
            appAjax('Updating...', {
              type: "PUT",
              url: "/_api/contacts(" + recordObj.id + ")/" + attributeName,
              contentType: "application/json",
              data: JSON.stringify({
                "value": newValue
              }),
              success: function(res) {
                table.updateRecord(attributeName, newValue, recordObj);
              }
            });
          }
          return false;
        }
        var table = new webAPIExampleTable({
          columns: [{
            name: 'firstname',
            label: 'First Name',
            handler: updateRecordAttribute
          }, {
            name: 'lastname',
            label: 'Last Name',
            handler: updateRecordAttribute
          }, {
            name: 'emailaddress1',
            label: 'Email',
            handler: updateRecordAttribute
          }, {
            name: 'telephone1',
            label: 'Telephone',
            handler: updateRecordAttribute
          }],
          data: [],
          addHandler: addSampleRecord,
          deleteHandler: deleteRecord
        });
        loadRecords().done(function(data) {
          table.data = _.map(data.value, function(record){
            record.id = record.contactid;
            return record;
          });
          table.render($('#dataTable'));
        });
      });
    </script>
    <div id="processingMsg" class="alert alert-warning" role="alert"></div>
    <div id="dataTable"></div>
    

    コードを貼り付けます。

  9. CTRL-S を選択して、コードを保存します。

  10. デザイン スタジオで 同期 を選択すると、コード編集でサイトが更新されます。

ステップ 4. Web API を使用して、読み取り、表示、編集、作成、および削除を実行します

Web API 機能をテストするには:

  1. プレビュー を選択し、次にデスクトップ を選択します。

  2. 以前に作成した Web API ユーザー ロールに割り当てられたユーザー アカウントでサイトにサインインします。

  3. 以前に作成された WebApi Web ページに移動します。

    サンプル webapi webpage。

  4. サンプル レコードを追加 を選択して、スクリプトからサンプル レコードを追加します。

  5. フィールドを選択します。 この例では、E メール を選択して、取引先担当者のメール アドレスを変更します。

    電子メールの編集

  6. 削除 アイコンを選択してレコードを削除します。

レコードを読み取り、編集、作成、および削除するためのサンプルを含む Web ページを作成したので、フォームとレイアウトをカスタマイズできます。

次のステップ

HTTP 要求の作成とエラーの処理

参照