Taksim

Tarih: Perşembe, Şubat 25, 2010 Kategori: Genel

İstiklal caddesi, Asmalı Mescit, Tepebaşı, Galatasaray, Nevizade, Cihangir, Gümüşsuyu, Kurtuluş, Elmadağ, Cezair sokak, Fransız sokağı, Sıraselviler, Firuzağa, Hayriye cad., İmam Adnan sok., Yeşil çam sok., Büyük Parmak Kapı sok., Tam neresi iyi bi öğrenmeye, onlarca yıldır baktığım Taksim’e artık sadece bakmaya değil görmeye karar verdim.

Geç mi kaldım?

Daha yeni başlıyorum.  Sırada, Sur içi İstanbulu, Üsküdar, Beşiktaş, Boğaz’ın iki yanı, Haliçin iki yanı ve adalar var.

Bi yerden başlamak gerek.

C# ile Word dosyası oluşturma ve Word dosyasını açma.

Tarih: Cuma, Ocak 22, 2010 Kategori: Genel

C# ile Microsoft Word Dokümanı Oluşturma ve Açma

Bu makalemde sizlere c# yardımı ile varolan bir microsoft word dokümanını nasıl açabileceğinizi ve yeni bir Microsoft word dokümanını nasıl oluşturabileceğinizi anlatmaya çalışacağım.

Bu işlem için öncelikle bir Windows Application Project oluşturalım ve ismini de wordapp olarak verelim.Bu işlemden sonra karşımıza gelen Windows Form nesnesi üzerine iki adet button ve bir adet de openfiledialog nesnesi yerleştirelim. Bütün bu işlemleri yerine getirdikten sonra formumuzun görünümü Şekil 1′deki gibi olacaktır.

Şekil 1. Form Görünümü

.NET üzerinden Microsoft Word ile ilgili işlemleri yapabilmemiz için .NET Project’imize Microsoft Word 11.0 Object Library isimli COM referansı eklememiz gerekmektedir. Bunun için Solution Explorer penceresi üzerinde bulunan References seçeneği üzerinde sağ tuşa tıklayalım ve Add Reference seçeneğini seçelim. Karşımıza gelen pencerede COM sekmesini seçip buradan Microsoft Word 11.0 Object Library referansını bulup OK tuşuna basalım. Böylece projemiz için gerekli olan COM referansı projemize eklemiş olacağız. Bu durum Şekil 2′de gösterilmiştir.

Şekil 2. Referans Ekleme

Programımızı yazmaya başlamadan önce formumuzun kod kısmına geçerek aşağıdaki namespace’i kodumuza eklememiz gerekir.

using Microsoft.Office.Interop.Word;

Bu işlemden sonra programımızı yazmaya başlayabiliriz. Öncelikle Form1 classımız içerisinde Application class türünde global bir nesne tanımlamalıyız.

ApplicationClass uygulama = new ApplicationClass();

Bundan sonra “Word Dokumanı Aç” etiketli butonun click event’ine aşağıdaki kod parçası yazılmalıdır.

private void button1_Click(object sender, EventArgs e)
{
if (openFileDialog1.ShowDialog() == DialogResult.OK)
{
//Açılacak Olan Dosya Adını gösteren değişken
object dosyaadi = openFileDialog1.FileName;
//Açılan dokumanın salt okunur olup olamayacağını belirleyen değişken
object sadeceokunur = false;
//Açılan dokumanın gösterilip gösterilmeyeceğini belirleyen değişken
object gorunur = true;
object missing = System.Reflection.Missing.Value;
//Word Programını görünür yapan satır
uygulama.Visible = true;
Document dosya = uygulama.Documents.Open(ref dosyaadi, ref missing, ref sadeceokunur, ref missing, ref missing, refmissing, ref missing, ref missing, ref missing, ref missing, ref missing, ref gorunur, ref missing, ref missing, ref missing, refmissing);
dosya.Activate();
//Açılan dokumanın ilk satırına parametre olarak gönderilen texti yazar
uygulama.Selection.TypeText(“Merhaba Dünya”);
//Bir alt satıra geçmenizi sağlar
uygulama.Selection.TypeParagraph();
//Sıradaki Satıra Tarihi ekleyen method
uygulama.Selection.InsertDateTime(ref missing, ref missing, ref missing, ref missing, ref missing);
uygulama.Selection.TypeParagraph();
}
}

Yukarıdaki kod yardımı ile seçtiğimiz bir word dokümanını c# yardımı ile açmış oluyoruz. Yukarıdaki kod da missing isimli parametreler dikkatinizi çekmiş olmalı. .NET’de com nesnelerine erişmek için opsiyonel olan parametreleri simüle etmede System.Reflection.Missing.Value değeri kullanılabilir. Ben de burada bir önceki cümlede anlattığım nedenle missing isimli değişkeni kullandım.

Şimdi de yeni bir word dokumanı oluşturalım. Bunun için de “Word Dokumanı Oluştur Butonunun” click event’ine aşağıdaki kodlar yazılmalıdır.

private void button2_Click(object sender, EventArgs e)
{
object missing = System.Reflection.Missing.Value;
//Yeni dokuman oluşturuluyor
Document dosya = uygulama.Documents.Add(ref missing, ref missing, ref missing, ref missing);
uygulama.Visible = true;
dosya.Activate();
//Yeni dosyadaki hizalamanın ortada olması sağlanıyor
uygulama.Selection.ParagraphFormat.Alignment = WdParagraphAlignment.wdAlignParagraphCenter;
//Yazı Koyu yapılıyor
uygulama.Selection.Font.Bold = (int)WdConstants.wdToggle;
// Yazı dokumana yazdırılıyor
uygulama.Selection.TypeText(“İlk Dokuman”);
}

Bu makalemde sizlere .NET Yardımı ile bir word dokümanının nasıl açılabileceğini ve yeni bir word dokümanının nasıl oluşturulabileceğini anlatmaya çalıştım. Bir sonraki makalede görüşmek üzere.

Kaynaklar:
1. csharpcorner

XML ile Adres Defteri

Tarih: Cuma, Ocak 22, 2010 Kategori: Genel
Xml Ile Adres Defteri
XML(Extensible Markup Language) dilinde veriler bazı işaretlerle (etiket) işaretlenirler. Örneğin bir HTML kodunda bir başlık yazısı <h1> etiketi ile işaretlenir. Sonuç olarak bir belgedeki verileri işaretlemeye yarayan dillere işaretleme dilleri denir.

W3C (World Wide Web Consortium) organizasyonu tarafından tasarlanan  XML , kişilerin kendi sistemlerini oluşturabilecekleri, kendi etiketlerini tanımlayarak çok daha rahat ve etkin veri haznesi yapabilecekleri ve bu belirlenen etiketleri kendi yapıları içerisinde standardize edebilecekleri esnek, genişleyebilir ve kolay uygulanabilir dildir.

Çok farklı tipteki verileri orjinal formatlarında tek bir havuzda tutabilen XML, bilgiye hızlı, kolay ve ortamdan bağımsız olarak erişebilme imkanı sunar. Günlük yaşantımızda kullanmakta olduğumuz verilerin %80’ini oluşturan ve “unstructured” olma özellikleri nedeniyle kendi bulundukları medya dışında veri özelliklerini koruyamayan (kelimeişlem, elektronik tablo çıktıları, PDF dokümanları, ses,resim vb) farklı tipteki verilerin, oryantasyona gerek duymadan hiyerarşik bir yapıda kullanılabilmelerine olanak vermekte ve bu verilerin hızlı bir şekilde sorgulanabilmelerini sağlamaktadır. Öncelikle veri transferinin kolaylaşmasını ve verinin içerik bilgisiyle saklanabilmesini hedefleyen XML, içerik ve sunum bilgilerini birbirinden ayırır. Bu özelliği ile de HTML”den farklılaşır

XML in diğer bir özelliği ise farklı platformlar arasında veri taşınabilmesine imkan sunmasıdır.

Örnek olarak bir adres defteri yapıp inceleyecegiz. Uygulamamıza system.xml namespaceini import edeceğiz. Yarattıgımız XML dosyamız

<?xml version=”1.0″ encoding=”utf-8″?>
<myAddresses>
<myAdress>
<name>Adım</name>
<surname>Soyadım</surname>
<address>Adresim</address>
<phone>Telefonum</phone>
</myAdress>
</myAddresses>
Şeklinde olacaktır.Adres defterimizdeki her kayıt <myAddresses> düğümünün içinde bulunacak ve bu kayıda ait alt bilgiler ise alt düğümlerde yer alacaktır. Bu xml dosyası uygulamamızda aynı klasörde ve adress.xml ismindedir.
Sub GetAddresses()
Dim ds As New DataSet
ds.ReadXml(“adress.xml”)
If ds.Tables.Count > 0 Then
dgAdres.DataSource = ds.Tables(0)
Dim doc As New XmlDocument
doc.Load(“adress.xml”)
Dim currentNode As XmlNode
currentNode = doc.DocumentElement
Label1.Text = “Toplam ” & currentNode.ChildNodes.Count.ToString & ” adet kayıt bulundu.”
Else
Label1.Text = “Kayıt Bulunamadı
End If
End Sub

