Kategoriler


SON YORUMLAR
Kaan çok eziksin
bsg. yazılımdan anlıyorsan bir işe gir.
İREM
Veri yapıları sınavım var..sınav süresi 30dk ve test..Veri yapılarında bilgili biri ücret karşılığında yardımcı olabilirse çok mutlu olurum..
Eray
29.8.2020 tarihli telefon numaram ile yaptığım yorum, ÖZEL DERS vermek, konu anlatımı yapmak veya freelancer olarak yazılım projelerinde yazılımcı olarak çalışmak içindir. Ödev yaptırmak, sınava girmek gibi isteklere geri dönüş yapmıyorum.
Tatar Ramazan
CLASS (Inheritance, abstract, interface, static) Kurallar: 1- Abstract ve interface classlarda new ile obje oluşturulamaz. Bu kural static sınıflar için de geçerlidir. 2- Statik metotlardan yalnızca statik değişken ve metotlar çağırılır. 3- Sınıfın tüm objeleri statik alanın aynı değerini paylaşır. 4- Sınıftan her obje oluştuğunda statik değişken değeri sıfırlanmaz kaldığı yerden devam eder. 5- Statik alana sınıftan obje oluşturmadan direk ulaşılabilir. 6- Statik değişken her zaman bir değere sahiptir. Nümerik değerler için değer atanmadıysa değeri sıfırdır. 7- Virtual metod, abstract ya da static olamaz. 8- Bir metod ya da properties override edilirken tipi değiştirilmez. 9- Türetilen sınıfta metod override edilmemişse ana sınıftaki içerik geçerli olur. 10- Bir interface uygulayan metod public olmalıdır. 11- Static metod abstract, virtual, override olamaz. 12- Properties?ler abstract ya da virtual olabilir. 13- Türetilen sınıf ana sınıftaki tüm abstract metodları uygulamazsa o da abstract olmalıdır. 14- Abstract metod içeren sınıf da abstract olmalı. 15- Abstract metod otomatikman virtual olur. 16- Türetilen sınıf abstract classtaki tüm metodları uygulamalıdır. 17- Virtual metod birden fazla türetilen sınıfta yeniden tanımlanabilir. 18- Bir sınıf birden fazla interface?i aralarına virgül konularak kullanabilir. 19- Interface tek başına hiçbir uygulama sağlamaz. 20- Abstract metod gövde içermez ve ana sınıf tarafından uygulanamaz. 21- Abstract sınıf içinde statik ya da virtual metod tanımlanabilir. 22- Bir interface metod uygulanırken public değilse başına tanımlandığı interface koyulur. 23- Protected tanımlanan field?a sadece türev sınıf içinden erişilir. 24- Fields (alanlar) virtual ya da abstract olamaz. 25- Interface?ler fields içermez. Properties içerebilir. 26- Bir constructor base ile miras alıyorsa hem aldığı mirası hem kendi içindekini uygular. İçi boşsa yalnızca kalıtım aldığını uygular. Miras alırken de derived (türetilen) classtaki parametre değerini esas alır. 27- Interface metod implemente edilirken override yazılmaz. Override virtual ya da abstract metodlar uygulanırken kullanılır.
World
Hello PIO
PIO
hello world
Tatar Ramazan
2009-10 yıllarında millet maaşını yazardı yüksek miktarlar alırlardı şimdi kimse yazmıyor zavallılar sürünüyorlar. Yanlışsam, durumunuz iyiyse çıkın yanlışlayın beni. Az bir kısmınız mutlu olacak diğerleri kıvransın dursun.
Tatar Ramazan
çok para bayılacaklar osuracaklar, sıçacaklar size zort zort zort...muhahah, puahahah...
tatminsiz
10.000 tl den aşağı çalışmam.

java ve c# ı yalayıp yuttum mssql oracle pl sql ibm db2 biliyorum. projeler yaptım kaç para alcam?
memnun
Muhasebe bölümünden bilişime geçtim 2 ay geride kaldım şimdi geri muhasebeye nakîl verdim ama bu parayı duyunca çallşmaya başladım
muhendis
Eskidendi o çok eskiden..mühendisler artık aç..4 yıllık mühendisim aldığım ücret 5000 tl...
cengiz
Ben de bilmiyorum faidesini...
orhon
ilk önce sql sonra t-sql

