このDrupalサービスRESTful APIが機能しないのはなぜですか?


8

私はDrupal 7でサービスモジュールを使用しています。AJAXを介して検索用語を送信し、タイトルに緩やかに一致する上位5つのノード(ノードidtitle)を含む配列を受け取ることができるサービスを実装したいと思います。http://example.com/api/に接続すると、次のメッセージが表示されます

サービスエンドポイントの「検索」が正常にセットアップされました。

しかし、http://example.com/api/search/Testなどに移動しようとすると、404が表示されます。


1
D8コアの一部となるRESTwsをチェックすることをお勧めします。
kqw 2014

将来の読者のために、エンドポイントからデータを取得するためにHTTP POSTとGETリクエストの使用を検討してください。多くのサービスエンドポイントにはPOSTリクエストが必要です。
David Thomas

回答:


1

後で試してみて、他のチュートリアルから読んだとき、私は休みのあるリソースを作ります、私にとっては石鹸はdrupalでは不可能です、試してみましたが成功しませんでした。このコードをコピーしてページングし、カスタムモジュール名とフックのみを変更できます。

/**
 * Implements hook_ctools_plugin_api().
 */
function core_custom_webservice_ctools_plugin_api($owner, $api) {
  if ($owner == 'services' && $api == 'services') {
    return array(
      'version' => 3,
      'file' => 'core_custom_webservice.services.inc'
    );
  }
}


function core_custom_webservice_services_resources() {
  $resources = array(
    'webservice_resources' => array(
      'operations' => array(
        'retrieve' => array(
          'help' => t('Response of webservice'),
          'file' => array('type' => 'inc', 'module' => 'core_custom_webservice', 'name' => 'core_custom_webservice.resource',),
          'callback' => '_core_custom_webservice_get_response',
          'access callback' => '_core_custom_webservice_access',
          'access arguments' => array('view'),
          'access arguments append' => TRUE,
          'args' => array(
            array(
              'name' => 'parameters',
              'type' => 'string',
              'description' => 'The parameters that define requested data',
              'source' => array('path' => '0'), // first argument in the url 
              'optional' => FALSE,
            ),
          ),
        ),
      ),
    ),
  );
  return $resources;
}

/* * *************************************************************************************************
 * Access callback 
 * For now only view/retrieve is implemented and if the user is logged in, he gets access
 */

function _core_custom_webservice_access($op) {
  global $user;
  $access = TRUE;

  switch ($op) {
    case 'view':
      if ($user->uid) {
        $access = TRUE;
      }
      break;
  }

  return $access;
}

function _core_custom_webservice_get_response($arg) {
  $response = 'something';
  return 'print '.$response;
}

サービスパスで再試行して、 http://path.come/?q = webservice_server_rest / webservice_resources / string.jsonで成功する


0

Servicesモジュールを使用してRESTfulリソースを作成した場合、JSON形式でHTTPリクエストに応答することが期待されるため、次のように移動してみてください。 http://example.com/api/search/Test.json




0

こんにちはあなたがしなければならない最初のことは

ステップ1:カスタムモジュールを作成して実装する hook_services_resources()

例:

function mymodule_services_resources() {
  return array(
    'search' => array(
      'create' => array(
        'help' => 'Search for a content',
        'file' => array('file' => 'inc', 'module' => 'your module name'),
        'callback' => '_function_to_call_when_this_service_is_called',
        'access callback' => 'user_access',
        'access arguments' => array('access content'),
        'access arguments append' => FALSE,
        'args' => array(
         array(
           'name' => 'data',
           'type' => 'struct',
           'description' => 'The id of the data to get',
           'source' => 'data',
           'optional' => FALSE,
         ),
       ),
      ),
     ),
  );
}

ステップ2:に行く

構造->サービス

モジュールを有効にします

ステップ3:クライアントにデータを送信する$ data-クライアントに送信されるデータは配列でなければなりません

  $url = $base_url.'/api/search';
            $response = drupal_http_request($url, array(
                'headers' => array('Content-Type' => 'application/json', 'Accept' => 'application/json'),
               'method' => 'POST',
               'data' => json_encode($data),
               'max_redirects' => 0,
               )
             );

正常に動作するかどうかを確認するために応答を印刷します。

チェックリスト:

  1. DBロギングモジュールを有効にしてログインを確認し、サービスを呼び出します。
  2. そのファイルはサービスが呼び出されたときにのみ呼び出されるため、それまではエラーや警告が表示されないため、構文エラーがないか確認してください。
  3. 応答を出力し、データが正しく渡されているかどうかをテストします。
  4. クライアント側で確認してください。

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.