Osman KURT

Kendime Not

ASP.Net le Döviz Kuru Çekmek

İnternet te o kadar çok bu tarz yazı varkı, hepsine baktım çok gereksiz ve kafa karıştırıcı kodlar kullanmışlar arkadaşlar.Bende bu yüzden kısa ve öz bir şekilde size anlatmaya karar verdim alt kısımda vereceğim kodları kulandığınız takdirde sorunsuz bir şekilde döviz kurlarını çekebilirsiniz. İlk olarak default.aspx kodlarımızı yazalım.

<table style="width: 100%; height: 75px">
    <tr>
        <td align="center">Dolar<br />
            <asp:Label ID="Label3" runat="server" Text=""></asp:Label>
            &nbsp;TL
        </td>
        <td align="center">Euro<br />
            <asp:Label ID="Label4" runat="server" Text=""></asp:Label>
            &nbsp;TL
        </td>
    </tr>
</table>

Şimdi ise default.aspx.cs sayfamıza geçelim ve merkez bankası xml dosyasını okuyalım.

XmlDocument xmlVerisi = new XmlDocument();
xmlVerisi.Load("http://www.tcmb.gov.tr/kurlar/today.xml");
decimal dolar = Convert.ToDecimal(xmlVerisi.SelectSingleNode(string.Format("Tarih_Date/Currency[@Kod='{0}']/ForexSelling", "USD")).InnerText.Replace('.', ','));
decimal Euro = Convert.ToDecimal(xmlVerisi.SelectSingleNode(string.Format("Tarih_Date/Currency[@Kod='{0}']/ForexSelling", "EUR")).InnerText.Replace('.', ','));
Label3.Text = dolar.ToString();
Label4.Text = Euro.ToString();

 

Bu kodlarımızı da yazdıktan sonra işlemimiz tamalanmıştır. Artık sitenizde döviz kurlarını barındırıyorsunuz.

Görüşmwk Üzere;

Osman KURT

Yazılım Geliştirici ve Grafiker

 

ASP.Net Dosya İşlemeleri

Dosya İşlemleri

Bir ASP.NET uygulamasında dosya sınıfını kullanarak dosyalara erişip, bu dosyalar üzerinden işlem yapmak mümkündür.


Bir ASP.NET uygulamasında dosya sınıfını kullanarak dosyalara erişip, bu dosyalar üzerinden işlem yapmak mümkündür.  Bu işlemler ; dosya oluşturmak, silmek, taşımak, kopyalamak ve bu dosyaları okuyup üzerine yazıp, dosya özelliklerini görebilmektir.
Bu işlemleri yapabilmek için sayanıza  System.IO uzayını eklememiz gerekmektedir.
Dosya Silme
Bir dizin altındaki dosyayı silmek için Delete() metodu kullanılır.
File.Delete(silinecek olan dosyanın yolu)
Silinecek olan dosyanın  yolu fiziksel yol yada  Server.MapPath() kullanarak göreceli yol olarak belirtilebilir.
File.Delete("c:\Projeler\Resimler\aslan1.jpg");
File.Delete(Server.MapPath("../Resimler/aslan.jpg"));
Dosyanın Olup Olmadığını Kontrol Etmek
Bir dosya üzerinde işlem yapmadan önce dosyanın olup olmadığını kontrol etmek isteyebilirsiniz.  Bir dosyayı silmek istendiğinde dosya yoksa çalışma zamanı hatası alınır. File.Exists()  metodu dosyanın olup olamdığını kontrol etmek için kullanılır.
File.Exists(kontrol edilecek olan dosyanın yolu)
Bu metot dosyanın durumuna göre True ya da False döndermektedir.  Aşağıdaki kod önce dosyanın olup olmadığını kontrol edip, dosya varsa silme işlemini gerçekleştirmektedir.
if(File.Exists("Dosya yolu"))
{
  File.Delete("Dosya yolu");
}

