Kendi Uygulamamızda OWIN

   OWIN makale serisinde, tanışma ardından yazdığımız OWIN katmanlarını önce Katan ardından da IIS üzerinde çalıştırdık. Bu sayede sunucu ve işletim sistemi bağımsız web uygulaması geliştirmenin tadını almaya başladık 🙂 Şimdi de sıra geldi kendi geliştirdiğimiz bir uygulama üzerinden bu OWIN katmanlarını sunmaya.

   Bu makalemde işleyeceğim senaryomda kendi geliştirdiğim basit bir konsol uygulaması üzerinde bir sunucu ayağa kaldırarak OWIN katmanlarımı aynı Katana ve IIS’de olduğu gibi sunmak olacak. Bunun için ilk iş Visual Studio’da “Console Application” şablonu ile basit bir konsol uygulamasını açmak olacak;

Visual Studio'da OWIN konsol uygulamamızı oluşturalım

 

   Sıradaki adım ise OWIN katmanlarımızı sunabilmek için uygulamamıza Microsoft.Owin.Hosting ve Microsoft.Owin.Host.HttpListener NuGet paketlerini eklemek. Bunu için Visual Studio içerisinde Package Manager Console içerisinde aşağıdaki iki satırı çalıştırmamız yeterli;

Install-Package Microsoft.Owin.Hosting -Pre 
Install-Package Microsoft.Owin.Host.HttpListener -Pre

NuGet-Paketleri

   Kurduğumuz bu NuGet paketlerinden Microsoft.Owin.Hosting uygulamamız içerisinde OWIN pipeline’ının ilklendirilmesini ve çalışmasını sağlayacak sınıfları barındırmaktadır, dolayısıyla uygulamamızla birlikte host katmanını oluşturacaktır. Önceki makalelerimizde de kullandığımız Microsoft.Owin.Host.HttpListener paketi ise sunucu katmanımızı oluşturacaktır.

   Uygulamamızda host katmanını oluşturabilmek için Microsoft.Owin.Hosting isim uzayı altında yer alan WebApp sınıfını kullanabiliriz.  Static bir sınıf olan WebApp içerisinde yer alan Start fonksiyonu ise ihtiyacımız olan tek şey…

using System;
using Microsoft.Owin.Hosting;

namespace Enterprisecoding.OWINKonsolUygulamasi {
    class Program {
        static void Main() {
            const string sunucuAdresi = "http://localhost:8080";

            using (WebApp.Start<Startup>(sunucuAdresi)) {
                Console.WriteLine("Sunucu {0} adresinden yayınlandı.", sunucuAdresi);
                Console.WriteLine("durdurmak için herhangi bir tuşa basınız...");
                Console.ReadLine();
            }
        }
    }
}

   Yukarıdaki kod sayesinde konsol uygulamamız içerisinden OWIN pipeline’ını başlatabilir ve web uygulamamızı sunabiliriz. Dikkatinizi çekmiştir; WebApp.Start fonksiyonu generic bir fonksiyon ve bir tür bilgisi beklemekte. Aslında burada beklenen tür bilgisi önceki makalelerimizde kullandığımız ve içerisinde Configuration fonksiyonu olan basit bir sınıf;

using Owin;

namespace Enterprisecoding.OWINKonsolUygulamasi {
    internal class Startup {
        public void Configuration(IAppBuilder app) {
            app.Use(typeof(DinamikCikti));
        }
    }
}

   Bu sınıfın dışarından generic olarak kabul edilmesindeki amaç yapılandırma bilgisinin keskin çizgilerle ayrılmasıdır. Yukarıdaki yapılandırma kodu içerisinde önceki makalelerimde kullandığım DinamikCikti sınıfını kullandım. Referans olması ve makalemdeki kodu hızlıca deneyebilmeniz adına bu sınıfın içeriği aşağıda paylaşmakla birlikte detayları için “OWIN; Hikayenin Devamı” makalemi okumanızı tavsiye ederim.

 using System;
using System.Collections.Generic;
using System.Globalization;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace Enterprisecoding.OWINKonsolUygulamasi {
    using AppFunc = Func<IDictionary<string, object>, Task>;

    public class DinamikCikti {
        private readonly AppFunc birSonrakiKatman;

        private const string YANIT = "<p>{0} adresini talep ettiniz.<br>OWIN katmanından merhaba<p>";

        public DinamikCikti(AppFunc birSonrakiKatman) {
            if (birSonrakiKatman == null) {
                throw new ArgumentNullException("birSonrakiKatman");
            }

            this.birSonrakiKatman = birSonrakiKatman;
        }

        public Task Invoke(IDictionary<string, object> environment) {
            var istekAdresi = (string)environment["owin.RequestPath"];

            var yanitIcerigi = Encoding.UTF8.GetBytes(string.Format(YANIT, istekAdresi));

            var yanitAkisi = (Stream)environment["owin.ResponseBody"];
            var yanitBasliklari = (IDictionary<string, string[]>)environment["owin.ResponseHeaders"];

            yanitBasliklari["Content-Length"] = new[] { yanitIcerigi.Length.ToString(CultureInfo.InvariantCulture) };
            yanitBasliklari["Content-Type"] = new[] { "text/html; charset=UTF-8" };

            return yanitAkisi.WriteAsync(yanitIcerigi, 0, yanitIcerigi.Length);
        }
    }
}

   Kodlamaların bitmesi ardından uygulamamızı çalıştırdığımızda aşağıdaki konsol ekranı bizi karşılayacaktır;

OWIN konsol uygulaması çalışıyor

 

   Sonrasında bir browser üzerinden http://localhost:8080 adresini açacak olursak önceki makalelerimden alışık olduğumuz çıktı bizi karşılayacaktır;

Localhost üzerinden uygulamamızı açtığımızda bizi alışkın olduğumuz bir ekran karşılayacaktır

Fatih Boy

Ankara'da yaşayan Fatih, bir kamu kurumunda danışman olarak çalışmaktadır. ALM süreçleri, kurumsal veri yolu sistemleri, kurumsal altyapı ve yazılım geliştirme konularında destek vermektedir. Boş zamanlarında açık kaynak kodlu projeler geliştirmeyi ve bilgisini yazdığı makalelerle paylaşmayı seven Fatih, aynı zamanda Visual C# ve Visual Studio teknolojileri konusundan Microsoft tarafından altı yıl üst üste MVP (En Değerli Profesyonel) ödülüne layık görülmüştür. İş hayatı boyunca masaüstü uygulamaları, web teknolojileri, akıllı istemciler gibi konularda Asp.Net, Php, C#, Java programlama dilleri ve MySql, MsSql ve Oracle gibi veritabanı yönetim yazılımları ile çalışmıştır. İngilizce ve Türkçe olarak yayınlanan makalelerini gerek İngilizce bloğunda, gerekse de Türkçe bloğunda bulabileceğiniz gibi web sitesinden de açık kaynak kodlu geliştirdiği yazılımlarına ulaşabilirsiniz. vCard - Twitter - Facebook - Google+

Bir Cevap Yazın

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