-
Data: 2009-05-25 08:38:11
Temat: Re: Jak używać wyjštków
Od: gregorius <gruza@spamerom_nie.priv4.onet.pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]somebody pisze:
> Jacek Czerwinski pisze:
>> somebody pisze:
>>> Wiktor Zychla pisze:
>>
>>> nie chodzi o korzystanie z tych gotowych kombajnów. Bardziej chodzi
>>> mi o naukę i poszerzenie wiedzy.
>>>
>>> Przykładowa aplikacja w .net framework to 4 dllki (data, view, mssql,
>>> utils) oraz aplikacja webowa. I interesuje mnie, jak sensownie
>>> wyświetlać użytkownikowi informacje na temat błędnie wpisanych danych
>>> w formularza. Walidatory pól nie są do końca dobrym rozwiązaniem.
>>
>> Szkoły, czy przynajmniej akcenty są nieco rózne.
>> jedna ze szkół "wyjątek to cos wyjątkowego" (w sensie normalne
>> sytuacje robi się normalnie) (np. w javie jak biblioteki i JVM z
>> zasady dośc mocno optymalizują, tak nikt nie optymalizuje obsługi
>> wyjątków. Stwierdzenie stosunkowo oficjalne bo chyba z Joshua Blocha)
>>
>> Inna szkoła: obsługiwać jak najbliżej.
>>
>> A może potrzebujesz po prostu dobrych walidatorów?
>>
>> Zawsze możesz odziedziczyć własne exception, ale to oznacza znów jedną
>> więcej zależność po obu stronach throw/catch.
>
> Jestem świadom, że szkół jest wiele i podejścia mogą być przeciwstawne,
> dlatego najpierw zapytałem o literaturę, aby móc wyrobić sobie jakieś
> własne zdanie.
>
> Walidatory nie wydają się być dobrym rozwiązaniem. Mam np. klienta
> (encja, byt z wycinka rzeczywistości), który posiada numer NIP. Jak
> rozsądnie powinno wyglądać sprawdzenie czy numer wprowadzany przez osobę
> obsługującą aplikację jest poprawny czy też nie?
>
> Teoretycznie może być to walidator w warstwie prezentacji, ale: dla
> warstwy prezentacji jest wzorzec MVP i może się ona zmienić. Zresztą mam
> wrażenie, że warstwa prezentacji nie jest najlepsza do tego. Więc gdzie?
> Niżej? Warstwa logiki? Ale dane są przechowywane w bazie danych i
> lepiej, żeby nikt błędnych insertów (w trakcie programowania) nie
> zrobił. Więc może procedura składowana dla wstawiania rekordu z
> odpaleniem innej procedury dla walidacji? Do zrobienia, jakoś logicznie
> uzasadnione.
[...]
Musisz wyważyć gdzie walidować. Z jednej strony szkoda pisać tę samą
walidację wiele razy, więc teoretycznie można by ją umieścić tylko w
bazie danych (np. walidować za pomocą trigerów). Ale wywołania bazy
danych są wywołaniami zdalnymi, więc ich nadmiar negatywnie wpływa na
wydajność. Więc przeważnie przesuwa się walidację bliżej użytkownika -
do warstwy logiki lub prezentacji. Dla mnie najwygodniej robi się
walidację w warstwie logiki, ale w aplikacjach ASP.NET (o których
wspomniałeś) szkoda generować żądanie z przeglądarki do klienta WWW po
to, żeby za chwilę powiedzieć, że pole nie może być puste.
Pozdrawiam
--
Grzegorz Gruza
Odpowiadając usuń "spamerom_nie." z adresu!!!
Następne wpisy z tego wątku
- 25.05.09 10:27 somebody
Najnowsze wątki z tej grupy
- Grok zaczął nadużywać wulgaryzmów i wprost obrażać niektóre znane osoby
- Can you activate BMW 48V 10Ah Li-Ion battery, connecting to CAN-USB laptop interface ?
- We Wrocławiu ruszyła Odra 5, pierwszy w Polsce komputer kwantowy z nadprzewodzącymi kubitami
- Ada-Europe - AEiC 2025 early registration deadline imminent
- John Carmack twierdzi, że gdyby gry były optymalizowane, to wystarczyły by stare kompy
- Ada-Europe Int.Conf. Reliable Software Technologies, AEiC 2025
- Linuks od wer. 6.15 przestanie wspierać procesory 486 i będzie wymagać min. Pentium
- ,,Polski przemysł jest w stanie agonalnym" - podkreślił dobitnie, wskazując na brak zamówień.
- Rewolucja w debugowaniu!!! SI analizuje zrzuty pamięci systemu M$ Windows!!!
- Brednie w wiki - hasło Dehomag
- Perfidne ataki krakerów z KRLD na skrypciarzy JS i Pajton
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- U nas propagują modę na SI, a w Chinach naukowcy SI po kolei umierają w wieku 40-50lat
Najnowsze wątki
- 2025-07-25 Kraków => Senior Fullstack Engineer (Low-Code Platform) <=
- 2025-07-25 Skrobanie
- 2025-07-25 Lublin => Konsultant ds. Wdrożeń ERP (moduł FK) <=
- 2025-07-25 Warszawa => Senior Frontend Developer (React + React Native) <=
- 2025-07-25 Re: Boeing Bad Dream (Koszmar) Liner rozbity w Delhi ...
- 2025-07-24 Re: Wypadek kolejowy na stacji Wiesiółka- analiza tragicznego zdarzenia z czerwca 2001 roku.
- 2025-07-23 Re: Tysiące wypadków na niebezpiecznych przejazdach kolejowych a Polskie Linie Kolejowe nic nie robią odlat, bo kierowca pociągu nie ginie
- 2025-07-23 Re: Tysiące wypadków na niebezpiecznych przejazdach kolejowych a Polskie Linie Kolejowe nic nie robią odlat, bo kierowca pociągu nie ginie
- 2025-07-23 Teoria Organizacji w Ujęciu Totaliztycznym - NOWA MONOGRAFIA
- 2025-07-24 Warszawa => MENA New Business Manager <=
- 2025-07-24 Środa Wielkopolska => SAP FI/CO Internal Consultant <=
- 2025-07-24 Fundacja Wolność od Religii domaga się wyjaśnień ws zawierzenia Powiatu Wschowskiego Maryi Królowej Polski
- 2025-07-23 Teoria Organizacji w Ujęciu Totaliztycznym - NOWA MONOGRAFIA
- 2025-07-23 Gdańsk => Programista Delphi <=
- 2025-07-23 Gdańsk => Programista Mainframe (z/OS, Assembler) <=