BT Profesyonelleri ve Kullanıcılar için ipuçları
C# ile Programlama

C# – TelNet Client

Projenizde TCPIP üzerinde bir porttan data okumak gerekebilir. Bunu Telnet ile yapabilirsiniz.

Kendi uygulamanız içerisinde gerek duyduğunuzda basit bir Telnet Client kodu ile bunu halledebilirsiniz. 

Ben ihtiyaç duyduğumda sağlıklı çalışır bir kod bulabilmek için epey uğraştım. Sonunda mevcut örneklerden aşağıdaki şekilde derlenmiş bir kod bloğu oluşturdum ve belirttiğim IP adresinin ilgili portundan sürekli akan datayı bir DataTable içerisine almayı başardım. Sizin de işinize yarayacağını düşünüyorum.

private void btnStart_Click(object sender, EventArgs e)
        {
            string line;

            Int32 port = 1234;
            string TargetIP = "192.x.x.x";

            try
            {
                TcpClient myClient = new TcpClient(TargetIP, port);

                if (myClient.Connected)
                {
//Burada ben bir label' ın değerini değitirerek bilgi mesajı vermeyi tercih ettim...                    
lblStatus.Text = TargetIP + " - Port : " + port + " Connected";
                }

                NetworkStream myStream = myClient.GetStream();

                StreamWriter gidenVeri = new StreamWriter(myStream);
                StreamReader gelenVeri = new StreamReader(myStream);

                DataTable CDRDataTable = new DataTable();
                  
                while ((line = gelenVeri.ReadLine()) != null)
                {
                   // DataTable'a Row ekleniyor, daha önce açılan field gelen veri satırı ile dolduruluyor ve satır DataTable' a ekleniyor.

                    DataRow dr = CDRDataTable.NewRow();
                    dr["RawCdrData"] = line;
                    CDRDataTable.Rows.Add(dr);
                }
              }
                myClient.Close();
                myStream.Close();
            }
            catch (SocketException)
            {
                MessageBox.Show("Tanınmayan Host - " + TargetIP + " - Çıkış yapılıyor...", "Uyarı", MessageBoxButtons.OK, MessageBoxIcon.Warning);
            }
        }

Burada bir method’ da Datatable döndürürseniz elde ettiğiniz veriyi istediğiniz şekilde kaydetmeniz de mümkün olacaktır.

Yüksek miktarda veriyi SQL’ e yazmaya kalktığınızda ise veri miktarı ile ilgili sorun yaşamanız muhtemel. Bunun için uyguladığım çözümü de bir başka yazıda paylaşmayı düşünüyorum.

Sorularınız için yorumları kullanabilirsiniz…

Bir yorum ekleyin

E-posta adresiniz yayınlanmayacak. Gerekli alanlar * ile işaretlenmişlerdir