Sem GÖKSU - Kişisel Web Sitesi Ana Sayfa | Hakkımda | Çalışmalarım | Kitap Önerileri | Fotoğraflarım | RSS RSS | İletişim
İçerik Kategorileri
Makale Kategorileri
Etiket Bulutu
Arama
Tema
Kaynaklar
Takip Ettiklerim

ASP.NET

ASP.NET 4.0 Menü Kontrolü Yenilikleri


Menu kontrolü çok pratik olmasına rağmen arka tarafta html table'a render edildiği için pek tercih edilmiyordu. Ayrıca kontrole CSS uygulamak da çok zor oluyor taklalar atmak zorunda kalıyorduk :) ASP.NET 4.0 ile birlikte artık liste elementlerine render ediliyor. Hem daha anlamlı bir HTML çıktısı oluyor hem de CSS uygulamak çok kolay oluyor. Ayrıca menu kontrolüne accessible rich internet applications (ARIA) özellikleri de eklenmiş durumda. Aşağıdaki örneği inceleyecek olursak DIV içerisinde liste ve içerisinde de menümüzün elemanlarını görebiliriz.

[ASP.NET 4.0]

<asp:Menu ID="menu" runat="server"> 
    <Items
        <asp:MenuItem Text="Ana Sayfa" NavigateUrl="Anaayfa.aspx"></asp:MenuItem
        <asp:MenuItem Text="Hakkımızda" NavigateUrl="Hakkimizda.aspx"></asp:MenuItem
        <asp:MenuItem Text="Referanslar" NavigateUrl="Referanslar.aspx"></asp:MenuItem
        <asp:MenuItem Text="İletişim" NavigateUrl="Iletisim.aspx"></asp:MenuItem
    </Items>
</asp:Menu>

[HTML Output]

<div id="menu"> 
    <ul class="level1"> 
        <li><a class="level1" href="Anaayfa.aspx">Ana Sayfa</a></li
        <li><a class="level1" href="Hakkimizda.aspx">Hakkımızda</a></li
        <li><a class="level1" href="Referanslar.aspx">Referanslar</a></li
        <li><a class="level1" href="Iletisim.aspx">İletişim</a></li
    </ul>
</div>

Bu makaleye 2 yorum yapılmış. | 11.11.2009 23:38:16

İnternet mucidinin en büyük hatası


World Wide Web Konsorsiyum'unun direktörü ve M.I.T. profesörü Tim Berners-Lee, bir röportajda kendisine yöneltilen ilginç bir soruya daha ilginç bir cevapla karşılık verdi.

İnternetin mucidi olarak tanınan Tim'e "Her şeyi yeniden yapma şansınız olsa neyi farklı yapardınız? Pişmanlıklarınız var mı?" şeklinde bir soru soruldu. Lee ise bugünkü aklı olsa http'den sonraki çift kesme " //" işaretinden bir tanesini çıkartmayı istediğini söyledi. Çift kesme işaretinin o günlerde bir programcılık standardı olduğunu, ancak sonradan bunun gerekli olmadığının anlaşıldığını belirten Lee, eğer çift kesme yerine tek kesme kullanılmış olsaydı insanların ek zahmetten kurtulacağını ve kağıda yapılan baskıda kapladığı yer yüzünden kesilen ağaçların olmayacağını söyledi.



Kaynak: http://www.milliyet.com.tr/Dunya/SonDakika.aspx?aType=SonDakika&KategoriID=19&ArticleID=1150214&Date=14.10.2009&b=Internet%20mucidinin%20en%20buyuk%20hatasi

Bu makaleye 1 yorum yapılmış. | 15.10.2009 00:41:14

Microsoft'tan Küçük İşletmelere WebsiteSpark


Microsoft WebsiteSpark programı Türkiye'de de duyuruldu! 10 kişiye kadar çalışanı olan ve ASP.NET, Silverlight, Sharepoint, PHP gibi teknolojilerle web uygulamaları geliştiren şirketlere 3 yıl süre ile ücretsiz yazılımlar sağlıyor.

•3 adet Visual Studio 2008 Professional Edition Lisansı
•1 adet Expression Studio 3 lisansı (Expression Blend, Sketchflow ve Web!)
•Ayrıca 2 adet Expression Web 3 lisansı.
•Windows Web Server 2008 R2 4 işlemci lisansı
•SQL Server 2008 Web Edition 4 işlemci lisansı
•DotNetPanel yönetim paneli

Daha da güzeli var! SQL ve Windows Server lisanslarını isterseniz yayın ortamında da kullanabiliyorsunuz. Yani lisansnlar sadece geliştirme ortamı için değil bir hosting sağlayıcıdan alacağınız dedicated sunucunuza bu lisansları kurup uygulamanızı canlı yayına da alabilirsiniz. Tüm bunların yanında Microsoft Partner'ları gibi;

