07 Nis 2009 Sem Göksu Açık Kaynak Kodlu Blog Sistemi Kategori: Yazılım Etiketler: ASP.NETSem Göksu Blog SistemiSilverlightSQL Server 2005 82 Yorum Sem Göksu Blog SistemiSem Göksu Blog Sistemi ile kendi bloğunuzu oluşturabilirsiniz. Blog içerisinde Caching, SQL Paging, Re-Write Path gibi bir çok konu işlenmiştir. Kullanılan Teknolojiler- ASP.NET 3.5- ASP.NET AJAX 1.0- Silverlight- JavaScript- Enterprise Library 3.0- SQL Server 2005Blog Özellikleri- İçerikler- Makaleler- Kitap Önerileri- Çalışmalar- Silverlight Fotoğfraf Galerisi- Kaynaklar- Takip ettiklerim- IE 8 Hızlandırıcı- RSS - Tema- Arama- Yorum- Arşiv- CMSBlog sistemini indirmek için http://www.semgoksu.com/semgoksu.rar adresini kullanabilirsiniz. Rar dosyası içerisinde bulunan semgoksu.sql isimli dosyayı çalıştırdığınız da veritabanınız hazır olacak. Bloğu kendinize uyarlamak için web.config içerisindeki ayarları yapmanız yeterli olacaktır. Bu ayarlar,Connection StringBloğun kullanacağı veritabanı için gerekli olan ConectionString bilgisi.HostEmail gönderimi için gerekli olan host bilgisi.Email Email'in gönderileceği email hesabı.PasswordEmail adresinin şifresi.SenderEmailGönderilecek olan mail adresi.SiteNameBlog ile ilgili açıklama.SiteOwnerBloğun sahibiSiteLinkBloğun adresi.SiteShortLinkBloğun kısa adresi.AdminUserCMS'e girişte kullanacağınız kullanıcı adı. AdminPassCMS'e girişte kullanacağınız şifre.Bloğu kullandıktan sonra bana bilgi verirseniz çok sevinirim :)
05 Nis 2009 ASP.NET Webinerleri Kategori: Yazılım Etiketler: ASP.NETWebiner 6 Yorum Uzun zamandır ASP.NET ile ilgili webiner düzenlemek istiyordum. Fakat Çağlayan Arıkan'ın bloğunda "Bilenler Bilmeyenlere Bilgisayar Öğretiyor" isimli bir yazı okudum ve aklıma böyle bir webiner dizisi düzenlemek geldi. Anlatmayı düşündüğüm konular aşağıda, eğer eklemek istediğiniz konu ya da konular varsa yazmanız yeterli. Süre konusunda henüz bir planlama yapmadım ama en kısa sürede başlamak istiyorum :)- WEB Uygulamalarına Giriş- ASP.NET Giriş - ASP.NET ile Durum Yönetimi- ASP.NET Web Kontrolleri - 1- ASP.NET Web Kontrolleri - 2- ASP.NET Web Kontrolleri - 3- ASP.NET Data Kontrolleri - 1- ASP.NET Data Kontrolleri - 2- ASP.NET Data Kontrolleri - 3- ASP.NET Validation Kontrolleri - ASP.NET Master Page Kavramı- ASP.NET User Control Kullanımı- ASP.NET Tema Kullanımı- ASP.NET Ajax 1.0
01 Nis 2009 ASP.NET 4.0 - Page.Description ve Page.Keyword Özellikleri Kategori: ASP.NET Etiketler: ASP.NETASP.NET 4.0 3 Yorum Merhaba arkadaşlar bu makale de ASP.NET 4.0 ile Page sınıfına gelen 2 yeni özelliği inceleyeceğiz. Bu özellikler Description ve KeywordsASP.NET 4.0 ile birlikte Page sınıfına Description ve Keyword isimli iki yeni özellik eklendi. Bu özellikleri kullanarak web uygulamalarına keywords ve desctiption meta etiketlerini ekleyebiliyoruz.ASP.NET 4.0 Öncesi ASP.NET 4.0 öncesinde keywords ve description meta etiketlerini <head> etiketi arasına yazabiliyorduk. <headrunat="server"> <title>Page Description ve Page Keyword Özelliği</title> <meta name="keywords" content="Buraya sayfa ile ilgili anahtar kelimeler gelecek..' /> <meta name="description" content="Buraya sayfanın açıklaması gelecek..." /></head>ASP.NET 4.0 YaklaşımıASP.NET 4.0 ile birlikte sayfa direktiflerinden Keywords ve Description özelliğini kullanarak meta etiketini belirleyebiliyoruz. [HTML] <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" Keywords="Anahtar kelimeler…" Description="Sayfa ile ilgili açıklama…"%> Bu bilgilerin veritabanından geleceğini de düşünürsek bu işlemi dinamik olarak da yapabiliriz. [C#] protected void Page_Load(object sender, EventArgs e){ this.Keywords = "Anahtar kelimeler…"; this.Description = "Sayfa ile açıklama…"; } Eğer sayfada head etiketi arasında tanımlı keywords yada description meta etiketi varsa bizim belirlediğimiz bilgiler üzerine yazılacaktır.
19 Mar 2009 ASP.NET MVC Yayınlandı Kategori: Yazılım Etiketler: ASP.NET 0 Yorum Uzun zamandır beklenen ASP.NET MVC sonunda yayınlandı. Bana göre web uygulamarında artık yeni bir trend başlıyor :) Hadi hayırlısı bakalım.ASP.NET MVC ile ilgili detaylı bilgi almak için, http://www.asp.net/mvc/ASP.NET MVC'yi indimek için de aşağıdaki adresi kullanabilirsinizhttp://www.microsoft.com/downloads/details.aspx?FamilyID=53289097-73ce-43bf-b6a6-35e00103cb4b&displaylang=enASP.NET MVCMicrosoft'un ASP.NET için geliştirdiği Model-view-controller iskeleti. Bu iskelet ile ASP.NET uygulamaları, Model, View ve Controller rollerine bölünerek geliştiriliyor. Model (Tanım) uygulamanın üzerinde duracağı meseleyi temsil ediyor. Controller, Model üzerindeki operasyonları tarif eden roldür. View ise, gerekli bilginin görünümünden sorumludur.
19 Mar 2009 ASP.NET 4.0 – Kontroller için ClientIDMode Özelliği Kategori: ASP.NET Etiketler: ASP.NETASP.NET 4.0 3 Yorum Merhaba arkadaşlar, bu makalemiz de ASP.NET 4.0 ile birlikte gelecek olan ClientIDMode özelliğini inceliyor olacağız...ASP.NET de kontroller render edildikten sonra bir ID değeri alıyor ve bu ID değeri tüm kontroller için benzersiz oluyor. Bu yüzden, eğer kontrol UserControl yada MasterPage içerisindeyse kontrol'ün ID'si UserControlAdi_KontrolAdi şeklinde uzun bir isme sahip oluyor. Bu şekilde özellikle istemci taraflı geliştirme yaparkan(Javascript, JQuery vs.) bu kontrollere erişmek çok zor oluyor ve uygulamayı geliştiren kişinin geliştirme süresini uzatıyordu. ASP.NET 4.0 Öncesi ve Read-Only ClientID ÖzelliğiAslında ASP.NET içerisinde her kontrolün ClientID isimli read-only bir propertysi var. Bu property ile kontrolün alacağı ID’ye erişebiliyoruz. Fakat kontrolü bir user control içerisine taşırsak WebUserControl1_lblClientID gibi bir ClientID’ye sahip oluyor. Bu da istemci tarafında yapılan işlemi ve süreci etkiler, yapılan işlemin hatalı olmasına neden olur. Çünkü eğer harici bir dosya içinde İstemci taraflı işlemler yapılıyorsa orada da ilgili değişikliğin yapılması gerekir.ASP.NET 4.0 Öncesi ClientID ÖzelliğiResponse.Write(KonrolAdi.ClientID); KonrolAdi.ClientID = “Atanamaz”; // => Read only bir özellik, atama yapılamaz !ASP.NET 4.0 Yaklaşımı ve ClientIDMode Özelliğiİstemci taraflı geliştirmenin web uygulamalı içerisinde kullanımın artmasıyla birlikte bu sorunu aşmak için ASP.NET 4.0 ile birlikte kontrollere ClientIDMode isimli bir özellik eklendi. Bu özellik kontrol render edildikten sonra kontrolün alacağı ClientID değerinin istediğimiz gibi atanmasını sağlıyor. Yani ClientID’nin değeri eskiden olduğu gibi uzunca bir değer olabilir, bizim vereceğimiz her hangi bir değer olabilir ya da kontrol’ün ID’si ile aynı olabilir.ClientIDMode özelliğinin alabileceği 4 özellik var. Bunlar Legacy (varsayılan değer), Inherit, Static, Predictable.LegacyClientIDMode’un default değeridir. Eğer ClientIDMode özelliğine Legacy’i enum’u set edilmişse kontrolün alacağı ID değeri önceki sürümlerde olduğu gibidir. Yani uzunca bir ClientID oluşur :)Örnek Kullanımı<asp:Content ID="Content1" ContentPlaceHolderID="ContentPlaceHolder1" runat="server"> <asp:Label ID="lblSample" ClientID="lblSample" ClientIDMode="Legacy" runat="server" Text="Deneme"></asp:Label> </asp:Content>Html Çıktısı<span id="ctl00ctl00_ContentPlaceHolder1_lblSample">Deneme</span>Inherit Her kontrol için default davranış gösterir. İçerisinde yer aldığı parent kontrolün ClientIDMode property’si ne olarak belirlenmişse, kontrol içinde o özellik atanır. Örneğin bir MasterPage ve Content sayfası var. Content sayfanın içinde de bir Label var. Master Page içerisindeki ContentPlaceHolder'ın ClientIDMode özelliği static ise Content sayfa içerisinde yer alan kontrolün özelliği de static olarak belirlenir.Örnek Kullanımı Master Page<asp:ContentPlaceHolder ID="ContentPlaceHolder1" runat="server" ClientIDMode="Static"> </asp:ContentPlaceHolder>Content <asp:Label ID=" lblSample" ClientID="lblInheritSample" ClientIDMode="Inherit" runat="server" Text="Deneme"></asp:Label> Html Çıktısı<span id="lblInheritSample">Deneme</span> // Parent Kontrolün(Content) ClientIDMode özelliği static olduğu için içteki kontrolünde ClientIDMode özelliği static olarak atandı…StaticBu mod seçildiğinde, kontrolün ClientID’ne ne atamışsak oluşacak olan HTML çıktısına da o değer atanır. Burada dikkat edilmesi gereken şey, ClientID’nin benzersiz olduğundan emin olmak zorundayız. Yani elimizde 2 User Control var. Her ikisi içinde de bir label olduğunu düşünürsek iki label’ın CleintID’si farklı olması gerekir. Eğer ikisi de aynı olursa, client site de yapacağımız işlemler de yanlış sonuçlar alabiliriz. Özellikle de databound kontrollerinden kullanmamak gerekir.Örnek Kullanımı<asp:Content ID="Content1" ContentPlaceHolderID="ContentPlaceHolder1" runat="server"><asp:Label ID=" lblSample" ClientID=”lblClientSample" ClientIDMode="Static" runat="server" Text="Deneme"></asp:Label> </asp:Content>Html Çıktısı<span id=" lblClientSample">Deneme</span>PredictableBu özellik, Gridview, Repeater gibi DataBound kontroller için daha kullanışlıdır. Burada işe yarayacak bir diğer property de RowClientIDSuffix özelliğidir. Bu özellik ile DataBound kontrolünün kolonu içerisinde yer alan kontrolün ClientID’nin değerinin sonuna takı olarak belirttiğimiz alanın değeri eklenir.Örnek Kullanımı<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="false" ClientIDMode="Predictable" RowClientIDSuffix="UrunAdi"> // RowClientIDSuffix özelliğine veri kaynağından gelen bir alan yazmak zorundayız. Birden fazla kontrol için yapacaksak alanları virgül ile ayırabiliriz.<Columns><asp:TemplateField><ItemTemplate><asp:Label ID="lblUrunAdi" runat="server" Text='<%# Eval("UrunAdi") %>'></asp:Label></ItemTemplate></asp:TemplateField></Columns></asp:GridView>Html Çıktısı<table cellspacing="0" rules="all" border="1" id="ctl00_ContentPlaceHolder1_GridView1" style="border-collapse:collapse;"><tr><th scope="col"> </th></tr><tr><td><span id="ctl00_ContentPlaceHolder1_GridView1_lblUrunAdi_Kalem">Kalem</span></td></tr><tr><td><span id="ctl00_ContentPlaceHolder1_GridView1_lblUrunAdi_Defter">Defter</span></td></tr><tr><td><span id="ctl00_ContentPlaceHolder1_GridView1_lblUrunAdi_Silgi">Silgi</span></td></tr><tr><td><span id="ctl00_ContentPlaceHolder1_GridView1_lblUrunAdi_Dosya Kağıdı">Dosya Kağıdı</span></td></tr></table> Eğer ClientIDMode özelliğini Predictable yapmasaydık,<table cellspacing="0" rules="all" border="1" id="ctl00_ContentPlaceHolder1_GridView1" style="border-collapse:collapse;"><tr><th scope="col"> </th></tr><tr><td><span id="ctl00_ContentPlaceHolder1_GridView1_ctl02_lblUrunAdi">Kalem</span></td></tr><tr><td><span id="ctl00_ContentPlaceHolder1_GridView1_ctl03_lblUrunAdi">Defter</span></td></tr><tr><td><span id="ctl00_ContentPlaceHolder1_GridView1_ctl04_lblUrunAdi">Silgi</span></td></tr><tr><td><span id="ctl00_ContentPlaceHolder1_GridView1_ctl05_lblUrunAdi">Dosya Kağıdı</span></td></tr></table>Makalenin sonuna geldik, başka bir makalede görüşmek üzere. ASP.NET ile kalın ;) Sem GÖKSU www.semgoksu.com | www.yazilimgunlugu.com sem.goksu@yazilimgunlugu.com Kaynaklarmsdn.com