msHOWTO

27 Mayıs 2013 Pazartesi

"A potentially dangerous Request.Form value was detected from the client" Hatası ve Çözümleri

Merhaba arkadaşlar. Bugün proje geliştirirken aldığım hatanın sebebini ve çözümlerini sizlerle paylaşacağım. Hatanın sebebi web projenizde herhangi bir sayfanızda herhangi bir yerinden girdi olarak HTML girdisi alınıyorsa direk olarak bu hatayı fırlatıyor. Asp.Net kendisi bu şekilde bir nebze de olsa güvenlik sağlamaya çalışıyor. Fakat bazen öyle durumlar oluyor ki kullanıcan HTML içerikli girdi almak durumunda kalıyorsunuz. Bu durumlar da yapılması gereken ilk şey farklı bir editör kullanmak. Örneğin CKEditor gibi. Fakat benim şuan geliştirdiğim uygulamda kullanıcıdan Google Map embed linki almam gerekiyor. Bunun için CkEditörü sayfaya import edip yüklenmesini sağlayıp sayfayı yavaşlatmak saçma ve gereksiz olur. Bu nedenle klasik ve düz TextBox kullanıyorum. Bu durumda da html girdi olduğu için direk bu hatayı fırlatıyordu. Bu sorunun birden fazla çözümü mevcuttur .

1-) Web.config dosyamıza <system.web> tag ının altına <pages validateRequest="false"/> tag ı eklenir.

2-) Bu şekilde veri girdisi sadece o page de olacaksa daha özele inip , ilgili page in <%@Page tagına  validateRequest="false" eklenir.

3-)Eğer bunları yapıp hala aynı hatayı alıyorsanız muhtemelen Visual Studio 2010 ve 4.0 ile projenizi geliştiriyorsunuz demektir. Bu durumda ise Web.config dosyamıza <system.web> tag ının altına   <httpRuntime requestValidationMode="2.0" /> tag ı eklenir.

Umarım faydalı olmuştur arkadaşlar. Bir sonraki makalemde görüşmek üzere.

22 Mayıs 2013 Çarşamba

Entity FrameWork .Net Framework 4.5 Projelerinde Transaction Kullanımı

Merhaba arkadaşlar ,

Geliştirmekte olduğum projemin içerisinde database işlemlerini yaptığım methodlarda transaction kullanmam gerekti.Daha önce .Net Framework 4.0 ile geliştirdiğim projelerimde Transaction yapısını kullanmıştım. Fakat şuan ki projemi .Net 4.5 ile geliştiriyorum.Transaction işlemi için .Net 4.0 da kullanmış olduğum ,


using (TransactionScope scope = new TransactionScope())
{
}

bloğunu tekrar kullanmam gerekiyordu. Fakat bu şekilde yazında TransactionScope Class ının içerisinde bulunduğu Library 'i görmedi. Bunun için uyguladığım çözüm ise ;

Solution içerisinde transaction uygulanacak sınıfın ait olduğu project teki references kısmına sağ tıklayıp Add Reference dedim . Çıkan listede System.Transactions olması gerekiyor.Bu listenin içerisinde göremiyorsanız siz de benim gibi , penceredeki Browse butonuna tıklayın ve aşağıdaki dizine konumlanın .

C:\Program Files (x86)\Reference Assemblies\Microsoft\Framework\.NETFramework\v4.5\

Daha sonra bu klasörün içerisinde System.Transactions.dll dosyasını seçin ve Ok butonuna basın. Bu şekilde referas olarak ekledikten sonra transaction uygulanacak sınıfınıza geri dönün. Ve

Using System.Transactions;

satırını ekleyin. Artık


using (TransactionScope scope = new TransactionScope())
{
}

scope larının içerisine yazacağınız tüm database işlemlerine transaction uygalanacaktır.Yani bir işlem başarısız olursa eğer , bu scope içerisindeki tüm database işlemleri geri alınacaktır.

Umarım faydalı olmuştur. Görüşmek üzere.

9 Mayıs 2013 Perşembe

Unable to update the EntitySet 'Slider' because it has a DefiningQuery and no element exists in the element to support the current operation. Hatasının Çözümü

Merhaba arkadaşlar. Bugün proje geliştirirken karşıma çıkan hatanın çözümünü sizinle paylaşacağım.Öncelikle hatayı Entity Framwork kullanarak veri tabanındaki bir tabloya kayıt eklerken aldım. Daha sonra bu hatanın çözümü için uyguladığım seçenekler ise ,

1-) Projemdeki modeli güncellemek ,
2-) Veri tabanındaki ilişkileri kontrol etmek ,
3-) Projemdeki modeldeki ilişkileri kontrol etmek ,
4-) Google ' a sormak :)

ve 4. seçenekte www.stackoverflow.com sitesinde karşıma çıkan öneriyi denedikten sonra sorunum çözüldü. Sorun aslında yapılmaması gereken bir hatadan kaynaklanıyormuş. Veri ekleme işlemi yaptığım tabloyu oluşturduğumda Primary Key belirtmediğimden dolayı hata alıyormuşum.

Yani kısaca sorunu ilgili tabloma Primary Key alanı ekleyerek , daha sonra da projemdeki modeli güncelleyerek çözmüş bulunmaktayım.

Umarım yardımcı olmuştur.