Java aplikacja WEB - obecne trendy

Java aplikacja WEB - obecne trendy
T9
  • Rejestracja:ponad 13 lat
  • Ostatnio:około 3 lata
  • Postów:48
0

Witam wszystkich,
Tak ostatnio zastanawiam się, przymierzając do stworzenia własnego projektu co jest obecnie trendy i w modzie w aplikacjach Webowych oraz wsparcie i rozwój nie skończy się przewidywalnie jesienią :)
Zastanawiam się nad połączeniem Springa (w którym kiedyś miałem okazję trochę grzebać) oraz Vaadin. JSP stanowczo chciałbym uniknąć, bo mam z nimi do czynienia na co dzień, GWT miałem przyjemność też trochę używać lecz, już w dość rozbudowanym systemie.
Czy mógłby ktoś polecić, co obecnie się wykorzystuje, nie zależy mi na wielkiej kobyle( jaką de facto jest jednak Spring, którą będzie ciężko okiełznać), gdyż nie planuję aby mój projekt był na tyle wielki, lecz czas to pokaże. Słyszałem też co nie co o Play Framework, lecz podobnie jak z Vaadim nie miałem z nimi do czynienia. Chciałbym, żeby nauka nowych rzeczy nie ograniczyła się tylko do mojego projektu, ale przyszłościowo mógłbym wiedzę wykorzystać też gdzie indziej. Liczę na owocną dyskusję :)
P.S.
Być może, kiedyś do tego systemu chciałbym podpiąć Activity wraz z prostymi procesami, dlatego fajnie jakby to wszystko współgrało ze sobą.

edytowany 1x, ostatnio: turo90
Shalom
  • Rejestracja:około 21 lat
  • Ostatnio:prawie 3 lata
  • Lokalizacja:Space: the final frontier
  • Postów:26433
0

Myślę że spokojnie możesz klepać z takim stosem jaki sobie wybrałeś. Mozesz też z zupełnie innym ;) Trendy są takie że co firma to inny stos, wiec specjalnie sie tym nie przejmuj.
Activiti sie ze Springiem zepnie bez problemów, bo ten silnik powstał na potrzeby Alfresco, które było w Springu pisane.


"Nie brookliński most, ale przemienić w jasny, nowy dzień najsmutniejszą noc - to jest dopiero coś!"
matoung
  • Rejestracja:około 10 lat
  • Ostatnio:ponad 7 lat
  • Postów:53
0

Dobre w Play Frameworku jest to, że łatwo można przepisać adres URL do odpowiadających im akcji(bodajże odpowiada za to plik conf/routes) oraz tworzenie strony typu CRUD jest bardzo proste. W stosunku do innych framów, Play Framework kładzie duży nacisk na bezpieczeństwo aplikacji (rozbudowane możliwośc walidacji itp.).

shagrin
  • Rejestracja:prawie 17 lat
  • Ostatnio:ponad 6 lat
  • Lokalizacja:Norwegia, Stavanger
0

A ja uważam, że front-end może być budowany w JS, HTML i CSS co może okazać się całkiem fajnym (lekkim) rozwiązaniem.
Obecnie pracujemy nad projektem, w którym back-end jest "prawie" całkowicie odcięty od front-endu, który opiera się głownie o AngularJS, Bootstrap, JQuery i czysty HTML, JS, CSS. Integracja pomiędzy back-endem a front-endem realizowana jest przez REST i WS.

Brałam udział w sporych projektach, gdzie interfejs użytkownika opierał się o "Javowe" frameworki, działało to topornie ;)


L4
Dokładnie na takich rozwiązaniach tworze swoje projekty :)
0