Dosya Taşıma
Bir dosyayı bir yerden başka bir yere taşımak mümkündür. Bunun için File.Move() metodu kullanılır.
File.Move("hedef dosya","taşınacak yer");
Hedef dosya taşımak istediğiniz dosyanın yoludur. Taşınacak yer ise dosyanızın taşınacağı yerdir. Eğer hedef dosyanız yoksa ya da taşıyacağınız yerde aynı dosyadan var ise hata alırsınız. Aşağıdaki kod önce taşınacak olan dosyanın olup olmadığını ve taşınacak olan yerde taşınacak dosyadan olup olmadığını kontrol edip, koşullar uygunsa dosya taşınmaktadır.
if((File.Exists(@"c:\Resimler\ozlem.JPG")) && (!File.Exists(@"c:\Resimler2\ozlem.JPG")))
    
{
  File.Move(@"c:\Resimler\ozlem.JPG",@"c:\Resimler2\ozlem.JPG");
}

Dosyayı bir yere taşırken farklı bir isim verirseniz, dosya taşınırken farklı bir isimle taşınmaktadır.
if((File.Exists(@"c:\Resimler\ozlem.JPG")) && (!File.Exists(@"c:\Resimler2\ben.JPG")))
    
{
  File.Move(@"c:\Resimler\ozlem.JPG",@"c:\Resimler2\ben.JPG");
}

Yukarıdaki kod ile ozlem isimli dosya resimler2 dosyasına ben olarak taşınmaktadır.
Dosya Kopyalamak
Dosyalar bir klasörden başka bir klasöre File.Copy() kullanılarak kopyalanabilmektedir.  Copy() metodu ile Move metodunda olduğu gibi dosyalar silinmemektedir.
File.Copy("Hedef dosya","Taşınacak yer");
if((File.Exists(@"c:\Resimler\ozlem.JPG")) && (!File.Exists(@"c:\Resimler2\ozlem.JPG")))
    
{
   File.Copy(@"c:\Resimler\ozlem.JPG",@"c:\Resimler2\ozlem.JPG");
}


Dosya Özellikleri
Dosyalara ait bazı özellikleri öğrenebilmek mümkündür.
GetCreationTime() : Bu metot  dosyanın oluşturulduğu zaman ve tarihi vermektedir.
GetLastAccessTime(): Bu metot dosyaya en son girilen zaman ve tarihi vermektedir.
GetLastWriteTime(): Bu metot dizindeki dosyaya en son yazılan zaman ve tarihi vermektedir.
File.GetCreationTime("Dosya Yolu");
File.GetLastAccessTime("Dosya Yolu");
File.GetLastWriteTime("Dosya Yolu");

ASP.NET 2.0 ile Metin Dosyalarını Okuma ve Yazma
   
StreamReader ve StreamWriter sınıflarını kullanarak; ASP.NET 2.0 da text dosyalarını okuma ve yazma işlemini gösteren basit bir uygulama.
   
Bu makalede StreamReader ve StreamWriter sınıflarını kullanarak; ASP.NET 2.0 da text dosyalarını okuma ve yazma işlemini gösteren basit bir uygulama yapacağız. Dil olarak C# kullandım ama kolaylıkla diğer dillere de çevirebilirsiniz.
   
Herhangi bir text dosyasını System.IO.StreamReader sınıfını kullanarak; bir Textbox kontrolü içinde okumak için aşağıda verdiğim kodu kullanın:
   
System.IO.StreamReader StreamReader1 = new System.IO.StreamReader(Server.MapPath("test.txt"));
TextBox2.Text = StreamReader1.ReadToEnd();
StreamReader1.Close();
   
   
if (System.IO.File.Exists(Server.MapPath("test.txt")))
   
System.IO.StreamWriter sınıfını kullanarak; Textbox kontrolünün içeriğini, bir text dosyasına yazmak için aşağıda verdiğim kodu kullanın:
   
System.IO.StreamWriter StreamWriter1 = new System.IO.StreamWriter(Server.MapPath("test.txt"));
StreamWriter1.WriteLine(TextBox1.Text);
StreamWriter1.Close();

   
Yukarıdaki örnekte StreamWriter sınıfı, eğer dosya daha önceden yaratılmamışsa bir dosya yaratacak; ve eğer yaratılmışsa üzerine yazacak.
   