•Firma başına iki teknik destek hakkı.
•Microsoft’un web şirketleri ekosistemindeki iş ortakları, müşterileri ve tamamlayıcı servisleri ve teknolojilerinden oluşan topluluğa erişim hakkı.    
•MSDN üzerindeki teknik bilgi ve danışmanlık sunan tartışma gruplarına sınırsız erişim.
hizmetlerinden de WebsiteSpark üyesi kuruluşlar faydalanabiliyor.

Başvuru için hemen http://www.microsoft.com/web/websitespark/ adresini ziyaret edebilirsiniz.

3 yıl sonra ne olacak?
Üç yılın sonunda eğer programdan ayrılmak isterseniz 100$'lık bir ödeme yapmanız gerekiyor. Fakat tahmin etmiyorum ki kimse ayrılsın çünkü bu üç senede yayında bile kullanabileceğiniz ücretsiz lisanslar ile çoktan firmanızı kuvvetli bir şekilde ayağa kaldırmış olmanız mümkün. Bu durumda da normal yöntemlerle yıllık 999$ vererek tüm bu lisansların development ortamında kullanılabilecek olanlarını alabilirsiniz ve yayın tarafı için de yine yıllık 199$ ile 1 adet Windows Web Server ve 1 adet SQL Server Web edition edinebilirsiniz. Kişisel kanaatimi sorarsanız bu rakamlar bile bir yazılım şirketinin masrafları arasında en ufak kalemleri oluşturacaktır.

Spark programları süper!
Microsoft bundan önce de öğrencilere ücretsiz lisans sağlayan DreamSpark ve yazılım üretimi yapan şirketlere ücretsiz lisans sağlayan BizSpark ile güzel bir seriyi başlatmıştı. Bu serinin WebsiteSpark ile devam etmesi gerçekten muhteşem. Artık bir yazılım şirketi kurmak veya bu ekonomik krizde şirketi tekrar ayağa kaldırmak, lisans dertleriyle uğraşmamak çok daha rahat.

Kaynak
http://daron.yondem.com/tr/PermaLink.aspx?guid=7132de37-7259-4459-9051-9edd1dcb12f3

Bu makaleye henüz yorum yapılmamış. | 29.09.2009 13:16:07

ASP.NET 4.0 ile URL Routing


Web uygulamarında kullanıcıların yapmış olduğu işlemlerde parametre aktarımı bazı durumlarda QueryString ile (URL’den) yapılmaktadır. Bu durumda adres çubuğunda oluşan link çok uzun ve okunamaz hale geliyor. Bu kullanıcı açısından görüntü kirliliği yaratıyor, arama motorları tarafından indexlenme ihtimalini azaltıyor ve geliştirici açısından parametrelerin okunması ve takip edilmesi zorlaştırıyor. Örneğin;

http://semgoksu.com/search.aspx?Kategori=ASP.NET&Tarih=15122009&Baslik=URLRouting

ASP.NET 4.0 ile birlikte URL Routing’i kullanarak bu sorunu ortadan kaldırabiliyoruz. Bu sayede hem oluşan link daha kısa ve anlamlı oluyor, hemde URL içerisindeki klasör yapısına sayfa ile ilgili keywordleri koyarak arama motorlarının daha kolay indexlemesini ve bu sayede sayfalarımızın daha üst sıralarda çıkması sağlayarak büyük bir avantaj sağlamış oluyoruz. Yukarıda vermiş örneği ASP.NET 4.0 URL Routing’i kullanarak aşağıdaki gibi yapabiliriz.

http://semgoksu.com/Arama/ASP.NET/15122009/URLRouting

URL Routing ilk olarak MVC ile birlikte geldi ve artık ASP.NET 4.0 ile birlikte URL Yönlendirme işlemi yapabilmemiz için her şey hazır durumda. Visual Studio 2010’u kullanarak yeni bir ASP.NET uygulaması oluşturalım ve konuyu örneklendirelim. Uygulamayı oluşturduktan sonra web uygulamamıza yeni bir Global.asax dosyası ekleyelim.


Globax.asax dosyası içerisinde bulunan Application_Start methodu içerisinde URL yönlendirme işlemini yapacağız. Bunun için ihtiyacımız olan ilk şey RouteTable. Bu sınıf farklı formatlardaki url yönlendirmelerini(Route’ları) saklayacak olan Route koleksiyonudur. İki parametre alır; Route’un adı ve Route nesnesi. Route nesnesi de URL’in gösterileceği formatı belirtmek için kullanılır. Uygulamaya gelen istekler Route’un formatına uygunsa PageRouteHandler’ın belirttiği path’e yönlenir. PageRouteHandler sınıfı yönlendirilecek olan fiziksel dosyayı Constructor’da(Yapıcı metot) parametre olarak alır.