Dzięki wszystkim za odpowiedzi i porady. Wychodzi na to, że wszystko jest dobre, a czy się sprawdzi, to trzeba spróbować i ewentualnie szukać wtedy innego rozwiązania.
Mam do Was jeszcze pokrewne pytanie, ale z chęcią bym wysłuchał cennych rad, o które w tym temacie raczej trudno, a mianowicie wybór stosu technologicznego to jedno, a implementacja szkieletu architektonicznego do którego z łatwością można wtedy implementować logikę biznesową to drugie. Czy mógłby ktoś podzielić się uwagami na ten temat.

azalut
  • Rejestracja:około 12 lat
  • Ostatnio:ponad rok
  • Postów:1129
0

tak btw chciałem się zapytać o jedną rzecz
wiadomo, że teraz jest popularne robienie RESTowych serwisów i obslugowanie różnymi js frameworkami, androidami itp jednak zastanawia mnie co teraz można poznać takiego frontendowego "backendowego". Tzn że współpracuje z backenem ściśle np. Spring+freemarker, thymeleaf, JSTL, JSF, Vaadin

Nie wiem jak określić te rozwiazania fronendowe jako grupe, ale myśle, że rozumiecie o co mi chodzi :)

Co teraz jest warte uwagi?
Bo np freemarker niby polecany (chyba?) ale pachnie starością trochę, Vaadin może być spoko ale ma spory narzut co do wyglądu. A może jednak?

Np w django fajnie pracuje mi się z tym mechanizmem który mam domyślnie, fajnie binduje obiekty ze stronami frontendu, jest taki.. przyjazny, intuicyjny - w przeciwieństwie do freemarkera (takie mam wrażenie)

Javaluke Scriptwalker
@azalut pracujesz już Panie kolego? :)
azalut
teraz juz tak ;-)
Shalom
  • Rejestracja:około 21 lat
  • Ostatnio:prawie 3 lata
  • Lokalizacja:Space: the final frontier
  • Postów:26433
0

Chodzi ci o silnik do templatów? Jak dla mnie to większość jest tak podobna że to bez różnicy.


"Nie brookliński most, ale przemienić w jasny, nowy dzień najsmutniejszą noc - to jest dopiero coś!"
azalut
  • Rejestracja:około 12 lat
  • Ostatnio:ponad rok
  • Postów:1129
0

Chodzi ci o silnik do templatów? Jak dla mnie to większość jest tak podobna że to bez różnicy.

@Shalom Właściwie to nie silnik do templatów, tylko jakąś taką technologie inną niż RESTy która jest aktualnie popularna i warta przyswojenia. (być może i któryś z silników templatów)

A tak btw w javie te silniki templatów takie.. toporne troche mi się wydają :)

edytowany 2x, ostatnio: azalut
0

JSF + Primefaces

azalut
  • Rejestracja:około 12 lat
  • Ostatnio:ponad rok
  • Postów:1129
0

Nie jestem do końca przekonany, czy JSF+Primefaces to jest aktualny trend. Częęęsto czytam, że JSF jest utrzymywane bo musi być. Znam go bardzo podstwowo, jednak słyszałem, że na wyższym poziomie potrafi baardzo irytować :) Chyba, że się mylę?

0

Spring Boot JAX-RS (Jersey 2.x) czy w wersji Spring 4 MVC dla Resta? I czy w sumie ma to znaczenie?

T9
  • Rejestracja:ponad 13 lat
  • Ostatnio:około 3 lata
  • Postów:48
0

Z racji braku czasu pomysł musiał trochę poczekać, szkoda że nie dojrzał do definitywnego wyboru stosu. Chciałbym powrócić jeszcze do tematu warstwy widoku. Nie jestem przekonany do spring + jsp/jsf bo jakoś odrzuca mnie od tych technologii prezentacji z powodu upływu lat i małej estetyczności/możliwości (chyba że się mylę) Trochę próbowałem zgłębic Vaadin ale podobnie jak GWT jest mocno ograniczony narzucając wygląd który imho bardziej nadaje się do aplikacji stricte biznesowych jak np. do eod'ów niż coś w deseń poralu społecznościowego/informacyjnego gdzie jednak wygląd ma bardzo duże znaczenia dla odbiorcy. Czy jednak może w ogóle nie ma sensu się bawić w frameworki widoków, silniki i zrobić to inaczej.. tylko jak ? :)
Heh.. wychodzi na to, że najgorzej jest zacząć, a nie zrealizować cele...

