Skip to content
This repository has been archived by the owner on Apr 27, 2021. It is now read-only.

Latest commit

 

History

History

06

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 

アップロード画像サムネイルの作成

会員ページにアップロードした画像のサムネイルを追加します。

  1. サーバー側ルーターの設定
  2. サーバー側Controllerの作成
  3. 会員ページにサムネイル追加
  4. フロント側Controller作成
  5. Herokuへデプロイ

サーバー側ルーターの設定

まず、サーバー側のルーターでURLと機能をマッピングします。

server/api/photo/index.js

var express = require('express');
var controller = require('./photo.controller');
var auth = require('../../auth/auth.service');

var multiparty = require('connect-multiparty');
var multipartyMiddleware = multiparty();

var router = express.Router();

router.post('/me', auth.isAuthenticated(), multipartyMiddleware, controller.upload);

+ // `/me`と`controller.showPrivate`をマッピングします
+ // URLと機能の間にauth.isAuthenticated()を経由させることで、
+ // 認証していないアクセスをフィルタリングします
+ router.get('/me', auth.isAuthenticated(), controller.showPrivate);

module.exports = router;

サーバー側Controllerの作成

続いてController側にプライベート画像取得APIを追加します。

server/api/photo/photo.controller.js

exports.upload = function(req, res) { ... }

+ // プライベートな写真を取得
+ exports.showPrivate = function(req, res) {
+  Photo.find({
+    owner: req.user._id // 自分の画像のみ取得します
+  }, function (err, photos) {
+    if(err) { return handleError(res, err); }
+    // 取得した画像を返します
+    return res.status(200).json(photos);
+  });
+ };

...

💝 認証済みユーザーの情報はangular-fullstack上の認証フィルタを経由することでreq.userにバンドルされています。

会員ページにサムネイル追加

続いて、会員ページにアップロード画像を表示するサムネイルを追加します。

client/app/me/me.html

<div class="container">
  <!-- ここはアップロードエリア -->
</div>

+ <!-- ここはサムネイルエリア -->
+ <div class="container">
+   <h4>私の写真</h4>
+   <div class="row">
+     <div class="col-xs-6 col-md-3" ng-repeat="photo in photos">
+       <img class="photo-img" ng-src="{{photo.url}}">
+     </div>
+   </div>
+ </div>

💝 ng-repeatはAngularJSのビルトインディレクティブです。コントローラの特定のプロパティに対して繰り返し処理を行うことができます。 AngularJS: API: ngRepeat

フロント側Controller作成

続いてControllerにプライベート画像取得機能を追加します。

client/app/me/me.controller.js

module('photoShareApp')
-  .controller('MeCtrl', function ($scope, Upload) {
+  .controller('MeCtrl', function ($scope, $http, Upload) {

    $scope.upload = function (file) {
      ...
    };

+     // 初期表示時に画像を取得します
+     $http.get('/api/photos/me').success(function (photos) {
+       $scope.photos = photos;
+     });

  });

以上で会員ページへのサムネイル追加は完了しました。
画面は次のようになります。

アップロード画像サムネイル

Herokuへデプロイ

アプリケーションをherokuへデプロイします。

grunt build
grunt buildcontrol:heroku

デプロイされた画面を確認してください。


👉 7. 画像削除機能の作成

👈 5. 画像アップロード機能の作成