• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Prośba o code review - PHP REST

Object Storage Arubacloud
0 głosów
326 wizyt
pytanie zadane 29 lipca 2018 w PHP przez User007 Bywalec (2,400 p.)

Witam.

Proszę o ocenę kodu małej aplikacji RESTowej.

Głównym celem aplikacji jest zapisywanie danych statystycznych (dane użytkownika, statystyki poziomów) z gry na platformę Android.

Główny rdzeń aplikacji jest ukończony. Do ukończenia pozostało jeszcze napisanie paru zapytań do bazy danych itp. Ale to szczegóły.

Jedyna BARDZO ważna rzecz która została do zrobienia to system uwierzytelniania zapytań z urządzeń mobilnych.

Ale może mój zamysł jak to ma działać opiszę w innym pytaniu aby tu nie zbaczać od głównego tematu. W każdym bądź razie mam parę pytań jak to najlepiej zrobić.

Co do apki tytułem wstępu to, podzielona ona jest na dwa segmenty:

/core - katalog gdzie jest trzymany silnik aplikacji,

/http - katalog gdzie można dodawać obsługę nowych zapytań url

Link do projektu: https://github.com/kapdom/Planetoid-REST

3 odpowiedzi

+3 głosów
odpowiedź 29 lipca 2018 przez Comandeer Guru (600,810 p.)
komentarz 29 lipca 2018 przez User007 Bywalec (2,400 p.)

Dziękuję za odpowiedzi. Przyjmuję wszystko do wiadomości :) z małymi pytaniami.

Zaczynając od końca.

Framework własny zrobiłem tylko po to aby się lepiej PHP nauczyć. I może żeby do portfolio dodać aby pokazać coś potencjalnemu pracodawcy. Jeśli moje rozumowanie jest błędne proszę napiszcie to. Chociaż w obecnym stanie to się to pewnie nie nadaje.

Config ma rozszerzenie .ini,  tylko na github jest wysyłane txt.

W przypadku validatora i innych klas to zawsze przestrzenie nazw są z dużej litery a katalogi z małej. Ktoś mi kiedyś napisał że tak ma być.

Dlaczego uważasz że Result.php to encja a nie model?

A po co mam trzymać jakikolwiek stan w statycznych metodach? Przecież ma to tylko wykonać działanie i zwrócić wynik. Myślałem że metody i właściwości statyczne świetnie się do tego nadają. Możesz dokładniej wyjaśnić dlaczego to jest problemem?

P.S. Napiszcie proszę chociaż jedną rzecz którą dobrze zrobiłem, bo się załamię :).

komentarz 29 lipca 2018 przez Comandeer Guru (600,810 p.)

Jeśli moje rozumowanie jest błędne proszę napiszcie to.

Twoje rozumowanie jest błędne ;) Jasne, frameworki się fajnie pisze, ale żeby to napisać dobrze, to trzeba mieć naprawdę sporo wiedzy i doświadczenia – choćby po to, by analizować inne frameworki i wyciągać wnioski z ich architektury. Inaczej powstanie coś, czego sami będziemy się wstydzić, gdy tylko nasza wiedza i doświadczenie wzrosną.

Zresztą większość produktów opiera się na ogólnie znanych i szanowanych frameworkach pokroju Symfony czy Laravela. Czemu? Bo to są frameworki popularne, przetestowane w boju, opierające się często na najlepszych praktykach w branży. Po co wymyślać koło na nowo? Lepiej ten czas poświęcić na implementację logiki biznesowej. Z tego też względu bardziej ceni się (z punktu widzenia biznesu) umiejętność pracy w znanych frameworkach niż umiejętność pisania własnego. To drugie znajduje zastosowanie raczej w naprawdę dużych, korporacyjnych projektach, gdzie czas do wdrożenia nie jest kluczowym czynnikiem, a zasoby pieniężne po prostu są.

Config ma rozszerzenie .ini,  tylko na github jest wysyłane txt. 

A czemu?

 W przypadku validatora i innych klas to zawsze przestrzenie nazw są z dużej litery a katalogi z małej. Ktoś mi kiedyś napisał że tak ma być.

Nie bardzo wiem, czemu miałoby tak być? Tego typu rzeczy naprawdę sprawiają problemy przy przenoszeniu aplikacji między różnymi systemami.

 Dlaczego uważasz że Result.php to encja a nie model?