KA
KA
  • Rejestracja:prawie 12 lat
  • Ostatnio:prawie 5 lat
  • Lokalizacja:Warszawa
  • Postów:1683
0

JSF jest fajny i angular. w to celuj. GWT.... nie lubie


PROGRAMY NA ZAMÓWIENIE, ZALICZENIA STUDENCKIE, KONFIGURACJA SERWERÓW, SYSTEMÓW I BAZ DANYCH, STRONY INTERNETOWE, POMOC W PROGRAMOWANIU, POPRAWIENIE I OPTYMALIZACJA APLIKACJI
JAVA, C++, LINUX, WWW, SQL, PYTHON
POSIADAM KOMERCYJNE DOŚWIADCZENIE
TANIO, SZYBKO I PORZĄDNIE
Z KOMENTARZAMI OBJAŚNIAJĄCYMI KOD
PISZ NA PRYWATNĄ WIADOMOŚĆ
CENY JUŻ OD 49,99ZŁ ZA PROGRAM
ZAJMIJ SIĘ TYM CO CIĘ NAPRAWDĘ INTERESUJE!
edytowany 1x, ostatnio: karolinaa
Zobacz pozostałe 7 komentarzy
Maciej Cąderek
Maciej Cąderek
@margor90 ES6 też się kompiluje, przeglądarki nie mają tu nic do rzeczy - zarówno TS jak i ES6 można z powodzeniem używać (i używa się, szczególnie w dużych projektach) od dłuższego czasu.
M9
Skoro się kompilują warto używać ES6 zamiast TS? Jaka jest korzyść? IMO mocne typy są lepsze.
Maciej Cąderek
Maciej Cąderek
@margor90 Zależy, czy potrzebne Ci typy czy nie, kwestia preferencji - mi dynamiczna natura js odpowiada, dlatego nie ciągnie mnie do TypeScriptu.
M9
Ja niestety widzę źródo trudnych do wykrycia błędów jak typy są dynamiczne, raczej można to obejść dobrym przetestowaniem aplikacji. Mało pracowałem na frontendzie.
Maciej Cąderek
Maciej Cąderek
Jak ktoś pracuje w Javie/C# i jest przyzwyczajony do klas, interfejsów i statycznej kontroli typów to TypeScript będzie raczej bezpieczniejszą opcją. Ja jestem "wychowany" na językach dynamicznych i błędy związane z typami to chyba najrzadszy typ błędów jaki mi się zdarza, dlatego od dodatkowych zabezpieczeń wolę prostotę (rzecz względna) i zwięzłość kodu.
M9
  • Rejestracja:prawie 10 lat
  • Ostatnio:prawie 6 lat
1

Poza tym Vaadin jest mocno server-side co powoduje, że nie nadaje się do wszystkich aplikacji. Takie JSF mimo, że również z natury server-side to jednak w PrimeFaces mocno wykorzystuje możliwości klienta. To może być duży atut. Oczywiście są to aplikacje biznesowe.. chyba jednak nie tego szukasz. :)

Co do społecznościówek. Wiele osób poleca Wicket jeśli chcesz mieć framework komponentowy z mocno customowymi własnymi komponentami. Chyba nie muszę wspominać, że taka aplikacja będzie Cię kosztowała znacznie więcej jak JSF czy Vaadin: komponenty same się nie stworzą. :)

Jednak jeśli nie masz kosmicznych wymagań i chcesz coś zrobić w miarę szybko i nie przeszkadza Ci praca w sesji (stanowość) to polecam zestaw JSF, EJB3, JPA2, PrimeFaces. Ale jak już wspomniałem to świetnie się sprawdza w biznesówkach, w społecznościówkach niekoniecznie.