Bilgisayar Mühendisleri
Here is the website inspired me to use 
it as a guide when I tried to define 
myself as an engineer candidate a few 
years ago. It really helped me to work
 and study feeling in confidence with 
being on the right way. I suggest this 
website to whom it may direct her/his 
to find the right career path. It 
includes many articles varies from 
real life experiences to detailed 
software engineering issues. But the 
most dignified parts for me are the 
articles in general and career titles.
Son okunan makaleler:
ViewState’in Sunucuda Saklanması
Bilgisayar Mühendisleri Kaç Para Alır?
Bilgisayar Mühendisleri Kaç Para Alır?
En iyi bilgisayar mühendisliği bölümüne sahip üniversiteler
Türkiye'de Bilgisayar Mühendisliğinin Durumu? Bilg. Mühendisliğinin bugünü ve geleceği
Sıralamanız Ne?
Bilgisayar Mühendisi Ne İş yapar? Program Nedir? Çeşitli Sorular?
Bilgisayar Mühendisi Ne İş yapar? Program Nedir? Çeşitli Sorular?
Bilgisayar Mühendisliği Hakkındaki 10 Büyük Yalan!
Soru sormayı bilmek?
En iyi bilgisayar mühendisliği bölümüne sahip üniversiteler
Oracle - Data Cartridges
Bilgisayar Mühendisleri Kaç Para Alır?
Açık Kaynak Kodlu Yazılım (Open Source Software) Nedir?
Imagine Cup 2007 Yazılım Tasarımı Türkiye Finalist'leri Belirlendi
Bilgisayar Mühendisliği Hakkındaki 10 Büyük Yalan!
Bilgisayar Mühendisleri Kaç Para Alır?
Bilgisayar Mühendisi Ne İş yapar? Program Nedir? Çeşitli Sorular?
ASP .NET - The TextBox Control
Hollanda, IT sektöründe ihtiyaç duyduğu en az 40 bin kişilik işgücü ihtiyacını karşılayabilmek için dünyadan iki ülke seçti.

Bilgisayar Mühendisleri Portalı

ViewState’in Sunucuda Saklanması

 

ASPNET uygulamaları, doğaları gereği, Win32 ortamı içinde çalışan Windows Forms uygulamalarından oldukça farklı yönlere sahiptirler: Bir ASPNET uygulamasının görüntü ve durumunu saklaması, her ne kadar Windows Forms uygulamalarına öykünse de, bir web programcısı için çok farklı yollara başvurma gereği ortaya koyar. Session ve Application objeleri, uygulamayı geliştiren kişinin en önemli olanaklarını belirlemektedir. Ancak pek çok programcı, bunların yanında yadsınamayacak bir değer taşımakta olan ViewState’in varlığını hiçe saymakta, ya da ona değerinin çok altında bir önem vermektedir. Bu makale sizlere ViewState’i genel olarak tanıtacak, alternatif örneklerle, kullanımı konusunda temel bilgiler verecektir.

İçerik:

  • Genel olarak ViewState
  • Getirileri ve götürüleri
    • Performans
    • Güvenlik
  • ViewState’in kullanımı
  • Kullanıma yönelik alternatifler
    • Sunucuda Saklamak
      • Server’ın diski üzerinde saklamak
      • SQL server ya da benzeri bir veri kaynağını kullanmak
      • DataSet ve Session objeleri üzerinde saklamak

Genel Olarak ViewState

ASP.NET ile uygulama geliştirmek, tanımı ve çalışma şekli gereği, “HTML çıktısı veren bir uygulama yazmak” olarak algılanabilir. Bu durum uygulama geliştiricinin, ASP.NET’in üretmekte olduğu HTML’in sunumunu yapmakta olan IIS ile browser arasında, sürekli veri gidiş-gelişlerini düşünmesini gerektirir. Gerçekte her bir Page objesi, Init event’i ve PreRender event’leri arasında oluşturulur, HTML çıktısı hazırlanır, ve bu çıktı browser’a gönderildiği anda dispose edilir. Dolayısıyla hiçbir zaman, bir önceki durumunu kendi başına hatırlayabilen bir Page objesinden söz edilemez. Programcı, Page objesine bu gidiş-gelişlerden herhangi biri sırasında, eski durumunu hatırlaması konusunda yardımcı olabilmek için ViewState ya da benzeri ortak bir depoya başvurmak zorundadır.