Sonuç olarak sayfaya yapılan request’lar RouteTable’daki Route’lardan birine uygun formattaysa PageRouteHandler’in işaret ettiği sayfaya yönlenir. URL bizim belirttiğimiz formatta görüntülenirken arka tarafta ilgili fiziksel dosya üzerinde işlem yapılır.

İlk olarak ana sayfamızdan(Default.aspx) detay sayfaya (detay.aspx) sayfasına bir yönlendirme işlemi yapalım. Detay sayfasına bir de parametre gönderelim ve bu parametreyi detay sayfada yakalayarak ekran da görüntüleyelim.

[Global.asax]
<%@ Application Language="C#" %>
<%@ Import Namespace="System.Web.Routing" %>
<script runat="server">
void Application_Start(object sender, EventArgs e)
{
    RouteTable.Routes.Add("Detay", new Route("Detay/{Parametre}", new PageRouteHandler("~/Detay.aspx")));
}
</script>

Appplication_Start metodu içerisinde sayfamıza gelecek olan url formatını Klasor/{Parametre} şeklinde belirttik. ({Parametre} yerine istediğimiz bir değeri gönderebileceğiz) Bu formatta gelen bütün istekler detay.aspx sayfasını gösterecek.

[Default.aspx]
<asp:HyperLink ID="link" runat="server" NavigateUrl='<%$ RouteUrl:RouteName=Detay, Parametre=Sayfa1 %>'>Detaya Git</asp:HyperLink>

Ana sayfaya bir HyperLink nesnesi ekledik. HyperLink içerisinde ilk olarak sayfamızın gideceği Route’u ve o Route’a göndereceğimiz Parametreyi bildirdik. Oluşacak olan format şu şekilde olacak. NavigatetUrl içerisinde kullanılan RouteUrl’i kod tarafında kullanamıyoruz.

http://localhost:50751/Detay/Sayfa1

Şimdi Detay.aspx sayfaya gidelim ve gönderdiğimiz parametreyi yakalayalım. Route içerisinde gönderdiğimiz bütün parametreler RouteData içerisinde yer alır. Göndermiş olduğumuz parametreye erişmek için RouteData.Values[“Parametre”] yada RouteData:Name şeklinde kullanırız.

[Detay.aspx.cs]
protected void Page_Load(object sender, EventArgs e)
{
    if (RouteData.Values["Parametre"]!=null)
    { 
        Response.Write(RouteData.Values["Parametre"].ToString());
    }
}

Sayfayı çalıştırdığımız da URL istediğimiz şekilde gitmiş ve Detay.aspx sayfasına göndermiş olduğumuz parametreyi’de ekranda görüntüledik.
Şimdi farklı bir örnek yapalım ve birden fazla parametreyi nasıl göndeririz ona bakalım. Bu örnekte SQL Server 2005’te yer alan örnek veritabanlarından AdventureWorks’u kullanarak Kategorileri ilk ekran da listeyelim. Kullanıcı ilgili kategoriye tıkladığında farklı bir sayfa da ilgili ürünler listelensin. Sayfaya göndereceğimiz URL formatını da istediğimiz gibi değiştirelim. Bunun için global.asax dosyamızı düzenleyelim. Route içerisinde format istediğimiz gibi düzenleyebiliriz. KategoriID ve KategoriAdi parametrelerini istediğimiz değerleri verebileceğiz.

[Global.asax]
<%@Application Language="C#" %>
<%@ Import Namespace="System.Web.Routing" %>

<script runat="server">

void Application_Start(object sender, EventArgs e)
{
    RouteTable.Routes.Add("Kategoriler", new Route("Katgoriler/{KategoriAdi}/{KategoriID}", new PageRouteHandler("~/Detay.aspx")));
}

</
script>


Sayfamıza bir Repeater ekleyelim. Burada Kategorileri listeleyeceğiz. Veritabanındaki verilere erişmek için projemize bir adet LINQ to SQL Classes Dosyası ekleyelim. İsim olarak AdventureWorks diyelim.



Kullanacağımız ProductSubCategory ve Product tablolarını’da dosyamıza alalım. Şimdi kategorilerimizi listeleyek olan HTML kodunu yazalım. Sayfaya Repeater, içerisinede bir HyperLink ekliyoruz.

[Default.aspx]
<asp:Repeater ID="rptKategoriler" runat="server" OnItemDataBound="rptKategoriler_ItemDataBound">
    <ItemTemplate>
        <asp:HyperLink ID="hlKategori" runat="server">
        </asp:HyperLink><br />
    </ItemTemplate>
</asp:Repeater>

