.Net Core Eğitimleri

10- ) Web Api Projesi 1. Kısım

Business Katmanı

Projenin şuana kadar mimarisini oluşturduk, artık web api mizi yani iş katmanımızı kodlayabiliriz. İş katmanı bizim uygulamamızın ne iş yapacağını ve ne senaryolar ile çalışacağını yani işin kendisini kodladığımız yerdir. Bu katman logic ve business katmanı olarak da anılabilir.

Dependency Injection mantığını kullanabilmek adına controllerlarımızın hepsinin ne tür metotlar içereceğini yani metot imzalarını kodlayacağımız interfaceler oluşturacağız. Bunun için web api projesine solution explorer üzerinden sağ tıklayalım ve Interfaces isminde bir klasör oluşturalım. Oluşturduğumuz klasörün üzerine sağ tıklayarak Add –> NewItem diyelim dosya tipimizi Interface işaretleyelim ve Name alanına ILanguageController yazarak kaydedelim.

Controllerların Oluşturulması

Daha sonra ILanguageController.cs dosyasına çift tıklayalım ve içeriğini aşağıdaki şekilde düzenleyelim. Aşağıdaki kodu dikkatli inceleyecek olursanız IApiController Interface inden kalıtım alıyor bu nedenle ortak tüm metot imzaları zaten buraya geleceği için ekstra olarak aynı kodları tekrar yazmamıza gerek yok. Aklınıza neden o zaman bu interface’i oluşturduk sorusu gelebilir, birinci nedeni bu controller içinde farklı ve kendisine özgü metotlar yazabiliriz, ikinci neden ise dependency injection yaparken bu interface üzerinden instance alacağız.

Daha sonra Web api projemiz içerisinde bulunan Controllers sınıfına sağ tıklıyoruz ve Add –> Class diyerek Name kısmına LanguageController yazarak kaydediyoruz. Bu sınıf yukarıda oluşturduğumuz ILanguageController arayüzünden kalıtım alacak. LanguageController.cs dosyamıza çift tıklıyoruz ve içeriğini aşağıdaki şekilde düzenliyoruz.

Yukarıdaki controller içerisinde sadece CheckDublicateLanguage isminde bir metot var geri kalanlar ApiBase üzerinde kodlanmış durumda, api base generic bir sınıf olduğu için içerisine Language entitymizi, LanguageDto sınıfımızı ve Controller’ın kendisini gönderiyoruz. Eğer bu controller diğerlerinden bağımsız bir işlem yapacak ise ya da var olan ortak metotlardan (baseden gelen Add,Update,Delete,Find .. vs gibi) birini override edecek ise sınıfın içerisinde bu kodlamayı yapmamız gerekir. Farklı metotları tabiki bu kısma yazmadan önce interface içerisinde kodlamamız önemli.

LanguageController ile işlemleri bitirdiğimizde ApplicationUserController’ı oluşturacağız. Bu sınıf bizim, Identity yapısını kullanarak kullanıcı işlemleri yapmamızı sağlayacak. Kullanıcı ekleme,silme,güncelleme .. gibi ortak özelliklerin yanında bir sonraki derste göreceğimiz şifre değiştirme, mail adresi üzerinden kullanıcı bulma gibi ekstra metotları da içerecek. Öncelikle interfaceimizi oluşturacağız, bunun için web api projemize içinde bulunan Interfaces klasörüne solution explorer üzerinden sağ tıklıyoruz ve Add –> New Item diyerek, dosya tipi olarak Interface’i seçip Name alanına IUserController yazarak kaydediyoruz.

IUserController.cs dosyasına çift tıklayalım ve aşağıdaki şekilde içeriğini güncelleyelim.

