Ana içeriğe atla

.NET Lisans Uygulaması

Merhaba arkadaşlar,bu makalemizde sizlere .net ortamında yazmış olduğunuz programlarınızda lisans kontrolünün ne şekilde yapılabileceği konusunda bilgi vermeye çalışacağım.göstereceğim lisans tekniği internet bağlantısı gerektirmektedir.ftp mize yüklü (yandex disk vb. dosya yüklemeyi sağlayan herhangi bir sağlayıcı da olabilir) xml dosyamızdan ilgili lisans bilgilerini okuyacak,buna göre lisans işlemlerini gerçekleştireceğiz.ilk önce lisans bilgilerini tutacağımız bir xml dosyası hazırlayacağız.

Örnek senaryomuza göre ; programımız ilk açılışta bir lisans anahtarı isteyecek. kullanıcı bu lisans numarasını girdiğinde programımız xml dosyamızın içerisinde lisans anahtarının kontolünü yapacak.eğer lisans anahtarı doğruysa programımız tam sürüm olarak kurulacak(Lisans bitiş tarihine kadar) eğer lisans anahtarımız yanlış ise hata verecek,hiç girilmediyse deneme sürümü olarak kurulacak.isterseniz vakit kaybetmeden kodlarımızı yazmaya başlıyalım.

1.İlk olarak Referans olarak kullanacağımız xml dosyamızı hazırlıyoruz.

yeni bir console veya windows forms projesi açalım ve aşağıdaki kodu kullanarak xml hazırlayalım.
try
{
XmlTextWriter xtw = new XmlTextWriter("License.xml", System.Text.Encoding.GetEncoding("windows-1254")) { Formatting = Formatting.Indented };

                    SqlConnection qcon = new SqlConnection("baglantıcumlesi");
                    qcon.Open();
                xtw.WriteStartDocument();
                xtw.WriteStartElement("License");
                for (int i = 0; i<= 100; i++)
                {
                    xtw.WriteStartElement("Key");
                    xtw.WriteAttributeString("Usage", "False"); --şuanda kullanımda mı ?
                    xtw.WriteAttributeString("StartDate",new DateTime(2014,01,01).ToString()); --geçerli olan başlangıç tariih
                    xtw.WriteAttributeString("EndDate", new DateTime(2014, 12, 31,23,59,59).ToString());--geçerli bitiş tarihi
                    xtw.WriteAttributeString("User", "");--kullanıcı adı
                    xtw.WriteAttributeString("IP", ""); -- lisansın kullanıldığı ip adresi
                    xtw.WriteAttributeString("MACAdress",""); --lisansın kullanıldığı pc nin mac adresi
                    xtw.WriteAttributeString("CompanyName", ""); -- firma adı
                    xtw.WriteAttributeString("Phone", ""); -- telefon
                    xtw.WriteAttributeString("Mail", "");   --mail
                    SqlCommand qcommand = new SqlCommand("SELECT NEWID() AS Deger", qcon); -- sql serverdan aldığımız 64 bitlik guid                    
                    xtw.WriteString(qcommand.ExecuteScalar().ToString().ToUpper()); -- lisans anahtarı (UPPER HALİNE DÖNÜŞTÜRDÜK BÜTÜN KARAKTERLERİ )
                    xtw.WriteEndElement();
                }
                xtw.WriteEndElement();
                xtw.WriteEndDocument();
                xtw.Close();
                qcon.Close();
                MessageBox.Show("Lisans Dosyası Başarıyla Oluşturuldu.");
}
catch(Exception ex)
{
MessageBox.Show("Hata: "+ex.Message);
}

Evet yukarıdaki örnekte de gördüğünüz gibi "SELECT NEWID() AS Deger" Sorgusuyla döngü içerisinde 100 adet guid almak suretiyle xml dosyamızı oluşturduk.dilerseniz sıradaki adıma geçelim;


2.Bu adımda kullanıcının girdiği lisans anahtarının doğrulamasını yapacağız.
        public static bool LisansKontrol(string pstrLisansAnahtari)
        {
            bool qreturn = false;
            WebClient request = new WebClient();
            string url = "Lisans.xml dosyamızın dolu";
            request.Credentials = new NetworkCredential("ftp kullanıcı adı", "ftp şifremiz");
            try
            {
                if (Encoding.GetEncoding("windows-1254").GetString(request.DownloadData(url)).Contains(String.Format(@">{0}", pstrLisansAnahtari)) == true) qreturn = true;
                else qreturn = false;
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }
            return qreturn;
        }

