.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 ->

Leave a Comment

E-posta hesabınız yayımlanmayacak. Gerekli alanlar * ile işaretlenmişlerdir