web-dev-qa-db-ja.com

サービス3を使用して画像を保存する方法

Services 3についての非常に詳細なチュートリアルをいくつか見つけました。ここに小さなリストがあり、非常に感謝しています。

http://drupal.org/node/1354202

node.saveサービスを使用して複数のイメージをノードに追加する方法

http://drupal.org/node/1699354

しかし、モバイルアプリからサーバーに画像をアップロードする方法が見つかりません。それは可能ですか?どこでサンプルを入手できますか?

これを実現するためのサービスコアはありますか?すべてのソリューションは、それを動作させるために何かをコーディングする必要があるように見えます。

8
niksmac

以前はこのような要件がありましたが、Webサービスを使用して、画像も保存するノードを作成する必要がありました。次のコードは、Webサービスを使用して画像をアップロードおよび保存します。

// File validator.
$validators = array(
  /**
   * Defaults already allow png, jpg etc. If more needed to be supported,
   * edit here.
   */
  'file_validate_extensions' => array(),
  'file_validate_size' => array(),
);


foreach ($_FILES['files']['name'] as $field_name => $file_name) {
  // Save the file and get file object.
    $file = file_save_upload($field_name, $validators, file_default_scheme() . "://");

  // Check whether image is uploaded.
  if ($file->fid) {
    $node = new stdClass();
    $node->type = 'CONTENT_TYPE';
    $node->title = 'TITLE';
    $node->language = LANGUAGE_NONE;
    $node->uid = 'USER_UID';
    node_object_prepare($node);

    $node->field_custom[$node->language][0]['value'] = 'SOME_VALUE';
    // File upload here..
    $node->field_image[$node->language][0] = (array)$file;

    $node = node_submit($node);
    node_save($node);
  }
  else {                                                                      
    return services_error(t('File upload failed'), 406, t('File upload failed'));
  }
}

注:以下のコードはサービス3を使用してテストされました。また、このWebサービスを使用していたのはiOSアプリであり、そこで機能しました。

注:POSTリクエストでアップロードされたファイル。

Googleを使用して上記のコードをテストしましたChromeプラグインREST Consoleと呼ばれます。プラグインをインストールするには、Chrome = Webストアで、最初に取得したプラグインをインストールします(上向きの緑と下向きの青い矢印)

お役に立てれば!

6
subhojit777

まず、エンドポイントでファイル->リソースの作成を有効にします。

そして「クライアント側」で私はこのようなことをしました:

/**
 * Upload a file using services 3.X
 * 
 * @param the path of the local file
 * @return bool|int the fid of the file.
 *
 * 
 * With the fid you can attach this file in the node object before to be send.
 * ej.
 * $node->title = 'My remote node';
 * $fid = node_upload_image('/The_path/to_the/local_file.jpg');
 * $node->file_field[0] = array( 
 *    'fid' => $fid,
 *    'list' => 1,
 *    'data' => array()
 * );
 * // Other fields related with the node.
 * ...
 * 
 * // Sending the node.
 * $data = http_build_query($node, '', '&');
 * $response = drupal_http_request('myremotesite.com'. '/node', array(
 *   'Accept' => 'application/json', 
 *   'Cookie' => 'auth_cookie_info'
 * ), 'POST', $data);
 *
 * Done. 
 */
function node_upload_image($image_path) {
  $file = array(
    'filesize' => filesize($image_path),
    'filename' => basename($image_path),
    'file' => base64_encode(file_get_contents($image_path)),
    'uid'  => 1  // This should change it by the user who use the service.
  );

  $data = http_build_query($file, '', '&');
  $response = drupal_http_request('myremotesite.com/myservice-endpoint' . "/file", array('Accept' => 'application/json', 'Cookie' => 'auth_cookie_info'), "POST", $data);


  if ($response->code == 200) {
    return json_decode($response->data)->fid;
  }


  $this->error =  $response->status_message; 
  return false;
}

私は別のDrupalからこれを行い、Drupal 6の場合は、コードをD7に移植するのは簡単です。そして、それをどのように行うかについての一般的な考えを理解していると思います。

3
Gnuget

画像をアップロードするには、ファイル名とファイル(base64でエンコードされている)のみが必要です。

あなたは私のレポをチェックすることができます ここ 、ここでDrupal 7 Rest Servicesを操作するための簡単なクラスと、方法に関するいくつかの例があるexamples.phpファイルを見つけることができますここで、最近追加した画像をアップロードする方法の例も見つけることができます。

https://github.com/flesheater/drupal_rest_server_class

2
Nikolay Borisov

通常のサービス3には「ファイル」エンドポイントがあります。ファイルの作成を有効にして、次のようなものを投稿できます。ファイル自体はbase-64でエンコードされています。

{
    "filename": "user993.jpg",
    "target_uri": "pictures/user993.jpg",
    "filemime": "image/jpeg",
    "file": "/9j/4AAQSkZJRgABAQELIiyoy0pUQRoFjAVVGAAMACiigBaKKKAP/2Q==...",
    "filesize": "5356"
}
2
rfay