"\r\n" ekleyerek; text dosyanızda satır başı oluşturabilirsiniz. Kod tarafından satır başı ekleme aşağıdaki kodu kullanarak yapılabilir:
   
StreamWriter1.WriteLine("Some text on line1.\r\nSome text on line2.");
   
Aşağıdaki örnek kod, iki textbox kontrolü içeren bir web sayfasıdır. Üstteki textbox ı düzenleyin ve kayıt butonuna tıklayın. Text dosyası üstteki textbox ın içindeki yazıyı kullanarak yaratılacaktır ve web sayfası ile aynı sanal dizine kaydedilecektir. Yeni oluşuturulan text dosyası daha sonra alttaki textbox içine daha önceden kaydedilen değişiklikleri göstermek için yüklenir.
   
Bu basit örnekte; StreamReader ve StreamWriter sınıflarının kullanılan birçok kullanım çeşidinden sadece birkaçını gösterdik. Bu sınıflar sadece text dosyaları için değil, text dosyası gibi çalışan tüm benzerleri içinde kullanılır. XML, web sayfaları, sınıflar (.cs ya da .vb) ve daha onlarcası bunlara örnektir.
 
 
OkuYaz.aspx
 
<%@ Page Language="C#" %>
   
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
   
<script runat="server">
   
    void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            TextBox1_Load();
        }
    }
   
    void Button1_Click(object sender, EventArgs e)
    {
        System.IO.StreamWriter StreamWriter1 = new System.IO.StreamWriter(Server.MapPath("test.txt"));
        StreamWriter1.WriteLine(TextBox1.Text);
        StreamWriter1.WriteLine("Line1.\r\nLine2.");
        StreamWriter1.Close();
        TextBox2_Load();
    }
   
    void TextBox1_Load()
    {
        if (System.IO.File.Exists(Server.MapPath("test.txt")))
        {
            System.IO.StreamReader StreamReader1 = new System.IO.StreamReader(Server.MapPath("test.txt"));
            TextBox1.Text = StreamReader1.ReadToEnd();
            StreamReader1.Close();
        }
        else
        {
            TextBox1.Text = "Yeni Dosya.";
        }
    }
   
    void TextBox2_Load()
    {
        if (System.IO.File.Exists(Server.MapPath("test.txt")))
        {
            System.IO.StreamReader StreamReader1 = new System.IO.StreamReader(Server.MapPath("test.txt"));
            TextBox2.Text = StreamReader1.ReadToEnd();
            StreamReader1.Close();
        }
    }
</script>
   
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    <title>Text Dosyasini Düzenle</title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <b><span style="font-family: Verdana">Text Dosyasini Düzenle</span></b><br />
        <asp:TextBox ID="TextBox1" Runat="server" Width="400px" Height="200px" TextMode="MultiLine"></asp:TextBox><br />
        <asp:TextBox ID="TextBox2" Runat="server" Width="400px" Height="198px" TextMode="MultiLine" Enabled="False"></asp:TextBox><br />
        <asp:Button ID="Button1" Runat="server" Width="60px" Height="20px" Text="Kaydet" OnClick="Button1_Click" />
    </div>
    </form>
</body>
</html>

Görüşmek Üzere

Osman KURT

Yazılım Geliştirici ve Grafiker

ASP.Net ve Linq Kullanımı

Arkadaşlar bu yazımda size asp.net linq mimarisinde ekleme silme güncelleme ve verileri görüntülemeyi gösterecğim.

Projemiz de kullanacağımız veri tabanımız;

 

İsterseniz ilk olarak bir web projesi oluşturalım ve açtığımız projeye visual stdio da sağ tıklayıp new ıtem diyerek Linq to SQL Classes ekliyoruz. Açılan pencereye veri tabanımızda ki abloları çekiyoruz. İşlemlerde kullanıcağımız tabloların tamamının burda olması gerekmektedir.

Şimdi bu işlemleri yaptıkdan sonr işlemlerimizi geçelim ilk olarak veri tabanımıza ekleme yapmayı öğrenelim isterseniz;