T9
  • Rejestracja:ponad 13 lat
  • Ostatnio:około 3 lata
  • Postów:48
0

Czyli ogólnie wykorzystać cały potencjał JEE, bez modzenia w dodatkowe zabawki? Skoro pojawiła się propozycja PrimaFace, to mam pytanie czy wygląd komponentów jest edytowalny, czy np button zawsze będzie wyglądał tak jak w demo. Miałby ktoś jakiś fajny przykład tak zrobionej aplikacji? Co coś ogólnodostępnego może wykorzystywać tę technologię?

niezdecydowany
niezdecydowany
"to mam pytanie czy wygląd komponentów jest edytowalny, czy np button zawsze będzie wyglądał tak jak w demo" przecież to zwykłe css'y ..
0

Spring boot na backendzie
JS i html5 na froncie

Kliknij, aby dodać treść...

Pomoc 1.18.8

Typografia

Edytor obsługuje składnie Markdown, w której pojedynczy akcent *kursywa* oraz _kursywa_ to pochylenie. Z kolei podwójny akcent **pogrubienie** oraz __pogrubienie__ to pogrubienie. Dodanie znaczników ~~strike~~ to przekreślenie.

Możesz dodać formatowanie komendami , , oraz .

Ponieważ dekoracja podkreślenia jest przeznaczona na linki, markdown nie zawiera specjalnej składni dla podkreślenia. Dlatego by dodać podkreślenie, użyj <u>underline</u>.

Komendy formatujące reagują na skróty klawiszowe: Ctrl+B, Ctrl+I, Ctrl+U oraz Ctrl+S.

Linki

By dodać link w edytorze użyj komendy lub użyj składni [title](link). URL umieszczony w linku lub nawet URL umieszczony bezpośrednio w tekście będzie aktywny i klikalny.

Jeżeli chcesz, możesz samodzielnie dodać link: <a href="link">title</a>.

Wewnętrzne odnośniki

Możesz umieścić odnośnik do wewnętrznej podstrony, używając następującej składni: [[Delphi/Kompendium]] lub [[Delphi/Kompendium|kliknij, aby przejść do kompendium]]. Odnośniki mogą prowadzić do Forum 4programmers.net lub np. do Kompendium.

Wspomnienia użytkowników

By wspomnieć użytkownika forum, wpisz w formularzu znak @. Zobaczysz okienko samouzupełniające nazwy użytkowników. Samouzupełnienie dobierze odpowiedni format wspomnienia, zależnie od tego czy w nazwie użytkownika znajduje się spacja.

Znaczniki HTML

Dozwolone jest używanie niektórych znaczników HTML: <a>, <b>, <i>, <kbd>, <del>, <strong>, <dfn>, <pre>, <blockquote>, <hr/>, <sub>, <sup> oraz <img/>.

Skróty klawiszowe

Dodaj kombinację klawiszy komendą notacji klawiszy lub skrótem klawiszowym Alt+K.

Reprezentuj kombinacje klawiszowe używając taga <kbd>. Oddziel od siebie klawisze znakiem plus, np <kbd>Alt+Tab</kbd>.

Indeks górny oraz dolny

Przykład: wpisując H<sub>2</sub>O i m<sup>2</sup> otrzymasz: H2O i m2.

Składnia Tex

By precyzyjnie wyrazić działanie matematyczne, użyj składni Tex.

<tex>arcctg(x) = argtan(\frac{1}{x}) = arcsin(\frac{1}{\sqrt{1+x^2}})</tex>

Kod źródłowy

Krótkie fragmenty kodu

Wszelkie jednolinijkowe instrukcje języka programowania powinny być zawarte pomiędzy obróconymi apostrofami: `kod instrukcji` lub ``console.log(`string`);``.

Kod wielolinijkowy