Bo model dla mnie to bardziej rozbudowane pojęcie, do którego wciska się wiele rzeczy (choćby właśnie pobieranie danych). Encja z kolei po prostu te dane reprezentuje.

A po co mam trzymać jakikolwiek stan w statycznych metodach? 

Skoro nie masz stanu, to po co Ci klasy i obiekty? Tutaj jest zarzewie problemu: jeśli całość jest bezstanowa, to równie dobrze możesz to przepisać na zwykłe funkcje i dalej będzie działać. Tu nie chodzi o samą implementację, a o sposób myślenia o aplikacji.

Napiszcie proszę chociaż jedną rzecz którą dobrze zrobiłem, bo się załamię :) 

Cóż, ja jestem okrutnym człowiekiem >:D. Ale mogę Ci na pocieszenie powiedzieć, że moje początki z PHP wyglądały bardzo podobnie. Niektóre rzeczy nabywa się po prostu wraz z doświadczeniem ;) 

komentarz 29 lipca 2018 przez User007 Bywalec (2,400 p.)

Config ma rozszerzenie .ini,  tylko na github jest wysyłane txt. 

A czemu?

A no temu, aby na githuba nie wysłać swojej konfiguracji dostępu do bazy danych itp. A zamiast tego wysyłać jakby szablon konfiguracyjny. To też mi ktoś tak "doradził".

Skoro nie masz stanu, to po co Ci klasy i obiekty? Tutaj jest zarzewie problemu: jeśli całość jest bezstanowa, to równie dobrze możesz to przepisać na zwykłe funkcje i dalej będzie działać. Tu nie chodzi o samą implementację, a o sposób myślenia o aplikacji.

No racja, racja.

Nie bardzo wiem, czemu miałoby tak być? Tego typu rzeczy naprawdę sprawiają problemy przy przenoszeniu aplikacji między różnymi systemami.

Sprawdziłem teraz na szybko laravela i rzeczywiście jest tak jak napisałeś. Nie wiem kto mi to wcisnął że tak zrobiłem jak zrobiłem.

Dzięki za review, dam znać jak wprowadzę zmiany.

komentarz 29 lipca 2018 przez Comandeer Guru (600,810 p.)

A no temu, aby na githuba nie wysłać swojej konfiguracji dostępu do bazy danych itp. A zamiast tego wysyłać jakby szablon konfiguracyjny.

W sumie robi sensy, chociaż chyba bym pomyślał nad config.template.ini lub czymś podobnym i odpowiednim ignore w .gitignore dla rzeczywistego pliku z konfiguracją. Niemniej mimo wszystko polecałbym spojrzeć na to, co podlinkowałem, o trzymaniu konfiguracji w zmiennych środowiskowych. 

komentarz 29 lipca 2018 przez User007 Bywalec (2,400 p.)
Tak zrobię.
komentarz 30 lipca 2018 przez CenterPL Pasjonat (19,070 p.)

Przyjęło się, że dla szablonowego configu robimy np config.ini.dist i wtedy problem z głowy. Ale co prawda, to prawda, orginał powinien być w .gitignore.

0 głosów
odpowiedź 29 lipca 2018 przez Mariusz08 Maniak (62,300 p.)

Za dużo metod statycznych.

$request = new Request();

?

switch ($_SERVER['REQUEST_METHOD']) {

Tutaj można użyć danych z klasy Request

0 głosów
odpowiedź 29 lipca 2018 przez User007 Bywalec (2,400 p.)

Zaktualizowany kod jest dostępny. https://github.com/kapdom/Planetoid-REST

Podobne pytania

0 głosów
0 odpowiedzi 344 wizyt
pytanie zadane 30 maja 2020 w PHP przez Mr. PanKrok Nowicjusz (230 p.)
0 głosów
1 odpowiedź 435 wizyt
pytanie zadane 11 grudnia 2017 w PHP przez jpacanowski VIP (101,940 p.)
+1 głos
0 odpowiedzi 262 wizyt
pytanie zadane 9 kwietnia 2021 w PHP przez Lopus Początkujący (360 p.)

92,551 zapytań

141,397 odpowiedzi

319,528 komentarzy

61,936 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...