Şimdide veritabanından verileri LINQ to SQL ile çekelim ve Repeater’a bağlayalım. ItemDataBound eventin’de HyperLink nesnesini yakalayıp kontrolün Text ve NavigateUrl özelliğini datadan gelen değer ile dolduracağız.

[Default.aspx.cs]
AdventureWorksDataContext db = new AdventureWorksDataContext();
protected void Page_Load(object sender, EventArgs e)
{
    rptKategoriler.DataSource = (from k in db.ProductSubcategories select k).Take(10); // 10 kayıt alalım
    rptKategoriler.DataBind();
}
protected void rptKategoriler_ItemDataBound(object sender, RepeaterItemEventArgs e)
{
    if (e.Item.ItemType == ListItemType.Item|| e.Item.ItemType == ListItemType.AlternatingItem )
    {
        HyperLink hl = e.Item.FindControl("hlKategori") as HyperLink;
        hl.Text = DataBinder.Eval(e.Item.DataItem, "Name").ToString();
        RouteValueDictionary parameters = new RouteValueDictionary() 
        {
            { "KategoriID", DataBinder.Eval(e.Item.DataItem, "ProductSubCategoryID").ToString() },
            { "KategoriAdi",DataBinder.Eval(e.Item.DataItem, "Name").ToString() }
        }; // Route’un alacağı parametreler’i dinamik olarak dolduruyoruz
        VirtualPathData path = RouteTable.Routes.GetVirtualPath(null,"Kategoriler", parameters); 
        hl.NavigateUrl = path.VirtualPath; // Oluşan Route’un pathini hyperlinke atadık.
    }
}

Kategorilerin listeleneceği sayfayı hazırladık. Şimdi de gidip detay sayfada görüntülenecek olan ürünler için gerekli sayfayı hazırlayalım. İlk olarak HTML’e bir Repeater ekleyelim ve içine bir label atalım. Text özelliğinde de ürün’ün adını görüntüleyelim.

[Detay.aspx]
<asp:Repeater ID="rptUrunler" runat="server">
    <ItemTemplate>
        <asp:Label ID="lblUrunAdi" runat="server" Text=<%# Eval("Name") %>>
        </asp:Label><br />
    </ItemTemplate>
</asp:Repeater>

Veriyi LINQ to SQL ile çekerek Repeater’a bağlayalım. Diğer sayfadan gelen KategoriID parametresinide almayı unutmuyoruz. Ürünler gelen KategoriID parametresine göre listelenecek.

[Detay.aspx.cs]
AdventureWorksDataContext db = new AdventureWorksDataContext();
protected void Page_Load(object sender, EventArgs e)
{
    if (RouteData.Values["KategoriID"]!=null)
    {
        int UrunID = Convert.ToInt32(RouteData.Values["KategoriID"]);
        UrunleriGetir(UrunID);
    }    
}

private void UrunleriGetir(int KategoriID)
{
    rptUrunler.DataSource = from u in db.Products
                    where u.ProductSubcategoryID == KategoriID
                    select u;
    rptUrunler.DataBind();
}

Şimdi sayfayı çalıştıralım ve sonuca bakalım,

Kategorilerden birine tıklayalım.



İşte bu kadar J
Bu makalenin de sonuna geldik başka bir makale de görüşmek üzere. ASP.NET ile kalın ;)

Sem GÖKSU
www.semgoksu.com| www.yazilimgunlugu.com
sem.goksu@yazilimgunlugu.com

Kaynaklar
msdn.com

Bu makaleye 1 yorum yapılmış. | 11.09.2009 15:14:03

Sem Göksu Açık Kaynak Kodlu Blog Sistemi




Sem Göksu Blog Sistemi
Sem 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 2005

Blog Ö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
- CMS

Blog 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 String
Bloğun kullanacağı veritabanı için gerekli olan ConectionString bilgisi.

Host
Email gönderimi için gerekli olan host bilgisi.

Email
Email'in gönderileceği email hesabı.

Password
Email adresinin şifresi.

SenderEmail
Gönderilecek olan mail adresi.

SiteName
Blog ile ilgili açıklama.

SiteOwner
Bloğun sahibi

SiteLink
Bloğun adresi.

SiteShortLink
Bloğun kısa adresi.

AdminUser
CMS'e girişte kullanacağınız kullanıcı adı.

AdminPass
CMS'e girişte kullanacağınız şifre.

Bloğu kullandıktan sonra bana bilgi verirseniz çok sevinirim :)

Bu makaleye 53 yorum yapılmış. | 07.04.2009 12:19:21

Ana Sayfa | Hakkımda | Çalışmalarım | Kitap Önerileri | Fotoğraflarım | RSS | İletişim
Sem Göksu 2004-2009 © Tüm Hakları Saklıdır.