Kısaca açıklayacak olursak; Kullanıcımız lisans anahtarı girdi.Doğrula butonuna bastı.Ftp üzerinden xml dosyamızı indirdik ve kullanıcının girdiği lisans anahtarının dosyamızda olup olmadığını karşılaştırdık.GetString(request.DownloadData(url)) ile xml dosyamızın içeriğini string olarak aldık ve Contains(String.Format(@">{0}", pstrLisansAnahtari) fonksiyonuyla aldığımız bu string ifadenin içerisinde anahtarımızın olup olmadığına baktık. Örnek olarak Lisans anahtarımız 411 ise contains ile aldığımız string ifade içerisinde ">411" şeklinde bir tanımlama olup olmadığını kontrol ettik.eğer varsa fonksiyonumuz geriye "true" yok ise "false" olarak dönüş yaptı.artık 3. adıma geçebiliriz.

3. Adım Lisans Dosyamız üzerinde gerekli güncellemelerin yapılması.
tek bir lisans anahtarının tek bir kullanıcı tarafından kullanılmasını sağlamak ve tarafımızdan takibinin yapılmasını kolaylaştırmak amacıyla lisans dosyamızın ilgili yerlerini update etmemiz gerekir.Bu Sayede hangi lisansın kimin tarafından kullanıldığını,ne zaman aktif edildiğini,ne zaman biteceğini vs. bulabiliriz.
 public  static void LicenseKeyUpdate(string LicenseKey,string KullaniciAdi,string IsletmeAdi,string TelefonNo,string Email)
        {
            try
            {
                WebClient request = new WebClient();
                string url = "xml dosyamız";
                request.Credentials = new NetworkCredential("ftp kullanıcı adı", "ftp şifremiz"); 
                XmlDocument qLicXml = new XmlDocument();
                qLicXml.LoadXml(request.DownloadString(url));
                XmlNodeList qList=qLicXml.SelectNodes("/License/Key");
                DateTime qsunucuzamani = Datetime.Now;
                foreach (XmlNode qnode in qList)
                {
                    if (qnode.InnerText == LicenseKey)
                    {
                        qnode.Attributes["Usage"].Value = "True";
                        qnode.Attributes["StartDate"].Value = qsunucuzamani.ToString();
                        qnode.Attributes["EndDate"].Value = qsunucuzamani.AddMonths(12).ToString();
                        qnode.Attributes["User"].Value = KullaniciAdi;
                        qnode.Attributes["IP"].Value = GetIP();
                        qnode.Attributes["MACAdress"].Value = MACAdresiAl();
                        qnode.Attributes["CompanyName"].Value = IsletmeAdi;
                        qnode.Attributes["Phone"].Value = TelefonNo;
                        qnode.Attributes["Mail"].Value = Email;
                    }
                }
                request.UploadString(url, qLicXml.InnerXml);
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }
        }

XML Dosyamızı indirdik.ilgili düzenlemeleri yaptık ve tekrardan upload ettik.Kullanıcının lisans kaydını yaptıktan sonra lisans anahtarını windows registry'ye yazın.programınız açılırken üstteki kodlar yardımıyla xml dosyasında lisans anahtarını,bitiş süresini vs. aratarak devamını getirebilmeniz mümkündür.
İsterseniz buradaki saat işlemlerini internetten de çekebilirsiniz.bu sayede güvenliği daha da arttırmış olursunuz.Bir sonraki makalemde internet üzerinden saati nasıl kullanabileceğimizi göstermeye çalışacağım.Şimdilik bu kadar.Bir sonraki makalede görüşmek üzere.








Yorumlar

Bu blogdaki popüler yayınlar

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

Devexpress SchedulerControl Kullanımı

Uzun bir aradan sonra merhaba; Sizlere bu makalede Devexpress ürününün en karmaşık kontrollerinden biri olan SchedulerControl nesnesinin kullanımı açıklamaya çalışacağım. Scheduler kontrol adındanda anlaşılacağı üzere tarihsel işlemleri görsel hale getirebileceğimiz detaylı bir kontroldür.zamanlamalı olarak randevu,görev,işlem vb. kavramları scheduler kontrol nesnesiyle kullanabiliriz.bunlarlada sınırlı değil tabiki.isterseniz Microsoft Outlook Takviminede bağlayabilir ve işlem kapsamınızı genişletebilirsiniz.Lafı fazla uzatmadan kodlamaya geçelim isterseniz. bu makaledeki bağlantı ve işlem şekilleri tamamen C# kodları ile yapılmaktadır.dataset vb. kontrolleri kullanmadım. yeni bir windows forms Projesi açalım ve boş bir forma schedulercontrol nesnesini sürükleyip bırakalım. kontrol ekranımıza yerleştiğinde alt kısımda SchedulerStorage isimli nesneyi göreceksiniz.SchedulerStorage SchedulerControl'ün çalışması için gerekli bir nesnedir zira veri işlemleri SchedulerStorage ...

Devexpress ASPxGridView içerisinde ASPxPopupControl Kullanımı

Merhaba, bu makalede sizlere; ASPxPopupControl  nesnesinin ASPxGridView  ile nasıl kullanacağına dair bilgi vermeye çalışacağım. Proje ortamında en sık karşılaştığımız işlemlerden biri, grid üzerinde düzenleme yapabilmektir.  Aslında standartta ASPxGridView  sizlere bu özelliği zaten kendi Edit modları ile sağlamakta. Fakat ASPxGridView üzerinde barındırılmayan ama bu veriler ile ilişkili olan işlemleri gerçekleştirmek için böyle bir yapıya ihtiyacımız var. Örneğin,  öğrencilerin not bilgilerini görüntülediğiniz Grid nesnesi üzerinde, sınav tarihlerini düzenlemek isteyebilirsiniz. İşte bu gibi durumlarda ASPxPopupControl kullanmamız gerekmekte. Örnekte (öğrencilere ait basit birkaç bilgi ile işlem gerçekleştireceğiz) bu işlemleri Client-Side desteğiyle nasıl gerçekleştirebiliriz ona bakalım; İlk olarak aşağıdaki gibi bir html tasarım oluşturalım;