Getirileri ve Götürüleri

Performans

ViewState’in kullanımı default olarak etkin durumdadır. Kullanımı sırasında, Session ve Application objelerinin kullandığı sunucu kaynağından daha az kaynak tüketir. Çünkü sunucu, veri tutma işini browsera verdiği ve her seferinde geri aldığı ViewState datasını, sadece Init sırasında deserialize etmek, ve PreRender sırasında, istemciye HTML göndermeden hemen önce serialize etmek dışında bir kaynak kullanmadığı için daha az hafıza harcayacaktır. Herhangi bir session sırasında bazen yüzlerce kere Page oluşturulmakta, ve dispose edilerek hafızadan atılmaktadır. ViewState de Page’in bir parçasıdır.

Hafıza kullanımının azalmasına rağmen ağ performansı konusunda pek iyimser olmak mümkün değildir: ViewState her bir PostBack işlemi sırasında ağ üzerinden istemciye gönderilmek ve geri alınmak zorundadır. Sayfalara bölünmüş, büyük miktarda veri içeren datagridlerin kullanımı örnek olarak gösterilirse, ViewState’in kilobyte’larca yer tutarak ve sayfayla birlikte taşınarak ağ üzerindeki performansı önemli ölçüde azaltabildiği gözlenebilir.

Güvenlik

ViewState browser’a gönderilen bir string’den oluşmakta olduğundan ve sadece Base64 olarak çevrimi yapıldığından, içeriğinin bir programcı tarafından çalınması mümkündür. Ancak sanılanın aksine, browser’dan sunucuya gönderilecek viewstate verisinin değiştirilmesi ile sunucunun kandırılması pek mümkün değildir. Bunun nedeni, yine sayfa üzerinde tanımlı özelliklerden enableViewStateMAC’ın default olarak “True” olmasıdır. (Pek çok kaynakta bu default değer “False” olarak belirtilse de gerçekte “True” değeri almaktadır.)

Browser’dan sunucuya gönderilmekte olan viewstate verisi, sadece temel güvenlik kriterleri izlendiğinde (Kredi kartı vb. gibi bilgilerin ViewState verisinin içine yerleştirilmemesi) doğal olarak bir güvenlik açığı yaratmayacaktır.

ViewState’in Kullanımı

ViewState’in ağ performansına yönelik negatif etkileri nedeniyle kullanımı konusunda belli kriterler ya da alternatifler getirmek yerinde olur:

  • Sabit sayfalarda enableViewState özelliği değerini “False”’a çevirmek.
  • Sayfa üzerinde state’in hatırlanması işlemini ViewState yerine, Session ya da Application objeleri ile taşınacak verilerle belirlemek.
  • Tüm sayfanın enableViewState’ini iptal etmektense, belli kontrollerin ViewState kullanmasını engellemek.

Kullanıma Yönelik Alternatifler

ViewState’in network performansı üzerindeki negatif etkisini azaltmak amacıyla bazı alternatif kullanım şekilleri geliştirilebilir. Bu yolda atılması gerekli en önemli adım, Page nesnesi tarafından ViewState’in nasıl kullanıldığının anlaşılmasıdır.

Sunucuda Saklamak

Page class’ı üzerinde ViewState’in alınması için yazılmış ve Page’den türettiğimiz her bir sayfamız tarafından ViewState verilerinin serialize-deserialize edilerek kullanılmasını sağlayan iki adet virtual metot bulunmaktadır:

protected virtual object LoadPageStateFromPersistenceMedium()

ve

protected virtual void SavePageStateToPersistenceMedium(object viewState)

