MVC ile beraber kodlama standartlarına dikkat etmeye başladım. Camel case harflendirmede esas olan kural değişken ilk sözcüğü küçük harfle başlar ve sonraki sözcükler büyük harfle başlar.
Örnek: buDegisken
MVC ile beraber kodlama standartlarına dikkat etmeye başladım. Camel case harflendirmede esas olan kural değişken ilk sözcüğü küçük harfle başlar ve sonraki sözcükler büyük harfle başlar.
Örnek: buDegisken
MVC’ye geçiş yaptığım dönemden bu yana Model, View ve Controller katmanları gördükçe kodlarım nedense bana çok karmaşık gelmeye başladı. Kendi kuruntum herhalde dedim ama biraz araştırma yaptıktan sonra analar ne developer doğuruyor demekten kendimi alamadım 🙂
Çok katmanlı mimarı hakkında Microsoft’un best practicelerini incelemenizi tavsiye ederim. Veritabanı işlemleri yapıldığı DAL (Data Access Layer), arayüz ile veritabanı arasındaki işleri yapan BLL (Business Logic Layer) katmanlar hakkında http://msdn.microsoft.com/en-us/library/aa581776.aspx (DAL) ve http://msdn.microsoft.com/en-us/library/aa581779.aspx (BLL) sayfalarını incelemenizi tavsiye ederim.
Bunlar haricinde katmanlar arası veri akışı sağlayabileceğiniz Entities, kendi helperlarınızı tutabileceğiniz Utilities ve verilerinizi dışarıya açmak için Service katmanlarıda oluşturabilirsiniz.
Bu mimari uygulama sürecin uzatsada yapınız mükemmel şekilde hiyerarşik ve modüler hale geliyor. Hele ki takım çalışması olan uygulamalarınız için size kolaylıklar sunuyor.
Katmanlı mimariyi anladıktan sonra, kendimi biraz daha Yazılım Geliştirici olduğumu hissetmeye başladım 🙂
Üzerinde çalıştığım projemde dosya yükleme eklemem gerekiyordu. Bütün view’lerimde Ajax.BeginForm ile post ediyordum ve post sonrası js işlemleri için parametre olak OnSuccess kullanıyordum. Upload işlemini Html.BeginForm ile yapmak zorunda kalınca OnSuccess’den mahrum kaldım.
Html.BeginForm ile post sonrasında js kütüphanelerimi aşağıdaki gibi bir yöntemle çalıştırdım 🙂
JS Kütüphanesi:
function querystring(key) {
var re = new RegExp('(?:\\?|&)' + key + '=(.*?)(?=&|$)', 'gi');
var r = [], m;
while ((m = re.exec(document.location.search)) != null) r.push(m[1]);
return r;
}
$(document).ready(function () {
if (querystring('i') == "FRAME_CLOSE") {
alert("Başarıyla eklenmiştir.");
parent.jQuery.fn.colorbox.close();
}
else if (querystring('i') == "DOSYA_BOYUT") {
alert("Dosya boyutu en fazla 10 MB olabilir.");
}
else if (querystring('i') == "DOSYA_TIP") {
alert("İzin verilen dosya formatları: *.jpg, *.pdf, *.doc, *.docx, *.xls, *.xlsx, *.udf");
}
else if (querystring('i') == "DOSYA_YOK") {
alert("Lütfen yüklemek istediğiniz dosyayı seçiniz.");
}
else if (querystring('i') == "HATA") {
alert("Lütfen formu kontrol ediniz.");
}
else if (querystring('i') == "WEB_HATA") {
alert("Beklenmedik bir hata oluştu. Lütfen tekrar deneyiniz.");
}
});
Controller.cs:
[HttpPost]
public ActionResult FileUpload(int id)
{
try
{
return Redirect("/Muvekkil/EvrakYeni?i=FRAME_CLOSE");
}
catch (Exception ex)
{
return Redirect("/Muvekkil/EvrakYeni?i=WEB_HATA");
}
}
MVC’de dosya yükleme işlemine göz atacağız.
Projemizde dosya yükleme için controller ve view oluşturduktan sonra, view kısmında dosya yükleme için formumuzu oluşturalım.
@using (Html.BeginForm("Index", "Home", FormMethod.Post, new { enctype = "multipart/form-data" }))
{
@TempData["sonuc"]
<div>
<input type="file" name="dosya" />
<input type="submit" value="Gönder" />
</div>
}
Controller’da gerekli kodlarımızı yazıyoruz.
[HttpPost]
public ActionResult Index(HttpPostedFileBase dosya)
{
if (dosya != null && dosya.ContentLength > 0)
{
var path = Path.Combine(Server.MapPath("~/upload_klasor"), dosya.FileName);
dosya.SaveAs(path);
TempData["sonuc"] = "Dosya başarıyla yüklenmiştir.";
}
return View();
}
Dosya yüklemek istediğimiz klasöre yazma izni veridikten sonra uygulamamızı çalıştırabilirsiniz.
İki tarih arasında tarih farkını almak istiyorsak DATEDIFF fonksiyonu ile bunu sağlayabiliriz.
Örnek:
SELECT DATEDIFF(dd, BASLANGIC_TARIH, BITIS_TARIH) AS GUN_FARK FROM TBL_TABLOM
İnternetin çok büyük bir kısmında kullanılan şifreleme teknolojisinde “Heartbleed” olarak tanımlanan ciddi bir güvenlik açığı tespit edildi. Tumblr da bundan etkilenmiş durumda.
Adres çubuğunda gördüğümüz; parolalarımızı, kişisel postalarımızı, kredi kartı bilgilerimizi koruduğunu düşündüğümüz küçük kilit işareti (HTTPS) aslında tüm bu gizli bilgileri bu açığın farkında olan kişiler için erişilebilir kılıyormuş.
İnternet üzerindeki tüm sitelerde özellikle de yüksek güvenlik gerektiren e-posta, dosya depolama ve banka hizmetlerini gerçekleştirdiğin alanlarda kullandığın ve bu güvenlik açığından etkilenmiş olabilecek tüm parolaları değiştirmek iyi olacaktır.
Teknik Referans: http://www.kayhankayihan.com/openssl-heartbleed-zafiyeti-ve-bugfix/
Üzerinde çalıştığım projeyi Windows Azure’de test etmek istemiştim. Projeyi publish yaptıktan sonra Windows Azure’ye dosyaları FTP ile transfer ettim. Azure’de siteyi çalıştırdığımda web.config hatalarından tutunda, referancelere kadar bir sürü hata aldım. Üzerinde 1-2 gün kafayı yedikten sonra, bin klasörü içindeki dll’lerin dosya boyutlarını fark ettim. Publish edilen dosya boyutları ile transfer edilenler aynı değildi. Sizde bunu gözden kaçırıp benim gibi kafayı ütülemeyin 🙂
Bilişim kariyerimdeki yazılım geliştirme ile uğraştığım senelere bakacak olursak, her halde en bıkmış olduğum olduğum konu sessionlardır.
Ne zaman üyelik sistemi veya session ihtiyaç duyduğum bir uygulama üzerinde uğraşsam beni bir huzursuzluk kaplıyor 🙂 Yıllardır bu bende tramva olarak sürer ve en sonunda bununla ilgili birşeyler yazıp içimi dökmek istedim.
Her yazılımcının bildiği gibi HttpContext.Session özelliği kullanımı üç başlık altında özetleyebiliriz. Uygulamaları olarak gideceğimiz için ilk önce string tipindeki değişkenlerimizi oluşturuyoruz.
string _ad = "Hüseyin"; string _soyad = "Yıldırım"; string _sehir = "Manisa";
Sessionlarımıza değişkenlerimizi kayıt ediyoruz.
Session["ad"] = _ad; Session["soyad"] = _soyad; Session["sehir"] = _sehir;
Sessionlarımızdaki değeri okuyoruz.
_ad = (string)(Session["ad"]); _soyad = (string)(Session["soyad"]); _sehir = (string)(Session["sehir"]);
Web Form sınıfı dışında ise böyle kullanıyoruz.
HttpContext context = HttpContext.Current; context.Session["ad"] = _ad; _ad = (string)(context.Session["ad"]);
Teoride her şey ne kadar kolay ama uygulamada hatam nerede yaaa ama bulacağım sorunu 😉
Üzerinde çalıştığım ASP.NET MVC 4 ile yazdığım projeyi Windows Azure üzerinden yayınlamayı planladığım için ufak bir deneme yapmak istedim.
Web sitesini hizmeti oluşturdum, FTP ayarlarını yapılandırıp publish ettiğim dosyaları hostinge transfer ettim.
Sıra SQL Server hizmetine veri tabanını import etmeye gelmişti. SQL Server hizmetini ekleyip, veri tabanımı oluşturdum ama verileri atamadım tabi 🙂 SMO ile bağlanmak istediğinizde bağlanmayacaktır, çünkü IP adresinize SQL Server’ınıza bağlanmak için izin vermeniz gerekmektedir.
Bağlansanız dahi hemen kolay olmuyor. Bende SQL Server Express 2008 R2 kurulu ve backup, generate script olarak datalarımı göndermeye çalışsam da başaramadım.
İnsan kendi kendine bu kadar zor olamaz diyor. Google’de araştırmalarım sonucunda Azure SQL Server Migration Wizard‘ı buldum.
Programı çalıştırdığınız da yapmak istediğinizi seçin ve ilk önce kaynak SQL Server bilgilerini girerek veri tabanızı seçin, sonrada Azure SQL Server bilgilerinizi girerek datalarınızı zahmetsizçe gönderebilirsiniz.
Visual Studio kullanıcılarının vazgeçilmez eklentisi NuGet hizmeti durdu. Temel amaçı 3. part paket ve DLL’leri projenize manuel olarak eklemek ve ayarları yazmak yerine kendi komutlarıyla hızlı bir şekilde yapmanızı sağlıyordu.
https://www.nuget.org/packages adresinden inceleyebilirsiniz.
Benim için olmazsa olmaz eklentim Nuget’in bir önce hizmet vermesini diliyorum.