Meteor - publikuj i subskrybuj

Jak już wspomniano w rozdziale Windykacja, wszystkie nasze dane są dostępne po stronie klienta. Jest to problem dotyczący bezpieczeństwa, który można rozwiązać za pomocą metod publikowania i subskrypcji.

Usuwanie autopublikowania

W tym przykładzie użyjemy PlayersCollectionzbieranie z następującymi danymi. Przygotowaliśmy tę kolekcję wcześniej, aby móc skoncentrować się na samym rozdziale. Jeśli nie masz pewności, jak tworzyć kolekcje MongoDB w aplikacji meteor, zapoznaj się z naszym rozdziałem o kolekcjach .

Aby zabezpieczyć nasze dane, musimy je usunąć autopublish pakiet, który pozwalał nam korzystać z danych po stronie klienta.

C:\Users\username\Desktop\meteorApp>meteor remove autopublish

Po tym kroku nie będziemy mogli pobrać danych bazy danych po stronie klienta. Będziemy mogli go zobaczyć tylko od strony serwera w oknie wiersza poleceń. Do kasy następujący kod -

meteorApp.js

var PlayersCollection = new Mongo.Collection('playersCollection');
var myLog = PlayersCollection.find().fetch();
console.log(myLog);

Plik command prompt okno pokaże całą kolekcję z czterema obiektami, podczas gdy developers consolepokaże pustą tablicę. Teraz nasza aplikacja jest bezpieczniejsza.

Korzystanie z funkcji publikowania i subskrypcji

Powiedzmy, że chcemy umożliwić klientom korzystanie z naszych danych. W tym celu musimy stworzyćMeteor.publish()na serwerze. Ta metoda wyśle ​​dane do klienta.

Aby móc odbierać i wykorzystywać te dane po stronie klienta, stworzymy Meteor.subscribe()metoda. Na końcu przykładu przeszukujemy bazę danych. Ten kod działa zarówno po stronie klienta, jak i serwera.

var PlayersCollection = new Mongo.Collection('playersCollection');

if(Meteor.isServer) {

   Meteor.publish('allowedData', function() {
      return PlayersCollection.find();
   })
}

if (Meteor.isClient) {
   Meteor.subscribe('allowedData');
};

Meteor.setTimeout(function() {
   var myLog = PlayersCollection.find().fetch();
   console.log(myLog);
}, 1000);

Widzimy, że nasze dane są rejestrowane zarówno w developers console i command prompt okno.

Filtrowanie danych klienta

Część danych możemy również opublikować. W tym przykładzie publikujemy dane zname = "John".

var PlayersCollection = new Mongo.Collection('playersCollection');

if(Meteor.isServer) {

   Meteor.publish('allowedData', function() {
      return PlayersCollection.find({name: "John"});
   })
}

if (Meteor.isClient) {
   Meteor.subscribe('allowedData');
};

Meteor.setTimeout(function() {
   myLog = PlayersCollection.find().fetch();
   console.log(myLog);
}, 1000);

Po uruchomieniu tego kodu command prompt zapisze wszystkie dane, podczas gdy po stronie klienta console po prostu zarejestruje dwa obiekty z nazwą John.