Bu metotlar, LosFormatter adlı, sadece sayfa üzerindeki ViewState nesnesinin (StateBag class’ı) serialize ve deserialize edilmesi için geliştirilmiş bir metot kullanmaktadırlar. LosFormatter’ın kullanımı konusunda bir ipucu yakalamak için, LoadPageStateFromPersistenceMedium metodu içinde olması muhtemel default kodlara şöyle bir göz atalım:

string strViewState = Request.Form["__VIEWSTATE"];
LosFormatter lf = new LosFormatter();
object viewState = lf.Deserialize(strViewState);

Page class’ından türetilmiş sayfamız üzerinde LoadPageStateFromPersistenceMedium ve

SavePageStateToPersistenceMedium metotlarının override edilmesi ve bu metotlar içinde

 

LosFormatter class’ının Deserialize ve Serialize metotlarının kullanılmasıyla sunucu, ViewState verilerini hiçbir şekilde istemciye göndermeden state bilgisini saklayabilir. Bu şekilde hem performans, hem de güvenlik konusunda önemli artı değerler kazanılabilir.

Aşağıda, bu konuda önerilebilecek üç ayrı alternatif hakkında bilgiler bulabilirsiniz:

Sunucunun Diski Üzerinde Saklamak

Sunucuda ya da Web Farm üzerindeki herhangi bir ağ paylaşımında, örneğin “SessionID.SayfaURL.viewState” adlı bir dosya tutulabilir. Aynı session ID’sine sahip tüm dosyalar, session sona erdiğinde silinebilir. Aşağıda bununla ilgili bir örnek bulabilirsiniz:

Örnek, web uygulamasının bulunduğu klasörde “NT AUTHORITY\NETWORK SERVICE” hesabının yazma hakkı bulunan “ViewStateData” adlı bir klasörün bulunduğu kabul edilerek hazırlanmıştır.

Öncelikle ViewState’i saklayacak ve okuyacak her iki virtual metodu da override edelim. Bu iki override işlemi de ViewState’in diskte saklanmasını istediğimiz Page class’ı içinde yapılacaktır:

     protected override void SavePageStateToPersistenceMedium(object viewState)
     {
          LosFormatter lf = new LosFormatter();
          StreamWriter sw = new StreamWriter(Server.MapPath("ViewStateData\\" + GetViewStateFileName()));
          lf.Serialize(sw, viewState);
       sw.Close();
     }

     protected override object LoadPageStateFromPersistenceMedium()
     {
            LosFormatter lf = new LosFormatter();
            StreamReader sr = new StreamReader(Server.MapPath("ViewStateData\\" + GetViewStateFileName()));
            string strViewState = sr.ReadToEnd();
            sr.Close();

            return lf.Deserialize(strViewState);
     }

     private string GetViewStateFileName()
     {
            string sessionID = Session.SessionID;
            string pageURL = Request.Url.Segments[Request.Url.Segments.Length - 1];
            return sessionID + "." + pageURL + ".viewState";
     }

SavePageStateToPersistenceMedium metodu, LosFormatter ve StreamWriter kullanarak, ve en altta belirlediğimiz GetViewStateFileName metodundan aldığı string’e dayanarak dosya yoksa oluşturacak, varsa da üzerine yazarak, içeriğinde ViewState verilerinin string olarak kalmasını sağlayacaktır.

LoadPageStateFromPersistenceMedium metodu ise ViewState’i string olarak alıp, yine LosFormatter aracılığıyla StateBag objesine dönüştürecektir.

Son olarak, Session bittiğinde gereksiz dosyaları silme işlemi de Global class’ı içinde aşağıdaki handler aracılığıyla yapılabilir:

     protected void Session_End(Object sender, EventArgs e)
     {
            string sessionID = Session.SessionID;
            System.IO.DirectoryInfo dir = new System.IO.DirectoryInfo(Server.MapPath("ViewStateData"));         
              System.IO.FileInfo[] files = dir.GetFiles(sessionID + ".*");

            foreach (System.IO.FileInfo file in files)
            {
                 file.Delete();
            }
     }

SQL Server ya da Benzeri Bir Data Kaynağı Kullanmak

ViewState’in SQL sunucusunda bir tabloda saklayarak connected senaryo ile almak da performansı arttıracak başka bir yöntem olarak düşünülebilir.