Şimdi sıra UserController’ın kendisini oluşturmaya geldi bu sınıf az önce oluşturduğumuz IUserController arayüzünden kalıtım alacak. Solution explorer üzerinden wep api projemiz altında bulunan Controller klasörüne sağ tıklayalım ve Add –> Class diyerek Name alanına UserController yazıp kaydedelim. Daha sonra UserController.cs dosyasına çift tıklayarak içeriğiniz aşağıdaki şekilde düzenliyoruz.

Son olarak web api projemiz içinde bulunan startup.cs dosyasında çeşitli tanımlamalar yapacağız. Solution explorer üzerinde web api projemiz altında bulunan startup.cs dosyasını bulalım ve çift tıklayarak içini aşağıdaki şekilde güncelleyelim.

Projeyi Ateşliyoruz

Tüm işlemleri tamamladığımızda artık projeyi çalıştırıp test edebiliriz.

Klavyeden F5 tuşuna ya da debug menüsünden start debugging seçeneğine basalım. Uygulamamız çalıştığında tarayıcıda otomatik olarak açılacak ancak karşınıza tarayıcı ekranında 404 not found ibaresi gelecektir. İleriki derslerde projeye swagger kuracağız ve ilk açılışta swagger’ın gelmesini sağlayacağız. Şimdilik ilk testimizi yapmak için tarayıcıda adres satırında uygulamamızın adresinden sonra /Languages/GetAll yazalım ve entera basalım. (benim bilgisayarımda http://localhost:61025/language/getall bu link ile çalışıyor ancak sizde port farklı olabilir.) Eğer tüm işlemler doğru ise karşınıza aşağıdaki gibi bir ekran gelmeli.

Postman ile Testler

Şimdi bir de post örneği yapalım. Bunun için ben postman isimli uygulamayı kullanacağım ve anlatımı onun üzerinden yapacağım. Siz farklı bir uygulama ya da chrome üzerinden bir plug-in seçebilirsiniz, ekranlar aşağı yukarı aynı olacaktır. Postman’ı açtıktan sonra aşağıdaki ekran görüntüsünü takip edelim ve yeni bir dil eklemeyi deneyelim. Business katmanımızda yazdığımız dublicate kontrol sayesinde aynı culture değerine sahip iki farklı kayıt eklememiz engellenmiş olmalı. Deneyip sonucu görelim.

Yukarıdaki adımları tamamladığımız da ilk denememizde sonuç kısmında aşağıdaki şekilde bir görüntü görmeliyiz.

Body kısmında gönderdiğimiz Json içeriği değiştirmeden tekrar Send butonuna basarsak bu sefer aşağıdaki ekranın bizi karşılaması gerekiyor.

Aynı şekilde Yeni bir user eklemek için gereken bilgileri alt kısma yazıyorum. Postman ya da diğer rest tester uygulamaları üzerinden aşağıdaki adımları takip ederek kullanıcı eklemeyi deneyebilirsiniz. Bu işlemlerden sonra mutlaka veritabanınızı kontrol edin ve kayıtların oluşup oluşmadığınız gözlemleyin.

Kullanıcı eklemek için yapılması gerekenler;

1-) Url kısmına –>  http://localhost:61025//User/AddAsync  yazıyoruz ancak dikkat edin sizin uygulamanız farklı bir portta çalışıyor olabilir benim portum 61025.

2-) Body kısmına aşağıdaki JSON’ı yapıştırın ve içeriğini istediğiniz gibi düzenleyin. Language Id kısmına önceden eklediğiniz bir dilin Id sini yazın.

{
“emailConfirmed”: true,
“email”: “test@test.com”,
“userName”: “testuser”,
“password”: “Abc.123”,
“phoneNumber”: “112233445”,
“title”: “Manager”,
“phoneNumberConfirmed” : true,
“languageId” : “fe15e038-a5d4-450a-8c0c-b83d2f502f48”
}

Bir sonraki derste Identity alt yapısını kullanarak kullanıcı işlemlerini(sil,güncelle .. vs) tamamlayacak  ve rol işlemlerini göreceğiz.

