Bazen programlarımızda sql scriptleri program üzerinden çalıştırmaya ihtiyac duyabiliriz. Bu durumda fiziksel bir yol üzerinde bulunan sql scriptimizi program içerisinden okuyarak ve metodumuz ile çalıştırarak işlemi gerçekleştirebiliriz.
okuma işlemimizi fileinfo sınıfını kullanarak aşağıdaki şekilde scripti string bir değişken içerisine aktararak gerçekleştiriyoruz. burada scriptimizin bulunduğu yolu veriyoruz ve ReadToEnd ile okunmasını sağlıyoruz.
FileInfo file = new FileInfo("C:\\Script.sql");
string scripttext = file.OpenText().ReadToEnd();
Metodumuz
protected virtual void ExecuteScript(SqlConnection connection, string script)
{
string[] commandTextArray = script.Split(new string[] { "GO" }, StringSplitOptions.RemoveEmptyEntries);
connection.Open();
foreach (string commandText in commandTextArray)
{
if (commandText.Trim() == string.Empty) continue;
SqlCommand command = new SqlCommand(commandText, connection);
command.ExecuteNonQuery();
}
connection.Close();
}
Okuma işlemi gerçekleştirildikten sonra metodumuzu kullanabiliriz.
ExecuteScript(baglanti, scripttext);
Not: bağlantımız örnek olarak sqlconnection baglanti=new sqlconnection(); şeklinde tanımlanmış bir bağlantı olabilir. Kolay gelsin...
28 Ocak 2012 Cumartesi
27 Ocak 2012 Cuma
C# IIS üzerindeki Klasörlere izin vermek (kod ile)
Bazı uygulamalarımızda ISS üzerindeki kullanacağımız klasörlerimize uygulama tarafında izinler vermemeiz gerekebilir bunun için aşağıda bahsedeceğim yapıyı kullanarak çözüm üretebilirsiniz. öncelikle aşağıdaki metodu kullanacağımızı belirteyim. ve sonrasında da biraz açıklayalım.
public void YazimIzniVer(string HesapAdi, string klasorYolu)
{
try
{
if (Directory.Exists(klasorYolu))
{
var klasor = new DirectoryInfo(klasorYolu);
var klasorGuvenligi = klasor.GetAccessControl();
var rule = new FileSystemAccessRule(HesapAdi, FileSystemRights.FullControl, InheritanceFlags.None | InheritanceFlags.ContainerInherit | InheritanceFlags.ObjectInherit, PropagationFlags.None, AccessControlType.Allow);
klasorGuvenligi.SetAccessRule(rule);
klasor.SetAccessControl(klasorGuvenligi);
}
}
catch (Exception)
{
MessageBox.Show("klasör izni verilemedi.");
}
}
metodumuz içerisine 2 değer almaktadır HesapAdi ve KlasorYolu. Hesap adımız kullanılan IIS versiyonuna göre değişmektedir. IIS 7 için IIS_IUSRS ve IIS 6 için de IIS_WPG bizim hesap adlarımızdır.
bu metod içerisinde bir noktaya değinicem. aşağıdaki satırda
var rule = new FileSystemAccessRule(HesapAdi, FileSystemRights.FullControl, InheritanceFlags.None | InheritanceFlags.ContainerInherit | InheritanceFlags.ObjectInherit, PropagationFlags.None, AccessControlType.Allow);
FileSystemRights.FullControl kısmı bizim vereceğimiz izni belirtmektedir. biz bura da tam yetki vermişiz siz kendinize uygun olanı kullanabilirsiniz.
şimdide bu metodumuzu nasıl kullanıcaz örnek bir satırda bunu görelim.
YazimIzniVer("IIS_IUSRS", "C:\\inetpub\\wwwroot\\uygulamaklasorunuz\\image");
evet görünen şekilde metodumuza ilk olarak IIS 7 versiyonuna göre hesap adımızı verdik daha sonrada klasör yolumuzu. siz klasör yolunu bir değişken olarakta buraya atayabilirsiniz.
kodumuz çalıştığında image klasörüne belirlediğimiz izin verilecektir. Kolay gelsin...
public void YazimIzniVer(string HesapAdi, string klasorYolu)
{
try
{
if (Directory.Exists(klasorYolu))
{
var klasor = new DirectoryInfo(klasorYolu);
var klasorGuvenligi = klasor.GetAccessControl();
var rule = new FileSystemAccessRule(HesapAdi, FileSystemRights.FullControl, InheritanceFlags.None | InheritanceFlags.ContainerInherit | InheritanceFlags.ObjectInherit, PropagationFlags.None, AccessControlType.Allow);
klasorGuvenligi.SetAccessRule(rule);
klasor.SetAccessControl(klasorGuvenligi);
}
}
catch (Exception)
{
MessageBox.Show("klasör izni verilemedi.");
}
}
metodumuz içerisine 2 değer almaktadır HesapAdi ve KlasorYolu. Hesap adımız kullanılan IIS versiyonuna göre değişmektedir. IIS 7 için IIS_IUSRS ve IIS 6 için de IIS_WPG bizim hesap adlarımızdır.
bu metod içerisinde bir noktaya değinicem. aşağıdaki satırda
var rule = new FileSystemAccessRule(HesapAdi, FileSystemRights.FullControl, InheritanceFlags.None | InheritanceFlags.ContainerInherit | InheritanceFlags.ObjectInherit, PropagationFlags.None, AccessControlType.Allow);
FileSystemRights.FullControl kısmı bizim vereceğimiz izni belirtmektedir. biz bura da tam yetki vermişiz siz kendinize uygun olanı kullanabilirsiniz.
şimdide bu metodumuzu nasıl kullanıcaz örnek bir satırda bunu görelim.
YazimIzniVer("IIS_IUSRS", "C:\\inetpub\\wwwroot\\uygulamaklasorunuz\\image");
evet görünen şekilde metodumuza ilk olarak IIS 7 versiyonuna göre hesap adımızı verdik daha sonrada klasör yolumuzu. siz klasör yolunu bir değişken olarakta buraya atayabilirsiniz.
kodumuz çalıştığında image klasörüne belirlediğimiz izin verilecektir. Kolay gelsin...
64 BIT OS üzerindeki IIS te 32 BIT Uygulamaları Çalıştırmak
Geliştirdiğiniz 32 bit (x86) uygulamanızı 64 işletim sistemi üzerinde ki IIS sunucusunda çalıştırmak istediğinizde beklemediğiniz bir hata alabilirsiniz. Bu hatayı almamak için IIS sunucunuzun 32 bit uygulamaları çalıştıma özelliğini aktif etmeniz gerekmektedir. Bu işlem için ISS sunucunuzun arayüz programını girin application pools menüsüne tıklayın açılan pencerede sağtıklayıp ayarlara girin ve ilgili özelliği true yapın. iyi çalışmalar.
Kaydol:
Kayıtlar (Atom)