Öncelikle SessionID, PageURL ve ViewState sütunlarından oluşan bir tablo belirlenmeli ve SavePageStateToPersistenceMedium metonunun bu tabloya yazarak ViewState’i saklaması, LoadPageStateFromPersistenceMedium metodunun da bu tabloda tarama yaparak ViewState verisini alması sağlanmalıdır:

protected override void SavePageStateToPersistenceMedium(object viewState)
{

      SqlConnection cn = new SqlConnection("data source=localhost;database=ViewStateDemo;trusted_connection=true");
       LosFormatter lf = new LosFormatter();

       StringWriter sw = new StringWriter();
       lf.Serialize(sw, viewState);
       System.Text.StringBuilder sb = sw.GetStringBuilder();
       string strViewState = sb.ToString();
       string strSessionID = Session.SessionID;
       string strPageURL = Request.Url.Segments[Request.Url.Segments.Length - 1];

       if (SatirVarMi())
       {
            SqlCommand cmd = new SqlCommand("update ViewStateData set ViewState = @ViewState where SessionID = @SessionID and                PageURL = @PageURL", cn);
            cmd.Parameters.Add("@ViewState", strViewState);
            cmd.Parameters.Add("@SessionID", strSessionID);
            cmd.Parameters.Add("@PageURL", strPageURL);

            try
            {
                 cn.Open();
                 cmd.ExecuteNonQuery();
            }

            catch (SqlException exp)
            {
                 throw exp;
            }

            finally
            {
                 cn.Close();
            }
       }

       else
       {
            SqlCommand cmd = new SqlCommand("insert ViewStateData (SessionID, PageURL, ViewState) values (@SessionID,                @PageURL, @ViewState)", cn);
            cmd.Parameters.Add("@ViewState", strViewState);
            cmd.Parameters.Add("@SessionID", strSessionID);
            cmd.Parameters.Add("@PageURL", strPageURL);

            try
            {
                 cn.Open();
                 cmd.ExecuteNonQuery();
            }

            catch (SqlException exp)
            {
                 throw exp;
            }

            finally
            {
                 cn.Close();
            }
       }
     }

protected override object LoadPageStateFromPersistenceMedium()
{
       SqlConnection cn = new SqlConnection("data source=localhost;database=ViewStateDemo;trusted_connection=true");
       SqlCommand cmd = new SqlCommand("select ViewState from ViewStateData where SessionID = @SessionID and PageURL =           @PageURL", cn);
       cmd.Parameters.Add("@SessionID", Session.SessionID);
       cmd.Parameters.Add("@PageURL", Request.Url.Segments[Request.Url.Segments.Length - 1]);
       string strViewState;

       try
       {
            cn.Open();
            strViewState = (string) cmd.ExecuteScalar();
       }

       catch (SqlException exp)
       {
            throw exp;
       }

       finally
       {
            cn.Close();
       }

       LosFormatter lf = new LosFormatter();
       return lf.Deserialize(strViewState);
     } 

     private bool SatirVarMi()
     {
       SqlConnection cn = new SqlConnection("data source=localhost;database=ViewStateDemo;trusted_connection=true");
       SqlCommand cmd = new SqlCommand("select count(*) from ViewStateData where SessionID = @SessionID and PageURL =      @PageURL", cn);
       cmd.Parameters.Add("@SessionID", Session.SessionID);
       cmd.Parameters.Add("@PageURL", Request.Url.Segments[Request.Url.Segments.Length - 1]);
       int rowCount;

       try
       {
            cn.Open();
            rowCount = (int) cmd.ExecuteScalar();
       }

       catch (SqlException exp)
       {
            throw exp;
       }

       finally
       {
            cn.Close();
       }

       if (rowCount == 1)
            return true;
       else
            return false;
     }

Son olarak düşünülmesi gereken, Session bittiğinde SQL’den gereksiz satırların silinmesidir. Bu işi de Global class’ı içinde aşağıdaki gibi halletmek mümkündür:

protected void Session_End(Object sender, EventArgs e)
{
     SqlConnection cn = new SqlConnection("data source=localhost;database=ViewStateDemo;trusted_connection=true");
       SqlCommand cmd = new SqlCommand("delete ViewStateData where SessionID = @SessionID", cn);
       cmd.Parameters.Add("@SessionID", Session.SessionID);

       try
       {
            cn.Open();
            cmd.ExecuteNonQuery();
       }

       catch (SqlException exp)
       {
            throw exp;
       }

       finally
       {
            cn.Close();
       }

DataSet ve Session Objeleri Üzerinde Saklamak

Son olarak farklı bir alternatif, ViewState’in Session objesi üzerinde bir dataset’te tutulması düşünülebilir. Aşağıda bu alternatifle ilgili örnek kodlar bulabilirsiniz:

Öncelikle DSViewState adında bir typed-dataset oluşturalım:

Bu DataSet’in, oluşan her bir yeni session’da bir instance olarak saklanması ve içindeki tabloya viewstate verilerinin DataRow’lar halinde eklenmesi ya da değiştirilmesi ile viewstate yine sunucu tarafında ram’de saklanabilecektir.

Global class’ı içinde aşağıdaki gibi bir Session değişkeni içinde dataset oluşturularak tüm session içinde bu değer kullanılabilir:

protected void Session_Start(Object sender, EventArgs e)
{
      DSViewState ds = new DSViewState();
       Session["dsViewState"] = ds;
}

ViewState’in dataset’te saklanması istenen Page class’ı içinde de aşağıdaki override işlemleri yapılarak da bu alternatif kullanılabilir.

protected override void SavePageStateToPersistenceMedium(object viewState)
{
     LosFormatter lf = new LosFormatter();
     StringWriter sw = new StringWriter();
     lf.Serialize(sw, viewState);
     System.Text.StringBuilder sb = sw.GetStringBuilder();
     string strViewState = sb.ToString();
     string strPageURL = Request.Url.Segments[Request.Url.Segments.Length - 1];
     DSViewState ds = (DSViewState) Session["dsViewState"];

     if (ds.ViewStateData.Rows.Contains(strPageURL))
     {
          DataRow row = ds.ViewStateData.Rows.Find(strPageURL);
          row["ViewState"] = strViewState;
     }
     else
     {
          DataRow row = ds.ViewStateData.NewRow();
          row["PageURL"] = strPageURL;
          row["ViewState"] = strViewState;
          ds.ViewStateData.Rows.Add(row);
     }
}

protected override object LoadPageStateFromPersistenceMedium()
{
     DSViewState ds = (DSViewState) Session["dsViewState"];
     string strPageURL = Request.Url.Segments[Request.Url.Segments.Length - 1];
     DataRow row = ds.ViewStateData.Rows.Find(strPageURL);
     string strViewState = (string) row["ViewState"];
     LosFormatter lf = new LosFormatter();
     return lf.Deserialize(strViewState); 
}

Sonuç olarak, örneklemeye çalıştığım bu üç alternatifle, ViewState ağ performansı negatif olarak etkilenmeden kullanılabilecek, daha hızlı çalışan ve ViewState’ten dilediğince yararlanan web uygulamaları geliştirmek mümkün olabilecektir.

Bu makaleyi beğendin mi? Yorumunu Yaz!







Sizden Gelen Yorumlar:

Yorum Yazın

Tolga(30.6.2013 13:26:34)
ViewState.lerle uğraşmak bazen problem olabiliyor.Bununla uğraşmaktan sıkılanlar için en iyisi biran önce ASP.NET MVC . e geçiş yapmak .
%75 %25 %0
Katılıyorum Çekimserim Katılmıyorum



Hüseyin Yıldırım(31.10.2012 15:24:19)
Session alanı oluşturup sessionu düşenleri sildirmek sorunu çözer diye düşünüyorum.
%0 %0 %0
Katılıyorum Çekimserim Katılmıyorum



Ozan GÖKGÖZ(14.7.2011 13:02:09)
Hocam makale güzelde kullanıcı tarayıcı şak diye kapattı.. Bunun gibi bir günde 100 kişi yapsa 100 dosya....
%100 %0 %0
Katılıyorum Çekimserim Katılmıyorum






Copyright© 2001-2024. Bilgisayar Mühendisleri Portalı | Bütün hakları saklıdır.