KayitEkle.aspx sayfamızı aşşağıdaki gibi tasarlayalım lütfen.

<table style="width:100%;">
<tr>
<td class="style1">
<asp:Label ID="Label1" runat="server" Text="Adınız Soyadınız"></asp:Label>
</td>
<td>
<asp:TextBox ID="txtAdSoyad" runat="server"></asp:TextBox>
</td>
</tr>
<tr>
<td class="style1">
<asp:Label ID="Label2" runat="server" Text="Kullanıcı Adınız"></asp:Label>
</td>
<td>
<asp:TextBox ID="txtKullaniciAdi" runat="server"></asp:TextBox>
</td>
</tr>
<tr>
<td class="style1">
<asp:Label ID="Label3" runat="server" Text="Şifre"></asp:Label>
</td>
<td>
<asp:TextBox ID="txtSifre" runat="server"></asp:TextBox>
</td>
</tr>
<tr>
<td class="style1">
&nbsp;</td>
<td>
<asp:Button ID="btnKaydet" runat="server" onclick="btnKaydet_Click"
Text="Kaydet" />
</td>
</tr>
</table>

Bu kodlarımızı yazdıktan onra şimdi cs kodlarımıza geçelim;


OsmkrtDataContext Osm = new OsmkrtDataContext();
Kullanicilar KullaniciInsert = new Kullanicilar
{
AdSoyad = txtAdSoyad.Text,
KullaniciAdi = txtKullaniciAdi.Text,
Sifre = txtSifre.Text
};
Osm.Kullanicilars.InsertOnSubmit(KullaniciInsert);
Osm.SubmitChanges();

Gördüğünüz gibi ekleme işlemimiz bu kadar kısa sürdü. Veritabanımızı zaten mimariye dahil ettiğimiz için sorunsuz bir şekilde ekleme işlemi gerçekleşecektir.

Şimdi Eklediğimiz veriyi çekmeyi gösteriyim ben en iyisi;

VerileriGoster.aspx sayfamıza bir adet GrdiView atıyoruz


<asp:GridView ID="GridView1" runat="server">
</asp:GridView>

Şimdi ise VerileriGoster.aspx.cs sayfamızı kodlamaya geçelim;


OsmkrtDataContext Osm = new OsmkrtDataContext();
var HakkimizdaSelect = from h in Osm.Hakkimizdas
select h;
GridView1.DataSource = HakkimizdaSelect;
GridView1.DataBind();

İşte Bu kadar basit. Verilerimizi çektik ve gridview de gösterdik.

Hadi Bide güncelleme yapalım ne derseniz. Guncelle.aspx diye bir web sayfası oluşturuyoruz ve Altına şu kodarımızı yazıyoruz;


<table style="width:100%;">
<tr>
<td class="style1">
<asp:Label ID="Label1" runat="server" Text="Adınız Soyadınız"></asp:Label>
</td>
<td>
<asp:TextBox ID="txtAdSoyad" runat="server"></asp:TextBox>
</td>
</tr>
<tr>
<td class="style1">
<asp:Label ID="Label2" runat="server" Text="Kullanıcı Adınız"></asp:Label>
</td>
<td>
<asp:TextBox ID="txtKullaniciAdi" runat="server"></asp:TextBox>
</td>
</tr>
<tr>
<td class="style1">
<asp:Label ID="Label3" runat="server" Text="Şifre"></asp:Label>
</td>
<td>
<asp:TextBox ID="txtSifre" runat="server"></asp:TextBox>
</td>
</tr>
<tr>
<td class="style1">
&nbsp;</td>
<td>
<asp:Button ID="btnGuncelle" runat="server"
Text="Guncelle" onclick="btnGuncelle_Click" />
</td>
</tr>
</table>

Bu kodlarımızı yazdık ve cs syfamıza geçiyoruz şu kodları yazıyoruz;