Uygulamamızda bu XML dosyasının verilerini datasete aktarmak için datasetin ReadXml() metodunu kullanabiliriz.ReadXml metodu ile xml dosyanın yapısını tamamen içeren bir dataset oluşacaktır. Ve biz bu dataseti i datagrid in source u olarak gösterirsek verileri datagridimize doldurabiliriz. Yukarıda bulunan sub bu işlemi yapmaktadır, ancak xml dosyada veri bulunmuyorsa dataset in içindeki tablo dolmayacağından tablo oluşmayacaktır. Bundan dolayı tablo oluşmuyorsa belirlediğimiz bir label da kayıt yok yazısını yazdırmamız uygun olacaktır.Kaç kayıt döndüğünü saymak için ise root elementimizin altındaki child node ların sayısını alabiliriz.
Private Sub btnDelete_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnDelete.Click
Dim doc As New XmlDocument
doc.Load(“adress.xml”)
Dim node As XmlNode
Dim currentNode As XmlNode
currentNode = doc.DocumentElement
node = currentNode.SelectSingleNode(“//myAdress[name="" & dgAdres.Item(dgAdres.CurrentRowIndex, 0).ToString & ""][surname="" & dgAdres.Item(dgAdres.CurrentRowIndex, 1).ToString & ""][address="" & dgAdres.Item(dgAdres.CurrentRowIndex, 2).ToString & ""][phone="" & dgAdres.Item(dgAdres.CurrentRowIndex, 3).ToString & ""]“)
currentNode.RemoveChild(node)
doc.Save(“adress.xml”)
End Sub
Seçili bir kayıdı silmek için yazdığımız bu sub da ise ilk önce bir tane xmlDocument tanımlayarak ve load metodunu kullanarak xml dosyamızı programımızda açıyoruz.Current node değişkenine root elementimizi atıyoruz. Ve root elementimizin altından selectsinglenode kullanarak tek bir düğümü geri döndürecek şekilde bir sorgulama yaptırıyoruz.Bu sorgulamada datagridde bulunan her bir hücredeki veriyi barındıran benzersiz olması gereken düğümü geriye döndürüyoruz ve bulundugumuz düğümün removechild metodunu kullanarak sorgulama sonucu elde ettiğimiz düğümü kaldırıyoruz. Burada unutulmaması gereken xml dosyayı programımızda açıp değişiklik yaptıktan sonra mutlaka save metodunu kullanarak kaydetmemizdir.
Private Sub btnSearch_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnSearch.Click
Dim xmlnodename As String
Select Case cbCriteria.SelectedItem.ToString
Case “Ad”
xmlnodename = “name”
Case “Soyad”
xmlnodename = “surname”
Case “Adres”
xmlnodename = “address”
Case “Telefon”
xmlnodename = “phone”
End Select
Dim doc As New XmlDocument
doc.Load(“adress.xml”)
Dim currentNode As XmlNode
currentNode = doc.DocumentElement
Dim results As XmlNodeList
If CheckBox1.Checked Then
results = currentNode.SelectNodes(“//myAdress[contains(" & xmlnodename & ","" & txtSearch.Text & "")]“)
Else
results = currentNode.SelectNodes(“//myAdress[" & xmlnodename & "="" & txtSearch.Text & ""]“)
End If
Dim x As Integer
Dim ds As DataSet = New DataSet
Dim xReader As XmlTextReader
For x = 0 To results.Count – 1
xReader = New XmlTextReader(results.Item(x).OuterXml, XmlNodeType.Element, New XmlParserContext(Nothing, Nothing, Nothing, XmlSpace.None))
ds.ReadXml(xReader, XmlReadMode.InferSchema)
Next x
If ds.Tables.Count > 0 Then
dgAdres.DataSource = ds.Tables(0)
Label1.Text = “Toplam ” & ds.Tables(0).Rows.Count & ” adet kay? bulundu.”
Else
dgAdres.DataSource = Nothing
Label1.Text = “Kay? Bulunamad?
End If
End Sub
Xml dosya içinde arama yapmak için ise silmede yaptığımız gibi xml document i açarak içinden uygun kriterlere göre düğümlerden oluşan bir nodelist döndürmek. Ancak burada sorgulama bire bir eşleşen kayıtları bulmak için = kullanarak içinde geçen kelimeye göre kayıt bulmak için xpath komutlarından contains i kullanarak olmaktadır. Fakat şimdi oluşturduğumuz bu xml dosyadaki düğüm listesini dataset e aktarmak için xmltextreader kullanarak geçici bir xml dosya yapısı elde ediyoruz. ve bunu dataset e aktarıyoruz.
Sub AddAddress()
Dim doc As New XmlDocument
doc.Load(“adress.xml”)
Dim NewMyAdress As XmlNode = doc.CreateElement(“myAdress”)
Dim newName As XmlNode = doc.CreateElement(“name”)
Dim newSurname As XmlNode = doc.CreateElement(“surname”)
Dim newAddress As XmlNode = doc.CreateElement(“address”)
Dim newPhone As XmlNode = doc.CreateElement(“phone”)
Dim NewnameText As XmlNode = doc.CreateTextNode(txtName.Text)
Dim NewsurnameText As XmlNode = doc.CreateTextNode(txtSurname.Text)
Dim NewaddressText As XmlNode = doc.CreateTextNode(txtAddress.Text)
Dim NewphoneText As XmlNode = doc.CreateTextNode(txtPhone.Text)
NewMyAdress.AppendChild(newName)
newName.AppendChild(NewnameText)
NewMyAdress.AppendChild(newSurname)
newSurname.AppendChild(NewsurnameText)
NewMyAdress.AppendChild(newAddress)
newAddress.AppendChild(NewaddressText)
NewMyAdress.AppendChild(newPhone)
newPhone.AppendChild(NewphoneText)
Dim targetnode As XmlNode
targetnode = doc.SelectSingleNode(“//myAddresses”)
targetnode.AppendChild(NewMyAdress)
doc.Save(“adress.xml”)
End Sub

XML dosyada kayıt eklemeler root element içine yapılacağından her node tek tek yaratılır. ve en alttaki node içine yazılması gereken değerler de yaratıldıktan sonra nodelar hiyerarşik yapılarına göre birbirlerine appendChild metodu kullanılarak bağlanır. ve birbirlerinin altında yer almaları sağlanarak bir tek node altında kayıtlar oluşturulur. Bu kayıdı taşıyan node ise root elemente append child ile eklenerek döküman kaydedilir ve xml dosyaya veri ekleme işi bitirilir.
Sub getUpdateInformation()
For Each xe As XmlElement In Guncellemi
If xe.Name = “name” Then
txtName.Text = xe.InnerText
ElseIf xe.Name = “surname” Then
txtSurname.Text = xe.InnerText
ElseIf xe.Name = “address” Then
txtAddress.Text = xe.InnerText
ElseIf xe.Name = “phone” Then
txtPhone.Text = xe.InnerText
End If
Next
End Sub
Güncelleme yapmak için ilk önce seçili kayıdın bilgilerine ulaşmak gerekir buda yukarıda incelendiği gibi basit bir sorgu sonucu oluşan node ın içindeki değerlerin okunması ile elde edilir.
Private Sub btnUpdate_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnUpdate.Click
Dim doc As New XmlDocument
doc.Load(“adress.xml”)
Dim currentNode As XmlNode
currentNode = doc.DocumentElement
Guncellemi = currentNode.SelectSingleNode(“//myAdress[name="" & dgAdres.Item(dgAdres.CurrentRowIndex, 0).ToString & ""][surname="" & dgAdres.Item(dgAdres.CurrentRowIndex, 1).ToString & ""][address="" & dgAdres.Item(dgAdres.CurrentRowIndex, 2).ToString & ""][phone="" & dgAdres.Item(dgAdres.CurrentRowIndex, 3).ToString & ""]“)
Dim cust As XmlNode
Dim newNode As XmlNode
Dim NewMyAdress As XmlNode = doc.CreateElement(“myAdress”)
Dim newName As XmlNode = doc.CreateElement(“name”)
Dim newSurname As XmlNode = doc.CreateElement(“surname”)
Dim newAddress As XmlNode = doc.CreateElement(“address”)
Dim newPhone As XmlNode = doc.CreateElement(“phone”)
Dim NewnameText As XmlNode = doc.CreateTextNode(txtName.Text)
Dim NewsurnameText As XmlNode = doc.CreateTextNode(txtSurname.Text)
Dim NewaddressText As XmlNode = doc.CreateTextNode(txtAddress.Text)
Dim NewphoneText As XmlNode = doc.CreateTextNode(txtPhone.Text)
NewMyAdress.AppendChild(newName)
newName.AppendChild(NewnameText)
NewMyAdress.AppendChild(newSurname)
newSurname.AppendChild(NewsurnameText)
NewMyAdress.AppendChild(newAddress)
newAddress.AppendChild(NewaddressText)
NewMyAdress.AppendChild(newPhone)
newPhone.AppendChild(NewphoneText)
Dim oldNode As XmlNode
Dim targetnode As XmlNode
targetnode = doc.SelectSingleNode(“//myAddresses”)
For Each nd As XmlNode In targetnode.ChildNodes
If nd.InnerText = Guncellemi.InnerText Then
oldNode = nd
End If
Next
cust = currentNode.ReplaceChild(NewMyAdress, oldNode)
doc.Save(“adress.xml”)
Me.Close()
End Sub

Update işlemi için ilk önce seçtiğimiz kayıda ait verileri bulunduran düğümü seçiyoruz. Daha sonra ise verilerin yeni hallerini barındıran düğümü aynı yeni kayıt ekleme işleminde olduğu gibi oluşturuyoruz ve replaceChild metodunu kullanarak eski düğümü yeni düğümle değiştirip dosyamızı kaydediyoruz.
Private Sub btnExport_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnExport.Click
Dim doc As New XmlDocument
doc.Load(“adress.xml”)
Dim currentNode As XmlNode
Dim str As String
currentNode = doc.DocumentElement
For Each x1 As XmlNode In currentNode
For Each x2 As XmlNode In x1
str &= x2.InnerText & “,”
Next
str = str.Substring(0, str.Length – 1)
str &= vbNewLine
Next
SaveFileDialog1.ShowDialog()
Dim strwriter As New StreamWriter(SaveFileDialog1.FileName)
strwriter.Write(str)
strwriter.Close()
End Sub
Verileri dışarıyla ortak bir dosya olan csv yani Comma Separated Value (Virgülle ayrılmış değerler) olarak kaydediyoruz. Bunun için root element içindeki düğümlerde tek tek dolaşıp değerlerini alarak “,” lerle ayırarak yeni bir text dosyası oluşturuyoruz.

String veri türlerini inceleyelim.

Tarih: Pazartesi, Ocak 18, 2010 Kategori: Genel

String veri türleri hakkında yazmayı düşündüm. Hangi konulardan bahsediyim diye bakarken, şöyle bir yazı buldum.

Yıllardır bilgisayarlar kullanıcılarla iletişim kurmak için yazıyı kullanırlar. Programlama dillerinde karakter kelimesi, bir harf, sayı, noktalama işareti ya da bir sembol anlamına gelir. String kelimesi ise karakterlerin yan yana gelerek oluşturdukları dizi anlamına gelir. C# Dilinde string bir anahtar kelimedir. String türünde bir değişken tanımlarken aşağıdaki gibi yazarız.

string Yazi;

Burada Yazi adında, string türünde bir değişken tanımlaması yapılmıştır ya da başka bir deyişle, Yazi string bir değişkendir.

C#taki string veri türü .net Framework içerisindeki System.String sınıfının bir aliasıdır yani string yazmakla System.String yazmak aynı şeydir.

Yani aşağıdaki gibi de string değişken tanımlaması yapılabilir.

System.String Yazi;

Eğer programımızın üst kısmında using direktifi ile

using System;

yazmışsak, başındaki System. ifadesini yazmayabiliriz. Bunu zaten daha önceki yazılardan biliyorsunuz.

String Yazi;

Şimdi burada bir karışıklık oldu. Eğer usnig direktifi ile System isim uzayı direktifi yazılmışsa büyük harfle yazılan String yeterlidir ama C#ta bir veri türü olan ve küçük harfle yazılan string kelimesi de kendi başına System.String anlamına gelen bir alias olduğundan aşağıdaki gibi bir ifadeyi yazmak yanlış olur.

System.string Yazi; //Yanlış oldu.

Çünkü string kelimesinin karşılığı olan System.String ifadesini yukarıdaki ifadede yerine yazarsak

System.System.String Yazi; //Yanlış oldu.

yazmış oluruz. Tabi ki böyle bir ifade yoktur, çalışmaz.

Şimdi string türünde bir değişken nasıl tanımlanır öğrendiğimize göre değer ataması yapalım.

Yazi = "C#Türkü çok seviyorum.";

Yukarıdaki ifadenin sağındaki değere string literal denir. Bir string literal sıfır ya da daha fazla karakterden oluşur. Karakterin tanımını yukarıda yaptığımıza göre içinde neler bulunabileceği de açıktır: Harf, rakam, noktalama işareti ayda sembol. Dikkat ederseniz bir string literal çift tırnak arasına yazılır. Bu durumda string literali başlatan ve bitiren çift tırnak işaretleri string ifadenin kendisine dâhil değildir.

Yazı dilinde noktalı virgül, soru işareti gibi işaretler çift tırnakların içine yazılır. Ama C#ta noktalı virgül atama işlemini bitiren işarettir ve en sona yazılır. Karıştırmamak gerekir.

Bir string literal tek satır olmak zorundadır. Aşağıdaki atama işlemi çalışmayacaktır.

Yazi = “C#Türkü çok
seviyorum.”; // Yanlış oldu.

Tamsayılar yazısında da anlattığımız gibi, string türü değişkenlere de tanımlama esnasında ilk değer ataması yapabiliriz.

string Yazi = “C#Türkü çok seviyorum.”;

Bir stringi ekranda göstermek için daha önceden de bildiğimiz Console.Write ya da Console.WriteLine yöntemlerini kullanabiliriz.

Console.WriteLine(Yazi);

Bu ifade konsolda aşağıdaki gibi bir çıktı verecektir.

Çift tırnak işaretleri, ekranda görünmedi. Çünkü onlar string ifademizin bir parçası değildir. Bir değişken tanımlaması yapmadan da bir string ifadeyi direkt Console.Write ya da Console.WriteLine yöntemlerine geçebilirsiniz.

Console.WriteLine(“C#Türkü çok çok seviyorum”);

Console.WriteLine ile tamsayıları gösterebildiğimiz öğrenmiştik. Şimdi de string ifadeleri gösterebildiğini öğrendik. Bunu yapması mümkündür, çünkü Console.WriteLine yönteminin aynı isimde birden çok sürümü vardır. Aynı yöntemin birden çok sürümleri olmasına yöntemlerin aşırı yüklenmesi denir. Başka bir yazıda bu meseleyi anlatacağız.

Aşağıdaki ilginç örneği dikkatle inceleyelim.

using System;

class stringler

{

static void Main()

{

string A, B, C;

A = “Merhaba, “;

B = “Dünya”;

C = A + B;

Console.WriteLine(C);

Console.ReadLine();

}

}

Ekran çıktısını incelersek çok temel bir örnek, ama programda ilginç bir yer var. 3 tane değişken tanımladık. İlk 2 tanesine değer ataması yapma işlemi daha öncekilerle aynı, sadece sayı değil de yazı kullandık. 3. değişkene değer ataması yapma işlemi biraz ilginç görünüyor. Çünkü iki tane yazı arasında toplama işlemi yapmaya çalışyıoruz.

Bu ne anlama geliyor? Artı işareti iki tane string ifadeyi birleştirir. Programı çalıştırdığımızda aşağıdaki çıktıyı görürüz.

Merhaba dünya cümlesi çok meşhur bir programcı selamıdır. 1978 yılında C Programlama Dili kitabının yazarları Brian W. Kernighan ve Dennis M. Ritchie tarafından ilk defa kullanılan bu ilk yazılan programın dünyaya merhaba demesi olayı gelenek haline geldi.

Ama Kernighan ve Ritchie string birleştirme örneğini yapamadılar, çünkü standart C dilinde string birleştirme yoktur, hatta string yoktur.

Değişik işlemler için aynı operatörün kullanılması, mesela toplama operatörü, operatörlerin aşırı yüklenmesi olarak bilinir. Bu meseyi de yine başka bir yazıda anlatacağız.

Dikkat ederseniz A değişkenine bir string literal ataması yaptık ama virgülden sonra bir boşluk bıraktık. Çünkü 2 tane stringi birleştirdiğimizde arasına kendisi boşluk koymaz bunu bizim belirtmemiz lazım.

Stringlerle de yine artı eşittir operatörünü kullanabilirsiniz.

string Yazi = “Bu bir yazıdır.”;

Yazi += “Bu da bir yazıdır.”;

Artı eşit operatörü, ilk string ifadenin sonuna ikinci string ifadeyi ekler. Bunlardan başka diğer operatörler stringlerle kullanılmaz.

String birleştirme işlemi, eğer çok uzun bir string ifadeyi bir değişkene atayacaksak çok işlevseldir.

string Kavgam =

“Kader beni, iki Alman devletinin tam sınırları üzerinde bir kasabada,” +

“Braunau am Inn’de dünyaya getirdi. Alman olan Avusturya, büyük Alman vatanına” +

“tekrar dönmelidir. Hem bu birleşme, iktisadi sebeplerin sonucu olmamalıdır. ” +

“Bu birleşme, iktisadi bakımdan zararlı olsa bile, mutlaka olmalıdır.” +

“Aynı kan, aynı imparatorluğa aittir. “;

Aynı zamanda string literaller ile string değişkenlerin bir kombinasyonu olarak string birleştirmeyi kullanabilirsiniz.

string programlama_dili = “C# “;

Console.WriteLine(“Ben ” + programlama_dili + ” programlamayı çok seviyorum.” + ” Ya sen?”);

Yukarıdaki birleştirilmiş ifade aslında aşağıdaki şekilde ayrı ayrı da yazılabilir.

string programlama_dili = “C# “;

Console.Write(“Ben”);

Console.Write(programlama_dili);

Console.Write(” programlamayı çok seviyorum.”);

Console.WriteLine(” Ya sen?”);

Dikkat ederseniz ilk dört ifadede Console.Write kullanırken sonuncusunda Console.WriteLine kullandık. Çünkü Console.Write yöntemi imleci alt satıra geçirmez.

Yukarıda yazdığımız her iki örneğin de ekran çıktısı aşağıdaki şekildedir.

System.String sınıfının Length diye bir özelliği vardır. Yöntem ve alan gibi özellik de bu cümlede teknik terim olarak kullanıldı. Özellikler de alanlar gibidir. Başka bir yazıda alanlar ve özelliklerden bahsedeceğiz. Şimdilik sadece Length özelliğinin ne işe yaradığını bilelim. Bir string ifadenin karakter sayısını bize verir.

Kavgam.Length

ifadesi bize 327 sayısını verir.

C#ta stringleri çift tırnak arasına yazarız. Eğer string literalin kendi içinde çift tırnak varsa onu nası yazabiliriz? Mesela aşağıdaki gibi bir string literali ekranda göstermek istiyoruz.

Atalarımız boşuna söylememiş “sakla samanı, gelir zamanı” diye.

Bu tür özel karakterlerin kullanılması programlama dillerinde her zaman problem olur. C# çözümü C ve C++ dillerinden almıştır. Bir string literal çift tırnak içeriyorsa, çift tırnakların soluna bir ters bölü işareti koymalıyız.

string Yazi = "Atalarımız boşuna söylelemiş \"sakla samanı, gelir zamanı\" diye";

Bu ters bölü işareti burada kaçış karakteri olarak görev yaptı. Kaçış karakteri sağındaki özel işaretin gerçek anlamında kullanılmasını engeller.

Peki, ters bölü işaretinin kendisini yazı içerisinde nasıl kullanırız? Yazı dilinde belki çok fazla kullanılmayan bir işaret ama MS-DOS ya da Windows programlarında dizin isimlerini ayırmada ters bölü işareti kullanılır. Bu ters bölü işaretinin çok acıklı bir hikâyesi var. UNIX işletim sisteminde dizin isimleri normal bölü işareti ile ayrılır, ters bölü işaretiyle değil. C dilinde de kaçış karakteri olarak kullanılma sebebi hiçbir özel anlamı olmamasıdır. MS-DOS 1.0 işletim sisteminde ise UNIX benzeri hiyerarşik bir dizin yapısı olmadığından normal bölü işareti komut satırı argümanı olarak kullanıldı.UNIX işetim sisteminde komut satırı argümanlarının solunda çizgi vardır. MS-DOS 2.0 işletim sisteminde hiyerarşik dosya yapısı gelince, C dilinde problem olacağı hiç akıllarına gelmedi ve dizin isimlerini ayırmakta normal bölü işareti yerine ters bölü işareti kullanıldı.

Bir string literal içerisinde eğer ters bölü işareti varsa yan yana iki tane kullanırız.

string Dizin = “C:\\Makaleler\\String Makalesi\\Metin.doc”;

Şimdi bunu ekrana yazdırıp çıktısına bakalım.

Artık MS-DOS ya da Windows programlarında ters bölü işareti kullanma zorunluluğumuz yok, onun yerine normal bölü işareti de kullanabilirsiniz.

string Dizin = “C:/Makaleler/String Makalesi/Metin.doc”;

Bilgisayarın içerisinde bir string literalin karakterleri sayılarla ve nihayetinde bitlerle saklanır. Uzun yıllar, bir çok bilgisayar ASCII (American Standard Code for Information Interchange – Bilgi Değişimi İçin Amerikan Kod Standardı) dediğimiz bir karakter kodlaması kullandı. ASCII 7-bit kodlardan oluştuğu için toplam 128 (27) çeşit karakteri gösterebilir.

Eğer standart Amerikan İngilizcesi klavyesi kullanıyorsanız, Üst Karakter Tuşuna (Shift Tuşu) bağlı olarak (harf, sayı ya da sembollerden) 47 tane tuştan 94 tane karakter oluşturabilirsiniz. Boşluk tuşu ayrı bir ASCII karakteri ile temsil edilir. ASCII ayrıca, yazıda gösterilmeyen, yazının nasıl gösterileceğini kontrol eden 33 tane kontrol karakteri sağlar. Bunlardan sadece bazıları günümüzde kullanılıyor. Satır başı tuşu, Sonraki satıra geçme tuşu (Bu ikisi imlecin bir sonraki satırın başına gitmesini sağlar), Geri Al Tuşu, Tab Tuşu, ESC tuşu. Bütün ASCII karakterleri klavyeden Ctrl tuşunu harf ve sembol kombinasyonları ile kullanarak oluşturulabilir. Yani 128 tane ASCII kodunu klavyeden yazabiliriz.

Fonksiyon tuşları (F1,…, F12), yön tuşları ve imleç hareket tuşları biraz farklıdır. Bunlar ASCII kodu üretmezler.

Pratikte kişisel bilgisayarlar ASCII tarafından sağlanan 128 karakteri de içeren yazı karakterlerini göstermek için 8-bit kullanırlar. Bu 8-bit kodlamaya ise genişletilmiş ASCII karakter kodlama seti denir.

Maalesef, genişletilmiş ASCII, tek standart değildir. Orijinal IBM Bilgisayar çizgi çizmek ve basit matematik semboller için ek rarakterler de kullandı. Windows ise Batı Avrupa dillerinde kullanılan sembolleri göstermek için Latin 1 adlı bir kodlamayı da destekler. Bir çok ülkede standart komiteleri kendi karakter kodlamalarını oluşturdular. Tabi ki bunların içinde Latin olmayan Arapça, İbranice, Yunanca, Kiril (Rusça) da var.

Sonuç karışıklık ve belirsizlik oldu. Eğer başka bir ülkeden ya da Apple Machintosh gibi başka platformlardan gelen e-posta mesajları almışsanız ve bunlarda anlamsız karakterler görmüşseniz bunların sebebi iki değişik 8-bit karakter kodlamasıdır.

1980lerin başında bu problemlere bir çözüm bulmak için çalışmalar yapıldı. Sonuç Unicode oldu. Unicode; Çince, Japonca ve Korece gibi şekilsel alfabeler de dâhil, bilgisayar iletişiminde kullanılan bütün dillerin karakterlerini gösterebilecek şekilde 65,536 (216) tane karakter içeriyor, 16-bit kodlama kullanıyor. Unicode karakterlerinin ilk 128 karakteri yine ASCII’nin aynısıdır. İkinci 128 tanesi ise Latin 1 karakterlerinin aynısıdır. Unicode hakkında daha fazla bilgi http://www.unicode.org adresinde mevcuttur. Unicode Standart Verison 3.0 adlı kitabın online sürümüne de yine bu siteden ulaşabilirsiniz.

8-bit karakter kodlamalarının yerini 16-bit Unicode karakterlere bırakması için uzun bir yol var. Ama bazı programlama dilleri, mesela C#, stringleri 16-bit Unicode olarak tutuyor. Unicode ile aşağıdaki gibi bir string ifadeyi rahatlıkla yazabilirsiniz.

Hem Yunan alfabesi hem de derece işareti ASCII karakter tablosunda yoktur.

Yunan harflerini Yunanca klavye ile rahatlıkla yazarsınız, ama derece işareti Yunan klavyeside yoktur. Genellikle, bir Unicode karakteri string içerisinde kullanabilmek için karakteri Unicode standardı sürüm 3.0 şekilde yazmak lazım ya da http://www.unicode.org/charts adresindeki şekilde ve bir ters bölü şareti daha sonra küçük ya da büyük harflerle U ya da X koyduktan sonra 4-basamak hex karakter kodu yazarak gösterilir.

string Angle = “The angle \u03B1 equals 60\u00B0″;

İlginçtir ama \u ve 4-basamak hex karakter kodlarını değişken isimleri diğer belirteçlerde kullanabilirsiniz. bu konuda daha fazla bilgi için C# Language Specification, 2.4.2 özellik dokümanına bakabilirsiniz.

C# ayrıca C dilinden aşağıdaki kaçış durumlarını da miras almıştır.

Kaçış Karakterleri Unicode Kodlaması Karakter İsmi
\0 \u0000 Null
\a \u0007 Uyarı (beep)
\b \u0008 Geri al Tuşu
\t \u0009 Tab
\n \u000A Yeni Satır
\v \u000B Dikey Tab
\f \u000C Form besleme
\r \u000D Satır başı
\” \u0022 Çift Tırnak
\’ \u0027 Tek Tırnak
\\ \u005C Ters Bölü İşareti

Örneğin aşağıdaki ifadede ekrana yazı gösterirken \a karakterine gelince hoparlörden beep sesi çıkar ve devam eder. \a sadece konsolda geçerlidir. \v ve \f ise sadece yazıcıda geçerlidir.

Console.WriteLine(“Uyarı sinyali ver \a ve devam et.”);

ASCII kodlamasının çıkış kaynağı daktiloda kullnılan karakterlerdir. Mesela \r ve \n işlemini ancak daktilo ile anlayabiliriz. \r Satır başı kodu, yazma kafasını satırın başına getirir. \n ise yazma kafasını bir sonraki satıra geçirir. \n ve \r birlikte kullanıldığında bir sonraki satırın başına gitmiş oluruz. Text dosyalarda bu işlemler olmaz, platform uyumsuzluğu vardır. MS-DOS ve Windows platformlarında text dosyalarda bütün satırlar satır başı ve yeni satır kodlarıyla sonlanır. UNIX platformunda ise sadece yeni satır koduyla sonlanır. Macintosh ortamında ise sadece satır başı kodu satırı sonlandırır.

C# konsol programlamada, sadece yeni satır kodu bir sonraki satırın başına geçmek için yeterlidir.

Aşağıdaki ifadelerden her ikisi de aynı işi yapar.

Console.Write(“\n”);

Console.WriteLine();

C# kaçış karakteri olarak ters bölü kullnmaya bir alternatif sunar. Eğer bir string literalin önüne @ işareti koyarsak kaçış karakteri kullanmaya gerek kalmaz.

string Dizin = @”C:\Makaleler\\String Makalesi\Metin.doc”;

Buna verbatim string (harfi harfine – aynısı) de denir. Ters bölü işareti de normal diğer karakterlerden biri olarak algılanır.

Tabi bu durumda çift tırnak için iki tane çift tırnak kullanmak gerekiyor.

string Yazi = @”Atalarımız boşuna söylelemiş “”sakla samanı, gelir zamanı”" diye”;

Daha önce artı işaretinin string ifadeleri birleştirmek için kullanıldığını göstermiştik. Artı işaretini string ifadeleri sayılarla birlikte yazmak için de kullanabiliriz.

int toplamTutar = 100;
Console.WriteLine(“Toplam tutar :” + toplamTutar + ” YTL dir.”);

Burada kural oldukça basittir. Eğer artı operandının bir tarafındaki ifade string ise diğer tarafındaki ifade de string ifadeye dönüştürülür ve daha sonra da string birleştirme işlemi gerçekleşir.

Aşağıdaki ilginç durumu inceleyelim.

int A = 12;

int B = 20;

Console.WriteLine(A + B + ” toplamlarıdır.”);

Console.WriteLine(“Toplamları ” + A + B);

Yukarıdaki program kodunun çıktısı aşağıdaki gibi olacaktır.

Peki neden ikisi farklı çıktı. Operatör önceliği kavramından tamsayılar yazısında bahsetmiştik. Operatör önceliği kurallarına göre toplama işlemlerinde öncelik soldan sağa doğrudur. İlk ifadede soldan itibaren başlandığından önce A + B işlemi yapıldı daha sonra da string ifadeye dönüştürülerek sonraki string ifade ile birleştirildi. İkinci WriteLine çağrısında ise “Toplamları” string ifadesi 12 ile birleştirildi. Daha sonra “Toplamları 12” string literali 20 ile birleştirildi. “Toplamları 1220” ifadesi oluştu.

Bu problemi çözmek için aşağıdaki gibi bir çözüm bulabiliriz.

int A = 12;

int B = 20;

Console.WriteLine(A + B + ” toplamlarıdır.”);

Console.WriteLine(“Toplamları ” + (A + B));

Parantezlerin toplama işlemine göre önceliği olduğundan ilk önce parantez içindeki işlem gerçekleşir ve sonuç aşağıdaki gibi olur.

Tamsayılar yazısında da ifade edildiği gibi bütün tamsayı türler .net Framework içerisindeki yapılardan türetilir. string veri tipi ise System.String sınıfından türetilir.

Sınıflar ve yapılar birbirlerine benzerler. Ama çok temel bir farklılıkları var, yapılar değer tiptirler, sınıflar referans tip. Daha fazla bilgiyi Değer Tip & Referans Tip adlı yazımızdan öğrenebilirsiniz.

Alıntı: http://www.csharpturk.net/Rehber.aspx?Makale=11

C# ‘ta Switch Case yapısı (Eski Select Case)

Tarih: Perşembe, Ocak 14, 2010 Kategori: Genel

Her dilde olduğu gibi C# dilinde de kontrol yapıları vardır. Bunlardan biri de switch case döngüsüdür… Peki nedir switch case, ne yapar?

Mantık olarak “if else” koşul yapısına benzer. Kendisine gönderilen parametreyi değerlendirir ve ona göre ayrılan kod bloğunu çalıştırır.

Şimdi bütün bunları kod bloğumuzda görelim…

switch(değişken)
{
       case kosul1:
              //kodlar bu panele gelecek
       break;

      case kosul2:
              //kodlar bu panele gelecek
      break;

       .
       .
       .

      case kosuln:
              //kodlar bu panele gelecek
      break;

      default:
            //eğer hiç bir koşul desteklenmiyorsa bu koşul gerçekleşecek
            break;
}

Evet arkadaşlar, yapıyı gördük; şimdi bunu daha iyi anlamak için bir örnekle açalım:

Bir button ve bir textbox koyalım formumuzun üzerine ve textbox’a girdiğimiz rakamı switch case kontrol yapısı ile kontrol edelim…

int sayi = int.parse(textbox1.text);
/* burda int tipi sayi değişkenine int.parse() fonksiyonu ile textbox1'în textini sayıya çevirerek aldık...  */

switch (sayi)
            {
                case 0:
                    MessageBox.Show("Girdiğiniz Sayı Sıfır'dır...","Uyarı");
                    break;
                case 1:
                    MessageBox.Show("Girdiğiniz Sayı Bir'dir...","Uyarı");
                    break;
                case 2:
                    MessageBox.Show("Girdiğiniz Sayı İki'dir...", "Uyarı");
                    break;
                case 3:
                    MessageBox.Show("Girdiğiniz Sayı Üç'tür...", "Uyarı");
                    break;
                case 4:
                    MessageBox.Show("Girdiğiniz Sayı Dört'tür...", "Uyarı");
                    break;
                case 5:
                    MessageBox.Show("Girdiğiniz Sayı Beş'dir...", "Uyarı");
                    break;
                case 6:
                    MessageBox.Show("Girdiğiniz Sayı Altı'dır...", "Uyarı");
                    break;
                case 7:
                    MessageBox.Show("Girdiğiniz Sayı Yedi'dir...", "Uyarı");
                    break;
                case 8:
                    MessageBox.Show("Girdiğiniz Sayı Sekiz'dir...", "Uyarı");
                    break;
                case 9:
                    MessageBox.Show("Girdiğiniz Sayı Dokuz'dir...", "Uyarı");
                    break;
                default:
                    MessageBox.Show("Girilen Değer Bir Rakam Değildir!","Uyarı");
                    break;
            }

Örneğimizi bitirdik bu basit bir örnek

active directory

Tarih: Çarşamba, Ocak 13, 2010 Kategori: Genel

ACTIVE DIRECTORY

Active Directory Windows Server 2003 ağlarındaki bir dizin hizmetidir. Dizin hizmeti, ağdaki kaynakların bilgisini tutan ve bu bilgiyi kullanıcılara ve uygulamalara sunan ağ hizmetidir. Dizin hizmeti ağ kaynaklarına ulaşmak, bu kaynakları isimlendirmek ve güvenli bir şekilde yönetmek için gereken ortamı sağlamak amacıyla oluşturulur.
Active Directory ortamdaki ağ altyapısına büyük ölçüde işlevsellik kazandırmaktadır. Özellikle kaynakların kontrolünün ve yönetiminin merkezileştirilmesi Active Directory organizasyonunun en önemli özelliğidir. Active Directory, fiziksel topoloji üzerine dayalı bir sistemin kullanıcıya daha baside indirgenmiş şekilde görünmesini ve kaynaklara erişim esnasında kullanıcının eriştiği kaynağın (örneğin printer) ağın neresinde olduğunu veya kaynağın ağa ne şekilde bağlanmış olduğunu bilmeksizin bağlanmasını sağlar.Active Directory çok büyük işletmelerdeki yoğun bilgileri alt kümelere bölerek saklayabilir ve böylece verilerin büyümesi veya küçülmesi durumunda, yani şirketin büyümesi veya küçülmesi durumunda sistemöe esneklik kazandırır.

Active Directory kurulu bir Windows Server 2003 ağ çapında sistem konfigürasyonlarını, kullanıcı profillerini ve uygulama bilgilerini Active Directory veritabanında saklar. Active Directory sistem yöneticilerinin, domain kapsamındaki tüm bilgisayarlarda desktop özelliklerini, ağ servislerini ve uygulamaları merkezi bir noktadan yönetebilmelerini sağlar.
Active Directory ayrıca, kullanıcıların sisteme bir kez dahil olmasını, yani logon olmasını ve ardından ağdaki birçok kaynağa tek bir logonla güvenli bir şekilde erişebilmesi konusunda da sistem yöneticilerine merkezi erişim kontrolü sağlar.

1. Active Directory Objeleri
Active Directory, veritabanında ağ objeleri hakkındaki bilgileri saklar. Bu Active Directory objeleri başta kullanıcılar, gruplar, bilgisayarlar ve yazıcılar olmak üzere ağ kaynaklarını temsil etmektedir. Dahası, Active Directory çapındaki tüm sunucular, Domain’ler ve Site’lar da Active Directory objeleri arasında yer almaktadır. Active Directory tüm objeleri dağıtılmış bir veritabanı üzerinde sakladığı için sistem yönticisi bu objelerin yönetimi kolaylıkla tek bir noktadan yürütebilir.
Yeni bir obje oluşturulduğu zaman bu objenin özellikleri (attribute) obje hakkında onu tanımlayan bilgiler içerir. Kullanıcılar bu objeye erişmek istediği zaman objeye atanan bu özelliklerden faydalanabilirler. Örneğin, bir kullanıcı domain içerisinde bir yazıcıya ulaşıyorken yazıcının bulunduğu yere (kat, bina, departman) göre arama yapabilir.

2. Active Directory: Mantıksal Yapı
Active Directory, organizasyon içerisinde hiyerarşik bir sistem oluşturmak için esnek bir yapıya sahiptir ve bu yapı hem yöneticiler için hem de kullanıcılar için kolayca anlaşılabilir özelliklere sahiptir. (Şekil 1) Active Directory’nin mantıksal bileşenleri şunlardır:
• Domains
• Organizational Units (OUs)
• Trees and Forests
• Global Catalog

ACTIVE DIRECTORY
Şekil 1

Domain
Active Directory en temel mantıksal bileşeni Domain’dir. Domain, aynı dizin veritabanını paylaşan bilgisayarlar bütünüdür ve sistem yöneticisi tarafından oluşturulur. Her bir Domain benzersiz bir isme sahiptir ve sistem yöneticisi tarafından belirlenmiş olan kullanıcı ve grup hesaplarına erişim sağlar.

Ayrıca Domain’ler güvenlik sınırı (Security Boundary) olarak da bilinir. Güvenlik sınırı sayesinde, eğer sistem yöneticisi ayrıca bir izin belirlememişse, bir kullanıcının hakları sadece o Domain içerisinde geçerli olacaktır. Her bir Domain kendi güvenlik yapısına sahiptir.
Domain’ler ayrıca replikasyon birimi olarak adlandırılır. Bir Domain içerisinde, Active Directory veritabanı kopyalarını bulunduran Domain Controller’lar bu koyaları Domain içerisinde yapılan değişiklikleri birbirlerine kopyalarak replikasyon yaparlar.

Organizational Units
Organizational Unit bir Domain içerisindeki objeleri organize etmek amacıyla oluşturulmuş objelerdir. Bir Organizational Unit kendi içerisinde kullanıcılar, gruplar, bilgisayarlar veya başka OU’lar olmak üzere başka objeler barındırabilirler.
OU’ları, organizasyonun ihtiyacını en iyi şekilde karşılayacak mantıksal bir hiyerarşi oluşturuyorken objeleri gruplamak amacıyla kullanabilirsiniz.
Örneğin, objeleri grupluyorken yönetimsel gereksinimleri ön planda tutabilirsiniz. Mesela, organizasyonda bir yönetici kullanıcılarda bir diğer kullanıcı da bilgisayarlardan sorumlu olacaksa, biri kullanıcılar için biri de bilgisayarlar için iki adet OU oluşturulur ve kullanıcılar birinde bilgisayarlar da diğerin toplanır. Son olarak da ikisini de ilgili kullanıcı yönetici olarak atanabilir.
OU birimlerinin kullanılabileceği bir başka örnek ise organizasyonun departmansal birimlere ayrılmasında geçerli olabilir. Örneğin bir “Muhasebe” bir de “Pazarlama” departmanları için OU oluşturulur ve bu departmanlarda çalışan kullanıcılar ilgili Oulara yerleştirildikten sonra departman şefleri bu birimlere yönetici olarak atanabilir.

Trees ve Forests
Oluşturulan ilk Windows Server 2003 Domain’i, Active Directory yapısındaki Kök Domain’i (Root Domain) ifade eder. Bundan sonra oluşturulacak olan yeni ek Domain’ler dizinin mantıksal Tree veya Forest yapısını oluşturacaktır.

Tree
Birbirine ardışık bir isim aralığını paylaşan Windows Server 2003 Domain’lerinin hiyerarşik olarak düzenlenmiş şeklidir.
Önceden oluşturulmuş bir Tree yapısında yeni bir Domain eklediğiniz zaman, yeni eklenen Domain sondan eklendiği Domain’inin Child Domain’i durumunda olur ve eklendiği Domain de eklenen Domain için Parent Domain olur. Yeni oluşturulan Child Domain’in ismi Parent Domain’den gelen isimle birleştirilir ve yeni oluşan Domain’in DNS ismi ortaya çıkar.

Örneğin ozgur.com bir Root Domain’dir. Bu Domain’e eklenecek yeni bir Domain ozgur.com Domain’inin Child Domain’i olacaktır, buna örnek olarak satis.ozgur.com Domain’ini gösterebiliriz. Bu örnekte satis.ozgur.com, ozgur.com Domain’inin Child Domain’i olacaktır. ozgur.com Domain’i ise Parent Domain konumundadır.

Forests
Forest, birden fazla Tree’nin birleşmiş halidir. Forest içerisindeki Tree’ler ardışık isim aralığına sahip değildirler. Oluşturulan ilk Domain bir Tree’yi ifade edecektir ve ilk Tree’nin oluşturulmasıyla Forest’da oluşmuş olacaktır. Sonradan bu Forest’a eklenecek olan Tree’ler, diğer Tree’lerle aynı isim aralığını paylaşmayacak olasalar da aynı Schema ve Global Catalog’a sahip olacaktır. Forest oluşturulurken kurulmuş olan ilk Tree Forest-Root olarak bilinir ve diğer Tree’ler bu Forest Root altında toplanırlar.

Global Catalog
Global Catalog, Active Directory’deki tüm objelerin özelliklerinin bir alt kümesini taşıyan bilgi deposudur. Bu barındırılan özellikler, varsayılan olarak, sorgulamalar esnasında en sık kullanılan özelliklerdir (örneğin kullanıcı ön ismi, son ismi ve logon ismi). Global Catalog kullanıcılara şu hizmetleri sunar:
• Gereken verinin nerede olduğundan bağımsız olarak Active Directory objeleri hakkında bilgiler sunar.
• Bir ağa logon oluyorken Universal Group Membership bilgisini kullanır.
Global Catalog Sunucusu Domain’deki bir Domain Controller’dır ve Domain’de oluşturulan ilk Domain Controller otomatik olarak Global Catalog seviyesine yükseltilir. Sonradan ek Global Catalog Sunucular eklenebilir.

3. Active Directory: Fiziksel Yapı
Active Directory’de mantıksal yapı ve fiziksel yapı birbirlerinden bütünüyle ayrık ve farklıdır. Mantıksal yapı ağ kaynaklarını organize etmek için kullanılıyorken fiziksel yapı ise ağ trafiğini yapılandırmak ve yönetmek için kullanılır. Domain Controller’lar ve Site’lar Active Directory’nin fiziksel yapısını oluşturan bileşenlerdir. (Şekil 2)

ACTIVE DIRECTORY
Şekil 2

Domain Controllers
Domain Controller, üzerinde Active Directory veritabanının bir kopyasını (replica) bulunduran bilgisayardır.Domain’de gerşekleştirilen herhangi bir değişiklik bir Domain Controller üzerinde gerçekleştirilir ve daha sonra domain’deki tüm Domain Controller’lar bu değişiklikleri replikasyon yoluyla birbirlerine kopyalarlar. Domain Controller’lar dizin bilgisini bulundururlar ve kullanıcıların logon işlemlerini, kimlik doğrulama işlemlerini ve dizin arama işlemlerini yürütürler.
Bir Domain’de bir veya daha çok Domain Controller olabilir. Ufak çapta bir organizasyona (LAN) bir Domain ve iki Domain Controller yetecekken farklı fiziksel lokasyonlara yayılmış büyük bir işletme için (WAN), her bir bölge başına bir veya iki Domain Controller daha uygun olacaktır. Bir Domain’e birden fazla Domain Controller yerleştirmenin amacı hem hata toleransı sağlamak hem de Domain Controller’lar arasında yük dağılımı yapmaktır.

Sites
Bir Site, birbirlerine yüksek bant genişliğine sahip dış hatlarlar bağlanmış bir veya birden fazla IP (Internet Protocol) alt ağlarını ifade etmektedir. Site’ları doğru bir şekilde yapılandırarak kullanıcıların logon işlemlerinde oluşan ağ trafiğini ve replikasyon işlemleri sırasında oluşan yoğunluğu en aza indirgemek için Active Directory’nin alt ağlar arasındaki fiziksel bağlantıları en efektif şekilde kullanmasını sağlayabiliriz.
Site oluşturmaktaki başlıca sebepler şunlardır:
• Replikasyon trafiğinin optimize edilmesi
• Kullanıcıların logon olması esnasında en hızlı ve en güvenilir bağlantıyı kullanarak doğru Domain Controller’ı bulabilmeleri

4. Active Directory ve DNS
Active Directory ve DNS entegrasyonu Windows Server 2003 Sisteminin en önemli özelliklerinden biridir. Active Directory ve DNS, objelerin hem Active Directory objeleri hem de DNS domainleri ve kaynak kayıtları (Resource Records) olarak sunulabilecek şekilde benzer bir hiyerarşik isimlendirme yapısına sahiptirler. Bu entegrasyonun sonucu olarak Windows Server 2003 Ağındaki bilgisayarlar, Active Directory’ye özgü birtakım servisleri çalıştıran bilgisayarların yerini öğrenmek için DNS Sunucuları kullanmaktadırlar. Örneğin, bir client Active Directory’ye logon olmak veya herhangi bir kaynağı (yazıcı veya paylaşılmış bir klasör) dizin içerisinde aratmak için bilmesi gereken Domain Controller’ IP adresini DNS Sunucu üzerinde SRV kayıtlarından öğrenmektedir. Active Directory’nin sorunsuz bir şekilde çalışması için DNS sunucuların SRV kayıtlarını eksiksiz bir şekilde barındırması gerekmektedir. SRV kayıtlarının amacı, client’lara logon esnasında veya herhangi bir kaynağa ulaşıyorken Domain Controller’ların yerlerini belirtmektir ve bu kayıtlar DNS sunucularda tutulur. SRV kayıtlarının olmadığı bir ortamda, client’lar Domain’e logon olamayacaklardır.
Ayrıca Windows Server 2003, DNS bilgilerinin Active Directory veritabanı ile tümleşik olarak saklanmasına olanak vermektedir. Bu sayede DNS bilgilerinin replikasyonu daha efektif ve güvenli bir hale gelmektedir.

Windows Server 2003, Active Directory organizasyonunu kurmadan, önce oluşturulacak olan Domain’in DNS altyapısını önceden oluşturmayı gerektirmektedir. Eğer oluşturulacak olan Domain’in DNS altyapısı kurulum öncesinden hazırlanmamışsa, kurulum esnasında da DNS altyapısı kurulabilir.

Active Directory Kurulum
Active Directory kurulumunu şu aşamalarda inceleyebiliriz:
5. Domain Controller for a new Domain:
1. Start menüsündeki Run kutusuna dcpromo yazın ve Enter’a basın. Karşınıza Active Directory Kurulum Sihirbazı gelecektir. (Şekil 1)

ACTIVE DIRECTORY
Şekil 1

2. Operating System Compatibility: İlk ekranda Next butonuna tıklatıp bir sonraki ekrana geçiniz. Karşınıza sistem uyumluluklarını açıklayan Operating System Compatibility ekranı gelecektir. Burda yazılanları okuduktan sonra sıradaki ekrana geçmek için Next butonuna tıklatınız. (Şekil 2)

ACTIVE DIRECTORY
Şekil 2

3. Domain Controller Type: Bu ekranda Domain Controller tipi belirlenmelidir. Üstteki seçenek “Domain controller for a new domain” yeni bir Domain oluştururken seçilmelidir. Eğer varolan bir Domain’e ek bir Domain Controller eklenecekse “Additional domain controller for an existing domain” seçeneği işaretlenmelidir. Gerekli seçeneği işaretleyip Next butonuna tıklatınız. (Şekil 3)

ACTIVE DIRECTORY
Şekil 3

4. Create New Domain: Bu ekranda Domain’in tipi belirlenmelidir. Üç adet seçenek bulunmaktadır (Şekil 4):
• Domain in a new forest: Yeni bir Forest için yeni bir Domain Controller oluşturmak için işaretlenir.
• Child domain in an existing domain tree: Önceden oluşturulmuş bir Domain Tree yapısına bağımlı yeni bir Child Domain oluşturmak için işaretlenir.
• Domain tree in an existing forest: Önceden oluşturulmuş bir Forest yapısına yeni bir Domain Tree eklemek için işaretlenir.
Gerekli seçeneği işaretledikten sonra Next butonuna tıklatınız.

ACTIVE DIRECTORY
Şekil 4

5. New Domain Name: Bu ekranda yeni oluşturulacak olan Domain’in tam DNS ismi girilmelidir. Örneğin, ozgur.com. Domain’in tam DNS ismini yazdıktan sonra Next butonuna tıklatınız. (Şekil 5)

ACTIVE DIRECTORY
Şekil 5

6. NetBIOS Domain Name: Bu ekranda Domain’in NetBIOS ismi belirlenmelidir. Varsayılan olarak gelen NetBIOS isminin kullanılması tavsiye edilir. Domain’in NetBIOS ismini belirledikten son Next butonuna tıklatınız (Şekil 6).

ACTIVE DIRECTORY
Şekil 6

7. Database and Log Folders: Bu ekranda Active Directory veritabanı dosyası olan NTDS.DIT dosyasının ve Logların nerede tutulacağını giriniz. Yoğun işlemlerde en iyi performansı elde etmek için Active Directory veritabanını ve Loglarını ayrı fiziksel harddiskler üzerine yerleştirmek tavsiye edilir. Varsayılan olarak veritabanı da loglar da “%SystemRoot%\NTDS” klasörüne yerleştirilir. Gerekli girdileri yazıp Next butonuna tıklatınız. (Şekil 7)

ACTIVE DIRECTORY
Şekil 7

8. Shared System Volume: Bu ekranda SYSVOL olarak bilinen Active Directory paylaşım klasörünün yeri belirlenmelidir. Bu klasör NTFS ile biçimlendirilmiş bir bölüm üzerine yerleştirilmelidir. Varsayılan olarak bu klasör “%SystemRoot\SYSVOL” şeklinde oluşturulur. Gerekli yolu girip Next butonuna tıklatınız (Şekil 8)

ACTIVE DIRECTORY
Şekil 8

9. DNS Registration Diagnostics: Bu ekranda DNS Server testi sonuçları gösterilmektedir.Eğer DNS altyapısı Active Directory kurulumu öncesinde hazırlanmamış ise Active Directory Kurulum Sihirbazı bize bu konuda üç seçenek sunmaktadır:
• “I have corrected the problem. Perform the DNS diagnostic test again.” : DNS altyapısının hazır olduğunu, ve testin tekrarlanmasını belirtir.
• “Install and configure the DNS server on this computer, and set this computer to use this DNS server as its preferred DNS server.” : DNS altyapısının oluşturulması Active Directory kurulumuna bırakır.
• “I will correct the problem later by configuring DNS manually.” : DNS altyapısının kurulumdan sonra yönetici tarafından manüel olarak gerçekleştirileceğini belirtir.
Gerekli seçeneği işaretleyip Next botununa tıklatınız (Şekil 9).

ACTIVE DIRECTORY
Şekil 9

10. Permissions: bu ekranda Domain’deki minimum işletim seyivesi belirlenmelidir ve Domain izinleri bu velirlenen seviyeye göre oluşturulacaktır. İki adet seçenek bulunmaktadır:
• “Permissions compatible with pre-Windows 2000 server operating systems” : Eğer Domain’de Windows 2000 öncesi sunucu tipi işletim sistemi olacaksa bu seçenek seçilmelidir.
• “Permissions compatible only with Windows 2000 or Windows Server 2003 operating systems” : Eğer Domain’deki tüm sunucu tipi işletim sistemleri Windows 2000 sonrası ise bu seçeneğin seçilmesi güvenlik açısından tavsiye edilir.
Gerekli seçeneği işaretleyip Next butonuna tıklatınız (Şekil 10).

ACTIVE DIRECTORY
Şekil 10

11. Directory Services Restore Mode Administrator Password: bu ekranda Directory Services Restore Mode için girilecek olan şifrenin belirlenmesi gerekmektedir (Şekil 11)

ACTIVE DIRECTORY
Şekil 11

12. Summary: Bu son ekranda yapılan ayarlamaların bir özeti bulunmaktadır. Eğer herhangi bir değişiklik gerçekleştirilmeyecekse Next butonuna tıklatıp Active Directory kurulumunu başlatınız (Şekil12).

ACTIVE DIRECTORY
Şekil 12

6. Additional Domain Controller for an existing Domain:
1. Start menüsündeki Run kutusuna dcpromo yazın ve Enter’a basın. Karşınıza Active Directory Kurulum Sihirbazı gelecektir.
2. Operating System Compatibility: İlk ekranda Next butonuna tıklatıp bir sonraki ekrana geçiniz. Karşınıza sistem uyumluluklarını açıklayan Operating System Compatibility ekranı gelecektir. Burda yazılanları okuduktan sonra sıradaki ekrana geçmek için Next butonuna tıklatınız.
3. Domain Controller Type: Bu ekranda Domain Controller tipi belirlenmelidir. Varolan bir Domain’e ek bir Domain Controller ekleneceği için “Additional domain controller for an existing domain” seçeneği işaretlenmelidir. Gerekli seçeneği işaretleyip Next butonuna tıklatınız.
4. Network Credentials: Bu ekranda, bilgisayarın ek Domain Controller olarak dahil olacağı Domain’den yetkili bir kullanıcının kimlik bilgilerinin girilmesi gerekmektedir. Bir Domain Admin veya Enterprise Admin kullanıcı ismini, şifresini ve bu kullanıcının dahil olduğu Domain’i yazıp Next butonuna tıklatınız.
5. Additional Domain Controller: Bu ekranda bilgisayarın ek Domain Controller olacağı Domain’inin tam DNS ismini yazınız. Yandaki Browse butonu ile Domain Ağacınının yapısını görebilir ve ek Domain Controller olarak katılmak istediğiniz Domain’i Browse görünümünden de seçebilirsiniz.
6. Database and Log Folders: Bu ekranda Active Directory veritabanı dosyası olan NTDS.DIT dosyasının ve Logların nerede tutulacağını giriniz. Yoğun işlemlerde en iyi performansı elde etmek için Active Directory veritabanını ve Loglarını ayrı fiziksel harddiskler üzerine yerleştirmek tavsiye edilir. Varsayılan olarak veritabanı da loglar da “%SystemRoot%\NTDS” klasörüne yerleştirilir. Gerekli girdileri yazıp Next butonuna tıklatınız.
7. Shared System Volume: Bu ekranda SYSVOL olarak bilinen Active Directory paylaşım klasörünün yeri belirlenmelidir. Bu klasör NTFS ile biçimlendirilmiş bir bölüm üzerine yerleştirilmelidir. Varsayılan olarak bu klasör “%SystemRoot\SYSVOL” şeklinde oluşturulur. Gerekli yolu girip Next butonuna tıklatınız.
8. Directory Services Restore Mode Administrator Password: bu ekranda Directory Services Restore Mode için girilecek olan şifrenin belirlenmesi gerekmektedir.
9. Summary: Bu son ekranda yapılan ayarlamaların bir özeti bulunmaktadır. Eğer herhangi bir değişiklik gerçekleştirilmeyecekse Next butonuna tıklatıp Active Directory kurulumunu başlatınız.

7. Child Domain in an existing Domain Tree:
1. Start menüsündeki Run kutusuna dcpromo yazın ve Enter’a basın. Karşınıza Active Directory Kurulum Sihirbazı gelecektir.
2. Operating System Compatibility: İlk ekranda Next butonuna tıklatıp bir sonraki ekrana geçiniz. Karşınıza sistem uyumluluklarını açıklayan Operating System Compatibility ekranı gelecektir. Burda yazılanları okuduktan sonra sıradaki ekrana geçmek için Next butonuna tıklatınız.
3. Domain Controller Type: Bu ekranda Domain Controller tipi belirlenmelidir. Üstteki seçenek “Domain controller for a new domain” Child Domain oluştururken seçilmelidir. Sonuçta Child Domain de yeni bir Domain’dir ve Child’ı olarak tanımlandığı Parent Domain ile kendisi arasında bir Trust Relationship olacaktır. Gerekli seçeneği işaretleyip Next butonuna tıklatınız.
4. Create New Domain: Bu ekranda Domain’in tipi belirlenmelidir. Üç adet seçenek bulunmaktadır:
Domain in a new forest: Yeni bir Forest için yeni bir Domain Controller oluşturmak için işaretlenir.
Child domain in an existing domain tree: Önceden oluşturulmuş bir Domain Tree yapısına bağımlı yeni bir Child Domain oluşturmak için işaretlenir.
Domain tree in an existing forest: Önceden oluşturulmuş bir Forest yapısına yeni bir Domain Tree eklemek için işaretlenir.
Burda seçmemiz gereken seçenek “Child domain in an existing domain tree” seçeneğidir. Gerekli seçeneği işaretledikten sonra Next butonuna tıklatınız.
5. Network Credentials: Bu ekranda, Child Domain’in ilişkisi olduğu Parent Domain’den yetkili bir kullanıcının kimlik bilgilerinin girilmesi gerekmektedir. Bir Domain Admin veya Enterprise Admin kullanıcı ismini, şifresini ve bu kullanıcının dahil olduğu Domain’i yazıp Next butonuna tıklatınız.
6. Child Domain Installation: Bu ekranda Parent Domain’in tam DNS ismini ve yeni oluşturulacak olan Child Domain’in ismini girmemiz gerekmektedir. Parent Domain kutusunun yanındaki Browse butonuna tıklatıp Child Domain’in katılacağı Domain Ağacınının yapısını görebilirsiniz. Yine Child olarak katılacağınız Domain’i Browse görünümünden de seçebilirsiniz. Parent Domain’i ve Child Domain’i yazınca yeni oluşacak olan Child Domain’in tam DNS ismini alttaki kutuda görünecektir. Gerekli bilgileri girip Next butonuna tıklatınız.
7. NetBIOS Domain Name: Bu ekranda Child Domain’in NetBIOS ismi belirlenmelidir. Varsayılan olarak gelen NetBIOS isminin kullanılması tavsiye edilir. Child Domain’in NetBIOS ismini belirledikten son Next butonuna tıklatınız.
8. Database and Log Folders: Bu ekranda Active Directory veritabanı dosyası olan NTDS.DIT dosyasının ve Logların nerede tutulacağını giriniz. Yoğun işlemlerde en iyi performansı elde etmek için Active Directory veritabanını ve Loglarını ayrı fiziksel harddiskler üzerine yerleştirmek tavsiye edilir. Varsayılan olarak veritabanı da loglar da “%SystemRoot%\NTDS” klasörüne yerleştirilir. Gerekli girdileri yazıp Next butonuna tıklatınız.
9. Shared System Volume: Bu ekranda SYSVOL olarak bilinen Active Directory paylaşım klasörünün yeri belirlenmelidir. Bu klasör NTFS ile biçimlendirilmiş bir bölüm üzerine yerleştirilmelidir. Varsayılan olarak bu klasör “%SystemRoot\SYSVOL” şeklinde oluşturulur. Gerekli yolu girip Next butonuna tıklatınız.
10. DNS Registration Diagnostics: Bu ekranda DNS Server testi sonuçları gösterilmektedir.Eğer DNS altyapısı Active Directory kurulumu öncesinde hazırlanmamış ise Active Directory Kurulum Sihirbazı bize bu konuda üç seçenek sunmaktadır:
• “I have corrected the problem. Perform the DNS diagnostic test again.” : DNS altyapısının hazır olduğunu, ve testin tekrarlanmasını belirtir.
• “Install and configure the DNS server on this computer, and set this computer to use this DNS server as its preferred DNS server.” : DNS altyapısının oluşturulması Active Directory kurulumuna bırakır.
• “I will correct the problem later by configuring DNS manually.” : DNS altyapısının kurulumdan sonra yönetici tarafından manüel olarak gerçekleştirileceğini belirtir.
Gerekli seçeneği işaretleyip Next botununa tıklatınız.
11. Permissions: Bu ekranda Domain’deki minimum işletim seyivesi belirlenmelidir ve Domain izinleri bu velirlenen seviyeye göre oluşturulacaktır. İki adet seçenek bulunmaktadır:
• “Permissions compatible with pre-Windows 2000 server operating systems” : Eğer Domain’de Windows 2000 öncesi sunucu tipi işletim sistemi olacaksa bu seçenek seçilmelidir.
• “Permissions compatible only with Windows 2000 or Windows Server 2003 operating systems” : Eğer Domain’deki tüm sunucu tipi işletim sistemleri Windows 2000 sonrası ise bu seçeneğin seçilmesi güvenlik açısından tavsiye edilir.
Gerekli seçeneği işaretleyip Next butonuna tıklatınız.
12. Directory Services Restore Mode Administrator Password: Bu ekranda Directory Services Restore Mode için girilecek olan şifrenin belirlenmesi gerekmektedir.
13. Summary: Bu son ekranda yapılan ayarlamaların bir özeti bulunmaktadır. Eğer herhangi bir değişiklik gerçekleştirilmeyecekse Next butonuna tıklatıp Active Directory kurulumunu başlatınız.

8. Active Directory Kurulum Sonrası Kontroller
Active Directory kurulumundan sonra Directory veritabanı dosyalarının, SYSVOL dosyalarının, DNS SRV kaynak kayıtlarının düzgün bir şekilde yapılandırılmış olduğunun doğrulanması gerekmektedir. Active Directory Kurulum sihirbazı işlemi sonlandırdıktan sonra şu adımları izleyerek kurulumun sorunsuz bir şekilde gerçekleştiğini doğrulayabilirsiniz:
• DNS veritabanını inceleyerek SRV kayıtlarının doğru şekilde oluşturulmuş olduğunu kontrol edin.
• SYSVOL klasörünün düzgün şekilde oluşturulduğundan ve paylaştırılmış olduğundan emin olun.
• Active Directory veritabanı ve log dosyalarının oluşturulduğunu doğrulayın.
• Olay Görüntüleyicisini (Event Viewer) açarak kurulum sırasında herhangi bir hatanın gerçekleşip gerçekleşmediğini kontrol edin.

SRV kaynak kayıtlarının kontrolü:
Active Directory kurulduktan sonra Domain Controller yeniden başlatıldıktan sonra DNS veritabanına SRV kaynak kayıtlarını kaydeder. Bu kayıtların oluşturulmuş olduğunu test etmek için Administrative Tools kısmından DNS yönetim konsolunu tıklayarak ilgili SRV kayıtlarının kontrol edebilir veya nslookup komudunu çalıştırarak DNS veritabanını sorgulayabilirsiniz.

SYSVOL klasörünü doğrulamak:
SYSVOL klasörünü doğrulamak için önce klasörün disk üzerinde oluşturulmuş olduğunu daha sonra da bu klasörün paylaştırılmış olduğunu doğrulamamız gerekir. Eğer SYSVOL klasöründe herhangi bir hata varsa bu klasörde saklanan veriler (Group Policy gibi) Domain Controller’lar arasında replike edilemeyecektir. SYSVOL klasörünün varsayılan yeri %SystemRoot%\SYSVOL yoludur.

Active Directory veritabanı ve log dosyalarını doğrulamak:
Active Directory veritabanının ve log dosyalarının düzgün şekilde oluşturulmuş olması gerekmektedir. Bunu doğrulamak için bakmamız gereken yer, eğer kurulum sırasında başka bir yer belirlemediysek, %SystemRoot%\NTDS klasörüdür. Bu klasör içerisinde şu dosyalar yer almalıdır:
Ntds.dit : Active directory veritabanı dosyası.
Edb.* : Transaction logları ve checkpoint dosyaları.
Res*.log : Rezerve edilen log dosyaları.

Olay Görüntüleyicisi kontrolü:
Active Directory kurulumu esnasında oluşabilecek herhangi bir hata için Olay Görüntüleyicisinin kontrol edilmesi gerekmektedir. Olması muhtemel hataların raporları için aşağıdaki logları kontrol edin:
• System Log
• Directory Service
• DNS Server
• File Replication service

Encription & Decription Şifreleme Algoritmaları

Tarih: Pazartesi, Ocak 11, 2010 Kategori: Genel
Algoritma konusunu en iyi şifreleme teknikleri ile işleyebileceğimi düşündüm.
Bu nedenle şifrelemeye kısaca göz atmak istiyorum.II. Dünya savaşında Alman denizaltı şifresi enigma’nın çözülebilmesi savaşın dengesini değiştirmişti. Bu düşünce lise yıllarında bana kendi şifreli dilimi geliştirmeye itmişti. Her harfin yerine başka harfler oluşturmuştum. Harfler tamamen kendime özel olduğu için yazdığımın çözüleceğine olanak tanımıyordum. Yıllar sonra kendi günlüğüme almış olduğum bu şifreli alfabedeki notları (alfabeyi unuttuğum için) okumakta zorlandığımda kendim çözmek için çaba sarfettiğimde çözülebileceğini keşfetmiş oldum.

Klasik harf değiştirme yöntemleri ile elde edilen şifreli dillerin çözümü için. O dil’in yapısı hakkında bilgi sahibi olmanız yetiyor. (Örneğin Türkçe de en çok A, E kullanılır sesli olduğu ve seslilerin sessizlere oranla az olduğu için). Ve bu kısa bilgi sayesinde cümle içinde en çok kullanılan karakteri aratıyorsunuz. Ve bu harf’in A olduğunu varsayıp okumaya çalışıyorsunuz. Nihayetinde bir kaç denemeden sonra diğer harfler kendini ele veriyor.

Yüz yıllar öncesinden beri gelen harf kaydırma teknikleri de aynı şekilde çözülür.

yusuf turan fırat yerine harf kaydrıma ile (kendinden bir ya da x sonraki harfi yazma)
zyşyg uvsbo gisbu kullanılarak harf kaydırma şifresi oluşturuluyordu.

Oysa bu gün SSL dediğimiz güvenli şifreleme sistemlerinde ise özet olarak;

RSA Public Key Sistemi Örnek
Hem p’nin hem de q’nun asal olduğu p ve q seçilir. P =11; q=13;
Mod alınacak değer hesaplanır n = pq. N = 11*13 = 143.
Euler’s totient fonksiyonu uygulanır t = (p-1)(q-1). t = (11-1)*(13-1) = 120.
T değeri ile en büyük ortak böleni 1 olan bir e değeri hesaplanır. e = 7. (7<120, ve 7 ve 120 nin en büyük ortak böleni 1 dir
e*d = 1 mod t olacak şekilde d değeri hesaplanır 7*d = 1 mod 120 => d = 103,
çünkü
7*103 = 721 = 1 mod 120.
public key (e, n). public key (7, 143).
Private key (d, n). private key (103, 143).
Plaintext M olsun. M = 5 kabul edelim.
ciphertext C = M^e mod n. Ciphertext:
C = 5^7 mod 143= 47
Şifre çözme işlemi =>
plaintext = C^d mod n = (M^e)^d mod n = M.
Plaintext:
47^103 mod 143 = 5
47^103 = (5^7)^103 = 5^721
= 5*[5^720] =5*[(5^120)^6]
= 5*[ 1^6] = 5.

5^120 = 5^t = 1 mod 143 (Euler teoremi)veya,
daha basitçe,
x^(e*d) = x; bu sebepten, 5^721 = 5’tir.

Bunun gibi 64 bit, 128 bit ya da 256 bit gibi şifreleme yöntemleri uygulanmaktadır.
Bu tür şifreleme yöntemlerinde işlemci şifrelemek yada çözmek için gönderilen her tür veri için zaman kaybetmekte ve şifreleme şifre çözme işi sunucuyu bu oranda zorlamaktadır.
Ancak şifre algoritması ne kadar yüksekse çözülme kırılma olasılığıda o düzeyde zor olacaktır. Ticari işlemler, bankacılık işlemleri, özel mesajlaşma yöntemleri, ulusal güvenlik kuruluşları, uluslar arası gizli kuruluşlar bu yöntemle bilgi alışverişini kullanmaktadır.

 Ben Algoritma’mı kendim oluşturduğum ve anahtarlarının, çözümünün daha da kolay ve anlaşılır olduğu bir yöntem kullanacağım. Ancak metin şifrelendikten sonra anahtarları ele geçirmeden şifrenin çözülmesinin mümkün olmayacağı bir yöntem olacak.

Öncelikle algoritmamı anlatayım;

Yine her harf’e bir numara vererek bu işe başlayacağız. Bu işi ileride geliştirmek isteyenler, harflere 256 ascii karakterlere, karakter numarasına başvurarak çalışma yapabilir.

x grubu : A=1 ‘dir
y grubu : B=2 ‘dir

Cümlemiz ALİ olsun

Cümle grubu: A=1 , L=15 , İ =12
Şifreleme tekniğimiz şu olsun: Cümle grubu1 + x grubu1 – ygrubu1 , Cümlegrubu2+xgrubu1-ygrubu1 ….

Buna göre formülümüz

A+A-b = 1+1-2=0
L+A-b = 15+1-2=14
İ+A-b = 12+1-2= 11

ALİ = 1,15,12 olarak tanımlıyken şimdi şifreli olarak 0,14,11 oldu
anahtar harflerimiz A ve B eğer bu iki harfi biliyorsak çözüm çok kolay olacaktır.
0 +2 -1 = 1 = A
14 +2-1=15 = L
11+2-1= 12 = İ

Sonucu elde edilir.
Ancak, bu çok ta basit bir yöntem oldu farkedeceğiniz gibi. Zaten bende basit olsun kolay anlaşılsın diye kısa yoldan anlattım. Şimdi algoritmamıza biraz zorluk katalım.

Bunun için anahtar’ın dişlilerini artırmamız gerekecek.

Diyelimki x grubu anahtarımız FIRAT y grubu anahtarımız ise İSTANBUL olsun.
x grubu : FIRAT
y grubu : İSTANBUL
Cümle Grubu : KULLANICI ADINIZ STURK

Buna göre şifreleme yapacak olursak
cümle grubu1 + x grubu1 – ygrubu1 = K+F-İ = 14+7-12 = 9
cümle grubu2 + x grubu2 – ygrubu2 = U+I-S = 26+11-23=14
cümle grubu3 + x grubu3 – ygrubu3 = L+R-T = … şeklinde giderse sonuç şu olur.

K + X - Y = S    
K + F - İ = 14+7-12 9 Ğ
U + I - S = 26+11-23 14 K
L + R - T = 15+22-25 12 İ
L + A - A = 15+1-1 15 L
A + T - N = 1+25-17 9 Ğ
N + F - B = 17+7-2 22 R
I + I - U = 11+11-26 -4  
C + R - L = 3+22-15 10 H
I + A - İ = 11+1-12 0  
  + T - S = 0+25-20 5 D
A + F - T = 1+7-25 -17  
D + I - A =     … şeklinde devam eder.
I + R - N =      
N + A - B =      
I + T - U =      
Z + F - L =      
  + I - İ =      
S + R - S =      
T + A - T =      
U + T - A =      
R + F - N =      
K + I - B =      

Burada dikkat edilmesi gereken noktalar,

1. sıradaki K harfinin karşılığı Ğ çıktığı gibi 5. sıradaki A harfinin karşılığı’da Ğ harfi çıkmıştır.

2. dikkat edilmesi gereken nokta ise -4, -17 gibi çıkan negatif değerlerdir.

- (negatif) çıkan değerlerin’de çözülebilir bir değer olabilmesi için Mod alma yönetmini uygulayacağız. (Bu tür yöntemleri işi daha da karıştırmak, zorlaştırmak için uyguladım) Örneğin -4 değerini aldığımız I+I-U : 11+11-26 = -4 değerini aldığımız formül üzerinden gidelim. Bunun için önce mod alacağımız bir sayı bulmamız gerek. Ben bu örnekte mod alınacak sayı olarak 32 sayısını buldum. a-z’ye kadar 29 , 0=’boşluk’, 30=’:’ 31=’ ” ‘ 32=’.’
Bu karakterleri de katarak 32 karakterden oluşan bir alfabe kullanmış oldum.

Mod 32 kabul ederek işlemimize devam edelim.
I+I-U formülünü mod((I+I-U),32) şeklinde yeniden kurgulayalım. Mod((11+11-26),32)
sonuç olarak 28 rakamını elde ederiz. Ancak burada dikkat etmemiz gerekn şudur.
Biz cümlemizde hangi kelimenin – sonuç hangisinin + sonuç vereceğini tahmin edemediğimiz için tüm formülü Mod içine alarak yeniden yapmamız gerekecektir.

DECRYPTION YÖNTEMİ
Formülü tersten uygulamamız sonucu verecektir. Yeterki anahtar kelimeleri ve sırasını (hangi anahtar kelime x hangi anahtar kelime y) bilelim.
Şifreleme yöntemimiz S = K+X-Y ‘idi. (S=Şifre, K= Kelime, X = Anahtar1, Y= Anahtar2)
Şimdi S’yi biliyoruz K ‘yı bilmiyoruz, X ve Y’yi biliyoruz.
örneğin ilk harf için;
Şifrede elimizde olan harf = Ğ, X= F, Y=İ ‘dir
Ğ=9 , F=7, İ=12
Ğ= K + F – Y
9 = K + 7 – 12 olduğuna göre K’yı yalnız bırakmak için K=S-X+Y
K= -7 + 12 + 9 olur.
K= 14 tür. Yani K = K ‘dır. (K(Kelime) = K (Kullanıcı adınızın ilk harfi olan K) ‘dır.
Ancak çözüm yolu içinde de mod alma yöntemini aynen uygulamak durumundayız. Çünkü şifrelerken mod alarak şifreleme yapmıştık.
Bu durumda formül
K= MOD(S) – X + Y ‘dir.

Bu formülü daha da zorlaştırmanın bir yolu’da şudur.

FIRAT ve İSTANBUL gibi kullanılan anahtarların yanına rakamlar koymaktır. Örneğin FIRAT4578 gibi. Bu da şu anlama getirilerek kullanılmalıdır.
FIRATFIRATFIRATFIRATFIRAT şeklinde yan yana kullanılacak şifreleme anahtarı’nda
1. seferde FIRAT 4 ile toplanacak. F= 7 + 4= 11 , I=11+4=15, R=22+4=26 gibi.
2. FIRAT yazılımında 4578′in ikinci karakteri olan 5 ile toplnacak böylece anahtar her seferinde farklı değerlerle çarpılmasını sağlayacaktır.
Bu yöntemle de daha da karmaşık hal alan şifrenin anahtarlar olmadan çözülebilmesi milyonda bir ihtimal bile değildir.

Şifreleme ve çözme konusunu ileride daha derinlemesine belkide örnekleriyle ele alabilirim. Şimdilik bu kadar yeter.

[Not: Bu metin tamamen Yusuf FIRAT tarafından oluşturulmuştur. İzinsiz alınması, kullanılması yasaktır. Yusuf FIRAT]

 

—————————————–

İşte gelişimini anlatmış olduğum yukarıdaki yöntemin üzerine şöyle bir yöntem düşün ki, 128 bitlik ya da 256 bitlik şifrelemeler nasıl olduğu hakkında yorumlarınız daha net oluşsun.

Örneğin : Kimsenin bilmesini duymasını istemediğimiz ve sadece parolayı bilecek kişinin bilmesini istediğimiz gizli kelime : “aba baba” olsun. Ve bu şifrenin çözülmesi için gerekli parola ise, Adivar Super Gazi olsun.

Şifreleme yukarıdaki algoritmaya göre şöyle yapıldığını düşünün.

1. Parola’yı mod alma sayısı olarak kullanacağız. Örn: Adivar = A+D+İ+V+A+R = 1+5 + 9 + 27+ 1+20 = 63 = 6+3 = 9 yani mod 9 üzerinden işlem yapacağız.

2. Parola olan Süper ve 3. parola olan Gazi kelimelerinin ilk harflerine göre mod 9 cinsinden gizlenmesi gereken cümleyi analiz edelim.

Önce aba ‘yı analiz edelim.

a = 1  (aba’nın 1. harfi olan a ‘nın alfabedeki sırası)
S= 21 (Mod 9′a göre 3)
G= 9 (mod 9′a göre 9)
a+S+G= 1+3+9 = 13

şimdi ekranda 13 yazınca biz onun a olduğunu anlayacağız.

Ancak aba kelimesinin 3. harfi olan a için tekrar aynı motoru çalıştırdığımızda ise sonuç farklı çıkacak.
Hemen analizi başlatalım
a = (Aba’nın 3. harfi olan a ‘nın alfabedeki sırası)
P= 19 (Mod 9′a göre 1) (Süper in  3. harfi P)
Z= 29 (mod 9′a göre 9) (Gazi’nin 3. harfi Z)

a+p+z = 1+ 1 + 9 = 11
Görebileceğiniz gibi, yukarıdaki örnekte a = 13 idi şimdi ise a = 11  işte aynı harfin bile başka başka sonuçlarla yazıldığı bu algoritmaların çözülme olasılığı bu nedenle çok çok daha düşmektedir.

(Not: Bu makale yusuffirat.com için Yusuf FIRAT tarafından yazılmıştır. Link (Bağlantı) verilmeksizin alınması ve kullanılması yasaktır.)

Projelerim

Tarih: Pazartesi, Ocak 11, 2010 Kategori: Genel

BuyCOMM (Online Ticaret Paketi) http://www.buycomm.com.tr / http://www.onlineticaret.net
BuyCOMM İsmi, yazılış stili, ticari uygulama yöntemleri, programlanması, tasarımı, işleyiş mantığı gibi tüm aşamaları. Proje sahibi firma : markum.net
Projenin İçinde bulunduğum süreç boyunca katılımcı düzeyinde.

Felibase (Tekstil İşleyiş Programı)
Tekstil firmasının 4 ayrı şubesinde farklı yazılım şirketleri tarafından yazılmış programlardan ortak veri alarak
şirket yönetimine bilgi sunmak. Grafik / sms mesaj vs.. Proje sahibi firma: felicita.com.tr
Projenin başından sonuna kadar tüm aşamalarında tek başına.

Feliçita Web Sitesi (Tekstil sektöründen bir firmaya yapılan web sitesi) http://www.felicita.com.tr
Proje sahibi firma: felicita.com.tr
Projenin başından sonuna kadar tüm aşamalarında tek başına. (Yetkililerden iş bilgileri almak kaydıyla)

Terrabase (Paperless firma içi işleyiş takip programı)
Fazla departman’a sahip olan firmalarda departmanlar arası diyaloğu kurmak, şirket yöneticilerinin departman
işleyişlerini takip edebilmesi, departman yöneticilerinin kendi departmanlarına tam hakimiyetinin sağlanması, şirket çalışanlarının günlük, haftalık ve aylık iş süreçlerini daha iyi programlayabilmesi. Proje sahibi firma terrailac.com.tr
Projenin başından sonuna kadar tüm aşamalarında tek başına. (Yetkililerden iş bilgileri almak kaydıyla)

Terra İlaç Web Sitesi (İlaç sektöründen bir firmaya yapılan web sitesi) http://www.terrailac.com.tr
İlaç firması web sitesi, online sipariş, online T.U.S. sınavı. Proje sahibi firma: terrailac.com.tr
Projenin başından sonuna kadar tüm aşamalarında tek başına. (Yetkililerden iş bilgileri almak kaydıyla)

Doğan Haber Ajansı (DHA) Haber Yönetim Sistemi. (Uluslar arası haber ajans’ı haber portali) http://www.dha.com.tr

Türkiyenin en büyük haber ajanslarından biri olan D.H.A. web sitesi. Muhabirlerin web üzerinden Doğan Grubu Haber merkezi ile iletişim kurarak, haber, video, resimlerin merkeze gönderilmesi, editörlerin onayladığı haberlerin yayınlanabilir havuza alınması, üst düzey yöneticilerin’de buradaki haberler’den onayladıklarının yayına verilmesi.
Projenin başından sonuna kadar tüm aşamalarında yazılım yöneticisi olarak. (Yetkililerden iş bilgileri almak kaydıyla)

FARMAVISION Lojistik, stok takip ve etiket programı.

Lojistik merkezinde uluslar arası lojistik program’ına yardımcı olarak yazılmış olan, promosyon takip ve etiket(barkod) baskı programı.
Projenin başından sonuna kadar tüm aşamalarında.

Visual Studio .Net ile MDB dosyasına kayıt yapma

Tarih: Pazartesi, Ocak 11, 2010 Kategori: Genel, Yazılım & Programlama

MDB Dosyasına Kayıt Yapma

Bir adet Windows Form oluşturalım,
Formun code bölümüne geçip code bölümünün en üst kısmına

Imports System.Data.OleDb

yazalım,

Daha sonra tekrar formumuzun desing moduna geçerek üç adet Toolbox tan TextBox ekleyelim TextBox’ ların Properties sekmesinden Name’lerini adi, soyadi ve telefon yapalım.

Daha sonra formumuza bir adet buton ekleyelim ve butonun Click eventine aşağıda yazanı ekleyelim. Ancak dikkat edilmesi gereken database yolunun doğru olması dır. Ayrıca aşağıdaki örnekte daha önceden Access te oluşturduğum vbdeneme.mdb veritabanı içine kayıt isminde bir tablo yarattım. Tablonun Fields leride id, adi, soyadi ve telefon dur.

Dim oTbl As New DataTable
Dim Baglantim As New OleDbConnection
Baglantim = New OleDbConnection( “PROVIDER= Microsoft.Jet.OLEDB.4.0;Data Source=D:\db\vbdeneme.mdb;”)
Baglantim.Open()
Dim YeniNesne As OleDbDataAdapter = New OleDbDataAdapter
Dim Kayit As String = “Select * From kayit”
YeniNesne.SelectCommand = New OleDbCommand(Kayit, Baglantim)
YeniNesne.Fill(oTbl)
Dim oRow As DataRow
oRow = oTbl.NewRow()
oRow.Item( “adi”) = adi
oRow.Item( “soyadi”) = soyadi
oRow.Item( “telefon”) = telefon
oTbl.Rows.Add(oRow)
Dim oCb As New OleDbCommandBuilder
oCb.DataAdapter = YeniNesne
YeniNesne.Update(oTbl)

Evet bir mdb dosyasına formdan gelen bir veriyi kaydettik.