Projenin buraya kadar olan kısmı ile ilgili sorun yaşıyorsanız bu link ile github üzerinden projeyi indirebilir ve kendi yazdığınız kodlar ile karşılaştırabilirsiniz. Sorularınız için yorum kısmını kullanabilir ya da mail adresim üzerinde benimle iletişime geçebilirsiniz.
Mail Adresim : mehmetalierol@windowslive.com

<- Önceki Post – Sonraki Post ->

.Net Core Eğitimleri

5-) Dto Katmanı ve AutoMapper

Dto Katmanı

Bu derste entitylerimiz ile veritabanından aldığımız verileri aktaracağımız ve ekleme,silme,güncelleme işlemleri öncesi verileri tutacağımız “Dto” katmanımızı oluşturacağız ve AutoMapper ‘ı projemize dahil edeceğiz. “Data transfer object” ler içlerinde business kod bulundurmazlar görevleri sadece verileri taşımak ve geçici olarak saklamaktır. Şimdi “Solution Explorer” içinden “Dto” projemize sağ tıklayalım “Add –> Class” diyerek yeni bir sınıf oluşturalım ve “OrganizationDto” olarak isimlendirelim. Artık yeni dosya oluşturma ekranlarını eklemeye gerek görmüyorum ancak bu konuda takıldığınız bir durum olur ise önceki derslere dönerek ekran görüntülerine bakabilirsiniz.

Dto Sınıflarının Oluşturulması

“Common” projesini oluştururken hazırladığımız “DtoBase” sınıfı oluşturduğumuz tüm “Dto” sınıfları için “base class” görevi görecek yani tüm “Dto” larımız bu sınıftan kalıtım alacak. “DtoBase” sınıfı “Common” projesi altında bulunduğu için “Dto” projemize sağ tıklayarak “Add –> Reference” diyoruz ve açılan pencereden “Common” projesini seçerek ekliyoruz. “OrganizationDto.cs” dosyasına çift tıklayarak içini aşağıdaki şekilde değiştiriyoruz.

Sırası ile aynı yönetmi uygulayarak “CustomerDto, LanguageDto, AppResourceDto, ApplicationRoleDto, ApplicationUserDto, ApplicationUserRoleDto” sınıflarınıda Dto projesine ekleyelim ve içeriklerini aşağıdaki gibi güncelleyelim.

CustomerDto.cs

LanguageDto.cs

AppResourceDto.cs

ApplicationRoleDto.cs

ApplicationUserDto.cs

ApplicationUserRoleDto.cs

AutoMapper

Dto ları ekledikten sonra sıra geldi AutoMapper alt yapısını oluşturmaya. Data katmanında eklediğimiz entityler daha öncede bahsettiğimiz gibi üzerlerinde CRUD işlemler yapmak için oluşturuldu. Görevleri sadece veritabanımızda bulunan tablolarımızı temsil etmek, yani son ana kadar bu sınıflara erişmek istemiyoruz, doğrudan bu katmana bir manipülasyon olmasını tercih etmiyoruz, araya Dto katmanını ekleyerek uygulama içerisinde aksiyon anına gelene kadar (Database gönderilecek CRUD komutları) verileri bu katman üzerinde tutacağız. Bu katmandaki sınıflar olabildiğince basit ve hiç bir şekilde business içermiyor. Peki her seferinde Dto to Entity ya da tam tersi Entity to Dto arasında veri akışını manuel mi kodlayacağız? Eğer hayatımızda AutoMapper çözümleri olmasaydı maalesef her bir sınıf içerisinde tekrar tekrar bu transferleri kodlayacaktık. Birde herhangi bir entitynin değiştiğini düşündüğünüzde bu durum kod yönetimini ve test odaklı yazılım geliştirme döngüsünün olmazsa olmaz refactoring aşamasını olumsuz etkileyecek bir hal alacaktı.

AutoMapper Nasıl Çalışır?

