İyonik - Cordova Facebook

Bu eklenti, Facebook API'ye bağlanmak için kullanılır. Facebook'u entegre etmeye başlamadan önce, burada bir Facebook uygulaması oluşturmanız gerekir . Bir web uygulaması oluşturacak ve ardından hızlı başlangıç ​​ekranını atlayacaksınız. Ardından, web sitesi platformunu şuraya eklemeniz gerekir:settingssayfa. Geliştirme sırasında site URL'si için aşağıdaki kod parçacığını kullanabilirsiniz.

http://localhost:8100/

Bundan sonra eklemeniz gerekir Valid OAuth redirect URIs üzerinde settings/advancedsayfa. Aşağıdaki iki URL'yi kopyalamanız yeterlidir.

https://www.facebook.com/connect/login_success.html
http://localhost:8100/oauthcallback.html

Facebook Eklentisini Kurmak

Bu eklentiyi kullanırken sıklıkla ortaya çıkan bazı sorunları çözmek için yukarıdaki tüm adımları uyguladık. Bu eklentinin kurulması zordur çünkü dahil olan çok sayıda adım vardır ve belgeler hepsini kapsamaz. Diğer Cordova eklentileriyle ilgili bilinen bazı uyumluluk sorunları da vardır, bu nedenleTeleric verified pluginuygulamamızdaki sürüm. Komut isteminden uygulamamıza tarayıcı platformu kurarak başlayacağız.

C:\Users\Username\Desktop\MyApp>ionic platform add browser

Ardından, yapmamız gereken şey, root Üstündeki öğe body etiketlemek index.html.

index.html

<div id = "fb-root"></div>

Şimdi Cordova Facebook eklentisini uygulamamıza ekleyeceğiz. Değişmen gerekAPP_ID ve APP_NAME Daha önce oluşturduğunuz Facebook uygulamasıyla eşleşecek şekilde.

C:\Users\Username\Desktop\MyApp>cordova -d plugin add 
   https://github.com/Telerik-Verified-Plugins/Facebook/ 
   --variable APP_ID = "123456789" --variable APP_NAME = "FbAppName"

Şimdi aç index.html ve aşağıdaki kodu bodyetiket. Yine emin olmanız gerekir.appId ve versionoluşturduğunuz Facebook uygulamasıyla eşleşiyor. Bu, Facebook SDK'nın uygulamanın geri kalanını engellemeden eşzamansız olarak yüklenmesini sağlayacaktır.

index.html

<script>
   window.fbAsyncInit = function() {
      FB.init({
         appId      : '123456789',
         xfbml      : true,
         version    : 'v2.4'
      });
   };

   (function(d, s, id) {
      var js, fjs = d.getElementsByTagName(s)[0];
      if (d.getElementById(id)) {return;}
      js = d.createElement(s); js.id = id;
      js.src = "//connect.facebook.net/en_US/sdk.js";
      fjs.parentNode.insertBefore(js, fjs);
   }(document, 'script', 'facebook-jssdk'));
</script>

Açısal Hizmet

Her şeyi kurduğumuz için, Facebook ile bağlantımız olacak hizmet oluşturmamız gerekiyor. Bu şeyler, daha az kod ile yapılabilir.controller, ancak en iyi uygulamaları takip etmeye çalışıyoruz, bu nedenle Angular hizmetini kullanacağız. Aşağıdaki kod, tüm hizmeti gösterir. Daha sonra açıklayacağız.

services.js

.service('Auth', function($q, $ionicLoading) {
   this.getLoginStatus = function() {
      var defer = $q.defer();
      
      FB.getLoginStatus(function(response) {
		   if (response.status === "connected") {
            console.log(JSON.stringify(response));
         } else {
            console.log("Not logged in");
         }
      });

      return defer.promise;
   }
   this.loginFacebook = function() {
      var defer = $q.defer();

      FB.login(function(response) {
		   if (response.status === "connected") {
            console.log(JSON.stringify(response));
         } else {
            console.log("Not logged in!");
         }
      });

      return defer.promise;
   }
   this.logoutFacebook = function() {
      var defer = $q.defer();

      FB.logout(function(response) {
         console.log('You are logged out!');
      });

      return defer.promise;
   }
   this.getFacebookApi = function() {
      var defer = $q.defer();

      FB.api("me/?fields = id,email", [], function(response) {
		
         if (response.error) {
            console.log(JSON.stringify(response.error));
         } else {
            console.log(JSON.stringify(response));
         }
      });

      return defer.promise;
   }
});

Yukarıdaki hizmette dört işlev oluşturuyoruz. İlk üçü kendinden açıklamalıdır. Dördüncü işlev, Facebook grafik API'sine bağlanmak için kullanılır. Geri dönecekid ve email Facebook kullanıcısından.

Biz yaratıyoruz promise objectsasenkron JavaScript işlevlerini işlemek için. Şimdi bu işlevleri çağıracak denetleyicimizi yazmamız gerekiyor. Daha iyi anlamak için her işlevi ayrı ayrı arayacağız, ancak istenen etkiyi elde etmek için muhtemelen bazılarını karıştırmanız gerekecek.

Denetleyici Kodu

.controller('MyCtrl', function($scope, Auth, $ionicLoading) {
   
   $scope.checkLoginStatus = function() {
      getLoginUserStatus();
   }

   $scope.loginFacebook = function(userData) {
      loginFacebookUser();
   };

   $scope.facebookAPI = function() {
      getFacebookUserApi();
   }

   $scope.logoutFacebook = function() {
      logoutFacebookUser();
   };

   function loginFacebookUser() {
      return Auth.loginFacebook();
   }

   function logoutFacebookUser() {
      return Auth.logoutFacebook();
   }

   function getFacebookUserApi() {
      return Auth.getFacebookApi();
   }

   function getLoginUserStatus() {
      return Auth.getLoginStatus();
   }
})

Muhtemelen neden geri dönmediğimizi merak ediyorsunuz Authdoğrudan işlev ifadelerinden (ilk dört işlev) hizmet. Bunun nedeni, muhtemelen daha sonra biraz daha davranış eklemek isteyeceğinizdir.Authişlev döndürülür. Veritabanınıza bazı veriler gönderebilir, giriş yaptıktan sonra rotayı değiştirebilirsiniz, vb. Bu, JavaScript kullanılarak kolayca yapılabilir.then() geri çağırmalar yerine tüm zaman uyumsuz işlemleri işlemek için yöntem.

Şimdi kullanıcıların uygulamayla etkileşim kurmasına izin vermemiz gerekiyor. HTML'miz, oluşturduğumuz dört işlevi çağırmak için dört düğme içerecektir.

HTML Kodu

<button class = "button" ng-click = "loginFacebook()">LOG IN</button>
<button class = "button" ng-click = "logoutFacebook()">LOG OUT</button>
<button class = "button" ng-click = "checkLoginStatus()">CHECK</button>
<button class = "button" ng-click = "facebookAPI()">API</button>

Kullanıcı, LOG INdüğmesi, Facebook ekranı görünecektir. Giriş başarılı olduktan sonra kullanıcı uygulamaya yönlendirilecektir.