OsmkrtDataContext Osm = new OsmkrtDataContext();
protected void Page_Load(object sender, EventArgs e)
{
if (Request.QueryString["ID"]==null)
{

}
else
{
var KullaniciId = int.Parse(Request.QueryString["ID"].ToString());
var Guncelle = from g in Osm.Kullanicilars
where g.ID == KullaniciId
select g;
foreach (var user in Guncelle)
{
txtAdSoyad.Text = user.AdSoyad;
txtKullaniciAdi.Text = user.KullaniciAdi;
}
}
}
protected void btnGuncelle_Click(object sender, EventArgs e)
{
if (Request.QueryString["ID"]==null)
{

}
else
{
var KullaniciId = int.Parse(Request.QueryString["ID"].ToString());
var KullaniciUpdate=from u in Osm.Kullanicilars
where u.ID==KullaniciId
select u;
foreach (var user in KullaniciUpdate)
{
user.Sifre = txtSifre.Text;
}
Osm.SubmitChanges();
}
}

Bu kodlarımızı yazdık yalnız ben bu projede ıd değerini elimle yazdım sizlere göstermek amacıyla siz istediğiniz gibi kullanmakta özgürsünüz.

Şimdi güncelle işlemimiz de bittiğine göre son olarak verileri silme işlemine geçebiliriz.

Sil.aspx diye bir sayfa oluşturuyoruz ve sayfamıza ;


<table style="width:100%;">
<tr>
<td class="style1">
<asp:Label ID="Label1" runat="server" Text="Adınız Soyadınız"></asp:Label>
</td>
<td>
<asp:TextBox ID="txtAdSoyad" runat="server"></asp:TextBox>
</td>
</tr>
<tr>
<td class="style1">
<asp:Label ID="Label2" runat="server" Text="Kullanıcı Adınız"></asp:Label>
</td>
<td>
<asp:TextBox ID="txtKullaniciAdi" runat="server"></asp:TextBox>
</td>
</tr>
<tr>
<td class="style1">
<asp:Label ID="Label3" runat="server" Text="Şifre"></asp:Label>
</td>
<td>
<asp:TextBox ID="txtSifre" runat="server"></asp:TextBox>
</td>
</tr>
<tr>
<td class="style1">
&nbsp;</td>
<td>
<asp:Button ID="btnSil" runat="server"
Text="Sil" onclick="btnSil_Click"/>
</td>
</tr>
  </table>

Bu kodlarımızı yazıyoruz. Bu kodlarımızı yazdıktan sonra ise cs tarafına geçiyoruz ve alt kısımda ki kodlarımızı oraya yazmaya başlıyoruz;


OsmkrtDataContext Osm = new OsmkrtDataContext();
protected void Page_Load(object sender, EventArgs e)
{
if (Request.QueryString["ID"] == null)
{

}
else
{
var KullaniciId = int.Parse(Request.QueryString["ID"].ToString());
var Sil = from d in Osm.Kullanicilars
where d.ID == KullaniciId
select d;
foreach (var user in Sil)
{
txtAdSoyad.Text = user.AdSoyad;
txtKullaniciAdi.Text = user.KullaniciAdi;
}
}
}
protected void btnSil_Click(object sender, EventArgs e)
{
if (Request.QueryString["ID"] == null)
{

}
else
{
var KullaniciId = int.Parse(Request.QueryString["ID"].ToString());
var KullaniciDelete = from d in Osm.Kullanicilars
where d.ID == KullaniciId
select d;
Osm.Kullanicilars.DeleteAllOnSubmit(KullaniciDelete);
Osm.SubmitChanges();
}
}

Yine ben burda id değerini elimle girmeyi tercih ettim siz göster sayfasından verecğiniz bir linkle(querstring) ile bu işlemi çok güzel bir şekilde gerçekleştirebilirsiniz.

Linq kullanımı bu kadar basit işte arkadaşlar. Gece oturdum ya o kadar bannerimde linq yazıyo bi yazı paylaşmadım dedim. Ben linq yapısını çok beğendim ama ne sebepten dir projelerimde kullanmıyorum. Elbet bir gün işimize yarayavaktır. Umarımsize de faydalı olur.

Görüşmek Üzere;

Osman KURT

Yazılım Geliştirici ve Grafiker