Kodların içerisinde bulunan yorumlarda da yazdığım gibi eğer entity ve dto sınıflarımızın property isimleri ve valueType ları aynı olur ise AutoMapper bu properylerin birbirine eşit olduğunu anlıyor ve hemen iki property arasında kaynak(source) –> hedef(target) ilişkisine göre veri transferi gerçekleştiriyor. Peki property isimleri aynı olmazsa ne oluyor? Burada da devreye AutoMapper’ın profile sınıfı altında bulunan genişletme kodları giriyor. Hedef ve kaynak arasında birbirine eşit propertyleri tek tek tanımlayarak bir mapping oluşturmuş oluyorsunuz ve isimleri aynı olmasa dahi bu iki propertyi maplediğiniz için veri transferi gerçekleşiyor. Herhangi bir property nin aktarılmasını istemiyorsanız ya da aktarılması esnasında değer içinde değişiklik yapmak istiyorsanız yine profile sınıfı içinde genişleme kodları ile bu işlemleri yapabilirsiniz.

AutoMapper Projeye Nasıl Eklenir?

Şimdi AutoMapper’ı projemize eklemek için aşağıdaki ekran görüntüsünde olduğu gibi Dto projemize sağ tıklayacağız ve Manage Nuget Packages diyerek nuget paket yöneticisini açacağız.

AutoMapper paketinin projeye eklenmesi - Mehmet Ali EROL
AutoMapper paketinin projeye eklenmesi

Daha sonra karşımıza gelen ekranda aşağıdaki adımları takip ederek projemize AutoMapper paketini dahil edeceğiz.

AutoMapper paketinin projeye eklenmesi 2 - Mehmet Ali EROL
AutoMapper paketinin projeye eklenmesi 2

AutoMapper Profile ile Mapleme

Bu işlemleri doğru bir şekilde yaptığımızda artık projemize AutoMapper’ı dahil ettik ve bu paketin altında bulunana Profile sınıfını kalıtım alan bir MappingProfile oluşturabiliriz.
Bunun için Dto projesine bir klasör ekliyoruz ve adına Mapper diyoruz (Bu klasörü oluşturmak zorunlu değil ben diğer sınıflardan ayrı bir yerde durmasını istediğim için bu klasörü açtım). Daha sonra bu klasöre sağ tıklayarak “Add –> Class” diyoruz ve oluşturacağımız sınıfın adına MappingProfile yazarak kaydediyoruz. Mapping yapabilmek için Dto projesine Data projesini referans vermeliyiz. Hemen Dto projesine sağ tıklayarak “Add –> Reference” diyoruz ve açılan pencereden Data projesini işaretleyerek kaydediyoruz. Son durumda Dto projemiz hem Common hem de Data projelerine bağımlı hale geldi.

MappingProfile.cs dosyasına çift tıklayarak içerisini aşağıdaki şekilde güncelliyoruz.

Sonuç

Dto ve AutoMapper işlemleri sonrası Solution Explorer Görüntüsü - Mehmet Ali EROL
Dto ve AutoMapper işlemleri sonrası Solution Explorer Görüntüsü

Bu işlemleri yaptığımızda artık Dto katmanımız ve AutoMapper alt yapımız hazır hale geliyor. İşlemleri doğru bir şekilde yaptı ise Solution Explorer üzerinde aşağıdaki gibi bir görüntü görüyor olmalıyız.

Projenin son haline github sayfam üzerinden bu link ile erişebilir ve buraya kadar yaptığımız işlemleri kontrol edebilirsiniz.

<- Önceki Post – Sonraki Post ->

.Net Core Eğitimleri

1) .Net Core Nedir?

.Net Core

.Net Core, Microsoft ‘un açık kaynak kodlu olarak piyasaya sürdüğü bir “framework” tür.

