Ana içeriğe atla

ASP.NET C# Devexpress - Formdan Nesneye / Nesneden Forma Dinamik Veri Almak

Merhaba,

Bu yazımda, projelerimde sıkça kullandığım bir özelliği sizlerle paylaşmak istiyorum. Veri tabanınız üzerinde herhangi bir tabloya ile ilişkili bir web form ekranında standartta INSERT,UPDATE,SELECT işlemlerini yapabilmek için, tek tek kontrolleri ve veri kaynağınızı eşitlemeniz gerekir.

TextBox1.Text=DataRow["Isim"].ToString() gibi. Ekrandaki kontrollerin sayısı arttıkça bu işlemler de uzayıp gider. Null kontrolleri, if deyimleri derken satırlarca kodları yanlızca bilgileri ekranda göstermek veya ekrandaki bilgileri tabloya INSERT veya UPDATE yapmak için kullanırız.

Aşağıdaki yapı sayesinde bu işlemlerin tümünü tek satırda yapabilmeniz mümkün. Reflection mimarisi kullanılarak yazdığım iki fonksiyon sayesinde bu işlemleri çok basit şekilde halledebilirsiniz.

(Bu yapı hem Devexpress hem standart ASP.NET kontrolleri için kullanılabilir.)

Veri tabanınızda bulunan tablonun yansımasını class halinde oluşturun;

vt Tablo ismi = class ismi
vt Kolon ismi = class field isimleri
vt Kolon tipi = class field tipi

ben örneğimde Ogrenci isimli bir tablo oluşturup, Adi,Soyadi,Cinsiyet,DogumYil,KayitAktif isimli kolonları ekledim ve aynı yolu izleyerek class oluşturdum. (Not: Bir sonraki yazımda bu class ları dinamik olarak nasıl oluşturabiliriz öğrenebilirsiniz.)


gelelim butonların kodlama kısmına. "btnBilgileriGetir" butonu, sınıf içerisindeki bilgileri ekrandaki kontrollere aktarırken "btnBilgileriSetEt" butonu da ekrandaki bilgileri sınıf örneğine alma işlemini gerçekleştirecek.
protected void btnBilgileriGetir_Click(object sender, EventArgs e)
    {
        Ogrenci qOgrenci = new Ogrenci()
        {
            Adi = "Ali",
            Soyadi = "Veli",
            Cinsiyet = "Erkek",
            DogumYil = 1990,
            KayitAktif = true
        };
        NesnedenForma(qOgrenci);
    }

    protected void btnBilgileriSetEt_Click(object sender, EventArgs e)
    {
        Ogrenci qOgrenci = new Ogrenci();
        FormdanNesneye(qOgrenci);
    }