Dodaj fragment kodu komendą . Fragmenty kodu zajmujące całą lub więcej linijek powinny być umieszczone w wielolinijkowym fragmencie kodu. Znaczniki ``` lub ~~~ umożliwiają kolorowanie różnych języków programowania. Możemy nadać nazwę języka programowania używając auto-uzupełnienia, kod został pokolorowany używając konkretnych ustawień kolorowania składni:

```javascript
document.write('Hello World');
```

Możesz zaznaczyć również już wklejony kod w edytorze, i użyć komendy  by zamienić go w kod. Użyj kombinacji Ctrl+`, by dodać fragment kodu bez oznaczników języka.

Tabelki

Dodaj przykładową tabelkę używając komendy . Przykładowa tabelka składa się z dwóch kolumn, nagłówka i jednego wiersza.

Wygeneruj tabelkę na podstawie szablonu. Oddziel komórki separatorem ; lub |, a następnie zaznacz szablonu.

nazwisko;dziedzina;odkrycie
Pitagoras;mathematics;Pythagorean Theorem
Albert Einstein;physics;General Relativity
Marie Curie, Pierre Curie;chemistry;Radium, Polonium

Użyj komendy by zamienić zaznaczony szablon na tabelkę Markdown.

Lista uporządkowana i nieuporządkowana

Możliwe jest tworzenie listy numerowanych oraz wypunktowanych. Wystarczy, że pierwszym znakiem linii będzie * lub - dla listy nieuporządkowanej oraz 1. dla listy uporządkowanej.

Użyj komendy by dodać listę uporządkowaną.

1. Lista numerowana
2. Lista numerowana

Użyj komendy by dodać listę nieuporządkowaną.

* Lista wypunktowana
* Lista wypunktowana
** Lista wypunktowana (drugi poziom)

Składnia Markdown

Edytor obsługuje składnię Markdown, która składa się ze znaków specjalnych. Dostępne komendy, jak formatowanie , dodanie tabelki lub fragmentu kodu są w pewnym sensie świadome otaczającej jej składni, i postarają się unikać uszkodzenia jej.

Dla przykładu, używając tylko dostępnych komend, nie możemy dodać formatowania pogrubienia do kodu wielolinijkowego, albo dodać listy do tabelki - mogłoby to doprowadzić do uszkodzenia składni.

W pewnych odosobnionych przypadkach brak nowej linii przed elementami markdown również mógłby uszkodzić składnie, dlatego edytor dodaje brakujące nowe linie. Dla przykładu, dodanie formatowania pochylenia zaraz po tabelce, mogłoby zostać błędne zinterpretowane, więc edytor doda oddzielającą nową linię pomiędzy tabelką, a pochyleniem.

Skróty klawiszowe

Skróty formatujące, kiedy w edytorze znajduje się pojedynczy kursor, wstawiają sformatowany tekst przykładowy. Jeśli w edytorze znajduje się zaznaczenie (słowo, linijka, paragraf), wtedy zaznaczenie zostaje sformatowane.

  • Ctrl+B - dodaj pogrubienie lub pogrub zaznaczenie
  • Ctrl+I - dodaj pochylenie lub pochyl zaznaczenie
  • Ctrl+U - dodaj podkreślenie lub podkreśl zaznaczenie
  • Ctrl+S - dodaj przekreślenie lub przekreśl zaznaczenie

Notacja Klawiszy

  • Alt+K - dodaj notację klawiszy

Fragment kodu bez oznacznika

  • Alt+C - dodaj pusty fragment kodu

Skróty operujące na kodzie i linijkach:

  • Alt+L - zaznaczenie całej linii
  • Alt+, Alt+ - przeniesienie linijki w której znajduje się kursor w górę/dół.
  • Tab/⌘+] - dodaj wcięcie (wcięcie w prawo)
  • Shit+Tab/⌘+[ - usunięcie wcięcia (wycięcie w lewo)

Dodawanie postów:

  • Ctrl+Enter - dodaj post
  • ⌘+Enter - dodaj post (MacOS)