Core öncesinde Microsoft tabanlı ortamlarda geliştirdiğiniz uygulamaları başka platformlar üzerinde koşturmak ya mümkün değildi ya da ekstra uygulamalar ve yöntemler gerektiriyordu. Microsoft, .Net Core ile birlikte bu sorunu ortadan kaldırmakla kalmadı aynı zamanda .Net Framework ile çalışırken karşılaşılan çeşitli sorunları da temizledi diyebiliriz. Örneğin dependency injection yapmak için Core öncesinde 3. parti çözümler kullanmak ve bir sürü ayar yapmak gerekebiliyordu ama artık Core içerisinde dependency injection gibi daha pek çok hayat kurtaran özellik gömülü bir şekilde geliyor. Olay sorunların giderilmesi ile sınırlı kalmıyor, bunların yanında performans üzerinde ciddi iyileştirmeler yapılmış ve tabi tüm bu iyileşmenin altında açık kaynak kod topluluğunun ciddi bir etkisi olduğunu söylemek gerekiyor. Bu link ile önceki sürümler ve .Net Core arasında performans karşılaştırmalarına göz atabilirsiniz.

Artık microsoft tabanlı bir işletim sistemi kullanmadan, visual studio geliştirme ortamına ihtiyaç duymadan gerekli geliştirmeleri yapabilir ve geliştirdiğiniz uygulamaları yine microsoft platformlarına bağımlı kalmaksızın başka ortamlarda çalıştırabiliriz. Core ‘un sürümlerine, sürümler içerisinde ne gibi farklılıkların bulunduğuna Microsoft’un sitesinden bakabilir ve gelişimi detaylıca görebilirsiniz.

Kısaca .Net Core’un temel özelliklerinden bahsettik, fazla detaya girerek gereksiz bilgiler vermek istemiyorum, daha detaylı bilgiye sahip olmak isteyenler mutlaka Microsoft’un sitesinden araştırma yapmalı ve gelinen son noktayı tecrübe etmeli.

Yazı Serisinin Amacı

Bu eğitim adım adım kurumsal bir backend projesinin nasıl yapılacağı ile ilgili bilgi vermek amacı ile hazırlanmıştır. Projeyi en baştan ekran görüntüleri ile birlikte oluşturacağız ve aşağıdaki özellikleri içerecek şekilde tamamlayarak hep birlikte yayına alacağız. Daha sonrasında angular 6 ile frontend tarafında geliştirmeler yapacağız. Ancak o başka bir ders konusu altında olacak. Aşağıda bulunan adımları içeren örnek projeyi bugün itibari ile bitirdim fakat yazıları yazmak ve yayınlamak biraz vaktimi alacak, bu nedenle eğer aşağıda bulunan konulardan herhangi birine ihtiyacınız var ise benimle iletişime geçebilirsiniz, örnek kodları sizinle paylaşabilirim.

Projenin Tanıtımı

Proje Adımları;
1- )    Projemizin oluşturulması ve gereklilikler
2- )    Projenin ana bilgilerini saklayacak common katmanının oluşturulması
3- )    .Net Core Identity ‘nin aktif hale getirilmesi ve code first ile veritabanı tasarımı
4- )    Data Transfer Object (Dto) ‘ların oluşturulması ve Auto Mapper
5- )    Repository ve UnitofWork tasarım desenlerinin eklenmesi
6- )    Web Api projesinin oluşturulması
7- )    ILogger ile dosya sistemine loglama ve AutoHistory ile değişiklik geçmişi
8- )    Usermanager ve Rolemanager ile Identity üzerinde kullanıcı işlemleri
9- )    Jwt token alt yapısı ile kullanıcı authentication alt yapısının kurulması
10- ) Rol bazlı authorization işlemleri
11- ) Web cache kullanımı ve projeye implemente edilmesi
12- ) Web api üzerinde paging alt yapısının kurulması
13- )  SignalR ile canlı veri akışının sağlanması
14- )  Unit testlerin yazılması ve Moq kullanımı
15- ) Swagger

<- Önceki Post – Sonraki Post ->