İşlemi gerçekleştiren Fonksiyonlar;
public void FormdanNesneye(object pobjData)
    {
        FieldInfo[] qInfos = pobjData.GetType().GetFields();
        if ((qInfos != null) && (qInfos.Length > 0))
        {
            foreach (Control qc in form1.Controls)
            {
                if (qc.ID != null)  //ID null değilse
                {
                    MethodInfo qMInfo = qc.GetType().GetMethod("FindControl"); //FindControl içeriyor mu
                    if (qMInfo != null) //bulunan kontrolde FindControl metodu varsa
                    {
                        foreach (FieldInfo qInfo in qInfos)
                        {
                            Control qMainControl = qc.FindControl(qInfo.Name);
                            if (qMainControl != null)
                            {
                                PropertyInfo qprop = qMainControl.GetType().GetProperty("Value");
                                PropertyInfo qpropText = qMainControl.GetType().GetProperty("Text");
                                PropertyInfo qpropChecked = qMainControl.GetType().GetProperty("Checked");
                                if (qprop != null)
                                {
                                    try
                                    {
                                        qInfo.SetValue(pobjData, qprop.GetValue(qMainControl, null));
                                    }
                                    catch
                                    {
                                        //string qhata = ex.Message;
                                        object cvalue = qInfo.FieldType;
                                        object xvalue = qprop.GetValue(qMainControl).GetType();
                                        if (qInfo.FieldType != qprop.GetValue(qMainControl, null).GetType())
                                        {
                                            try
                                            {
                                                object o = Convert.ChangeType(qprop.GetValue(qMainControl, null), qInfo.FieldType);
                                                qInfo.SetValue(pobjData, o);
                                            }
                                            catch
                                            {
                                            }
                                        }
                                    }
                                }
                                else if (qpropText != null)
                                {
                                    try
                                    {
                                        qInfo.SetValue(pobjData, qpropText.GetValue(qc, null));
                                    }
                                    catch
                                    {
                                        if (qInfo.FieldType != qpropText.GetValue(qc, null).GetType())
                                        {
                                            object o = Convert.ChangeType(qpropText.GetValue(qc, null), qInfo.FieldType);
                                            qInfo.SetValue(pobjData, o);
                                        }
                                    }
                                }
                                else if (qpropChecked != null)
                                {
                                    try
                                    {
                                        qInfo.SetValue(pobjData, qpropChecked.GetValue(qc, null));
                                    }
                                    catch
                                    {
                                        if (qInfo.FieldType != qpropChecked.GetValue(qc, null).GetType())
                                        {
                                            object o = Convert.ChangeType(qpropChecked.GetValue(qc, null), qInfo.FieldType);
                                            qInfo.SetValue(pobjData, o);
                                        }
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }

    public void NesnedenForma(object pobjData)
    {
        FieldInfo[] qInfos = pobjData.GetType().GetFields();
        if ((qInfos != null) && (qInfos.Length > 0))
        {
            foreach (Control qc in form1.Controls)
            {
                if (qc.ID != null)
                {
                    MethodInfo qMInfo = qc.GetType().GetMethod("FindControl");
                    if (qMInfo != null)
                    {
                        foreach (FieldInfo qInfo in qInfos)
                        {
                            Control qMainControl = qc.FindControl(qInfo.Name);
                            if (qMainControl != null)
                            {
                                PropertyInfo qprop = qMainControl.GetType().GetProperty("Value");
                                PropertyInfo qpropText = qMainControl.GetType().GetProperty("Text");
                                PropertyInfo qpropChecked = qMainControl.GetType().GetProperty("Checked");
                                try
                                {
                                    if (qprop != null) qprop.SetValue(qMainControl, qInfo.GetValue(pobjData)); else if (qpropText != null) qpropText.SetValue(qMainControl, qInfo.GetValue(pobjData)); else if (qpropChecked != null) qpropChecked.SetValue(qMainControl, qInfo.GetValue(pobjData));
                                }
                                catch
                                {
                                }
                            }
                        }
                    }
                }
            }
        }
    }
Not: Hata almamak için sayfanıza System.Reflection kütüphanesini eklemeyi unutmayın
Buraya tıklayarak örneği indirebilirsiniz.




Bu blogdaki popüler yayınlar

ASP.NET Sayfalar arası veri taşıma işlemleri

merhaba;

bu yazımda sizlere asp.net üzerinde sayfalar arasında veri taşıma işlemlerinden bahsetmek istiyorum.hepimizin bildiği gibi uygulamarımızda sayfalarımız arası haberleşmeler büyük önem arzetmektedir.bazı sayfalarda bazı işlemlerin yerine getirilebilmesi için diğer sayfalardan gelecek verilere ihtiyaç duyulabilir(GET).ASP.NET üzerinde veri taşıma işlemleri aşağıdaki şekillerde yapılabilir.

1-)QueryString : en yaygın ve basit kullanıma sahip olanıdır.istenilen verileri sayfayı post ettiğiniz zaman yönlendirildiğiniz sayfaya URL üzerinden taşır.

Kullanımı :

a sayfasından b sayfasına isim taşıyalım.

a sayfasında linkinizi şu şekilde değiştirirseniz:
Response.Redirect("gidileceksayfa.aspx?isim=can");
Tarayıcınızın URL kısmına baktığınızda:

www.siteadi.com/b.aspx?isim=canolarak görürsünüz.a sayfasından veri aktarımı tamamlanmıştır.bundan sonraki adım b sayfasından gelen veriyi almaktan ibarettir.o da şu şekilde yapılır:

b sayfasında "isim" adında bir değişken tanıml…

Devexpress Türkçe Dil Paketi

Merhaba,

Devexpress kontrollerinizi türkçe veya  başka bir dil ile kullanmak istiyorsanız Localized assembly leri indirmeniz gerekmektedir.Daha önceleri bu çok zorlu bir süreç oluyordu.internetteki uzun araştırmalar,yanlış veya eksik çeviriler vs. bir sürü problem ile karışılaşıyorduk.nihayet beklediğimiz gibi developer express firması bu soruna el attı ve güzel bir çözüm getirdi.artık https://localization.devexpress.com/ adresi üzerinden devexpress türkçe paketlerini en güncel ve doğru şekliyle hemen indirip kullanabilirsiniz.dil desteğini uygulayabilmek için exe nin bulunduğu path deki dll dosyalarını değiştirmeniz yeterli olacaktır.eski dll dosyaları yerine yeni dil paketindeki dosyaları yapıştırın ve uygulamanızı başlatın.bu hizmeti kullanabilmek için resmi devexpress sitesi olan http://devexpress.com/ 'a üye olmanız gerekmektedir.işlem tamamlandığında indirme linki e-posta adresinize gelmektedir.dil pakedini indirirken talep ettiğiniz paketversiyonun kullandığınız devexpress…

PAYTR SANAL POS ASP.NET C# Entegrasyonu

merhaba, bu makalede sizlere PAYTR Sanal pos yapısını .NET üzerinde nasıl çalıştıracağımız ile ilgili bilgi aktarmaya çalışacağım. Ücretsiz başlangıç sağlaması ve sabit ödeme almaması sebebiyle düşük bütçeli e-ticaret yapmak isteyen kişilerin tercih ettiği PAYTR Sanal pos entegrasyonu temelde PHP üzerine kurulmuş. Dolayısıyla .net ile e-ticaret yazmaktaysanız bu sizi bir hayli zorluyor zira firma ile birçok görüşme yapmama rağmen sağlıklı bir .net örneklemesi bulamadım. Baktım olacak gibi değil, sonunda oturdum kendi entegrasyonumu kendim yazdım :). aşağıda detaylı olarak bulabilirsiniz.

//using satırlarımızı ekleyelim; using Newtonsoft.Json.Linq; using System; using System.Collections.Generic; using System.Collections.Specialized; using System.Data; using System.Linq; using System.Net; using System.Security.Cryptography; using System.Text; using System.Web; using System.Web.Script.Serialization; using System.Web.UI; using System.Web.UI.WebControls; //aşağıdaki sabit PAYTR Fonksiyonla…