Java Server Page ' GİRİŞ

    JSP dinamik web sayfaları hazırlayabileceğimiz,java tabanlı bir web teknolojisidir..
JSP yazmak için ECLİPSE veya NETBEANS'i kurmanız gerekiyor.Daha sonra local bir server'i daha kurmanız gerekiyor.NETBEANS'te bunları plugins edebiliyorsunuz.Ben başlangıç olarak Apachenin TOMCAT'ini kurdum.GlassFish Tomcat gibi bir sürü sunucu var.Herhangi birini kurup işe atılabilirsiniz.Kariyerinizi java üzerine kurmayı düşünüyorsanız.Paylaşacam örnekleri anlayıp kendinizde değişik kaynaklardan çalışmaya başlayın..Java SE'den başlayıp Java EE' ile devam edin..Java çok geniştir.Bende bu yazım ile Java EE'ye geçiş yapmış bulundum.Fakat
Java SE'örnekleri paylaşmaya devam edeceğim.Swing olsun OOP olsun.Zamanım yettiğince paylaşmaya çalışacağım.İyi çalışmalar.

İLK JSP ÖRNEĞİMİZ
 
 İlk örneğimizi kodlarken dikkat edeceğimiz noktalar var.JSP taglarla yazılır.HTML kodları ile birlikte çalışır.Ve bunu yaparken bir sunucuya ihtiyaç duyar.Tıpkı PHP,ASP.NET gibi..Java'da yazdığınız çoğu kodu çalıştırmanız mümkün.Evet şimdi örneğimize bakalım..

<%--
    Document   : newjsp
    Created on : 15.Şub.2018, 13:39:20
    Author     : Gökhan
--%>

<%@page contentType="text/html" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>JSP Page</title>
</head>
<body>
    <h1>Hello World!</h1>
    <%@page language="java" %>
    <% out.println("Bu benim"); %>
    <% out.println("ilk JSP sayfam"); %>
</body>
</html>

Bu örneği NETBEANS IDE 8.2 de yazdım.Örnekte JSP taglarının <% ile başlayıp %> ile bittiğini görüyorsunuz..Onun dışında page tag'ı kullanılmış ona daha sonra ayrıntılı bakacağız..
 

JAVA-OOP BASİT KOMUTLARI GERÇEKLEŞTİREBİLEN BİR ROBOT YAPIMI (ÇOK DAHA FAZLA GELİŞTİRİLEBİLİR)


package robot;
 import javax.swing.*;
public class ROBOT {
    public String name;
    public double R;
    public double theta;
    public ROBOT(String is){R=0;theta=0;name=is;}
    public ROBOT(String is,double Ri){name=is;R=Ri;theta=0;}
    public ROBOT(String is,double Ri,double theta_angle){name=is;R=Ri;theta=theta_angle*Math.PI/180.0;}
    public ROBOT(ROBOT r1){name=r1.name;R=r1.R;theta=r1.theta;}
    public void Turn_North(){theta=Math.PI/2.0;}
    public void Turn_South(){theta=3.0*Math.PI/2.0;}
    public void Turn_West(){theta=Math.PI;}
    public void Turn_East(){theta=Math.PI;}
    public void Turn(double angle){theta+=angle*Math.PI/180.0;}
    public void Scroll(){R+=1;}
    public void Scroll(double Ri){R+=Ri;}
    public void go_back(){R-=1;}
    public void go_back(double Ri){R-=Ri;}
    public String output(){
        String s="------------"+name+"---------------\n";
        s+="Cartesian coordinates x = "+R*Math.sin(theta)+" y = "+R*Math.cos(theta)+" \n";
        s+="Polar coordinates R = "+R+" Theta angle = "+theta*180/Math.PI+" \n";
            return s;
    }
    public static void main(String[] args) {
        ROBOT R2D2=new ROBOT("aRtuDitu");
        ROBOT z2=new ROBOT("GOKHAN",1.0,90.0);
        ROBOT z3=new ROBOT(R2D2);
        String s="";
        R2D2.Turn_North();R2D2.Scroll();s+=R2D2.output();
        R2D2.Turn_West();R2D2.Scroll(2.0);s+=R2D2.output();
        z2.Turn_East();z2.Scroll(3.0);s+=z2.output();
        z2.Turn_South();z2.Scroll();s+=z2.output();
        s+="Copy Robot z3 : "+z3.output();
        JOptionPane.showMessageDialog(null,s, "Robot class test",JOptionPane.PLAIN_MESSAGE);
}
    }

JAVA-POLİMORFİZM HAYVAN ÖRNEĞİ

class Hayvan {
public void avYakala() {
System.out.println("Hayvan av Yakala");
}
}
class Kartal extends Hayvan {
public void avYakala() {
System.out.println("Kartal av Yakala");
}
}
class Timsah extends Hayvan{
public void avYakala() {
System.out.println("Timsah av Yakala");
}
}
public class Polimorfizm {

  public static Hayvan rasgeleSec() {
int sec = ( (int) (Math.random() *3) ) ;
Hayvan h = null ;
if (sec == 0) h = new Hayvan();
if (sec == 1) h = new Kartal();
if (sec == 2) h = new Timsah();
return h;
}
    public static void main(String[] args) {
    Hayvan[] h = new Hayvan[3];
// diziyi doldur
for (int i = 0 ; i < 3 ; i++) {
h[i] = rasgeleSec(); //upcasting
}
// dizi elemanlarini ekrana bas
for (int j = 0 ; j < 3 ; j++) {
h[j].avYakala(); // !Dikkat!
}
    }
   
}

JAVA-INHERITANCE KİTAP ÖRNEĞİ

class Kitap2 {
public int sayfaSayisiOgren() {
System.out.println("Kitap2 - sayfaSayisiOgren() ");
return 440;
}
public double fiyatOgren() {
System.out.println("Kitap2 - fiyatOgren() ");
return 2500000 ;
}
public String yazarIsmiOgren() {
System.out.println("Kitap2 - yazarIsmiOgren() ");
return "xy";
}
}
class Roman2 extends Kitap2 {
public int sayfaSayisiOgren() {
System.out.println("Roman2 - sayfaSayisiOgren() ");
return 569;
}
public double fiyatOgren() {
System.out.println("Roman2 - fiyatOgren() ");
return 8500000 ;
}
public static void main( String args[] ) {
Roman2 r2 = new Roman2();
int sayfasayisi = r2.sayfaSayisiOgren();
double fiyat = r2.fiyatOgren();
String yazar = r2.yazarIsmiOgren();
}
}

JAVA-SWİNG Pİ SAYISININ HESABI

import javax.swing.*;
public class TEST {

    public static void main(String[] args) {
       //pi = 4 - 4/3 + 4/5 -4/7+4/9-4/11+...+
String s;
int i;
double pi=0;
int artieksi=-1;
    for(i=1;i < 100000;i++)
    {
        artieksi*=-1;
        pi+=4/(2.0*i-1.0)*artieksi;
    }
        s="pi = "+pi;
        JOptionPane.showMessageDialog(null,s,"pi sayısı hesabı",JOptionPane.PLAIN_MESSAGE);
    }
}

JAVA-DATE() (THREAD İLE ZAMAN KONTROLÜ)

import java.util.*;
public class Tutoriall {
    public static void main(String[] args) {
        try{
            System.out.println(new Date()+"\n");
            Thread.sleep(10000);
            System.out.println(new Date()+"\n");     
        }
        catch(Exception e)
        {
            System.out.println("Got on exception");
        }
    }
}

JAVA-INHERITANCE (KALITIM BASİT ÖRNEK)

 class FutbolTakimi
{
    public int TakiminDegeri;
    int EnDegerliOyuncusu;
    int Ligi(int t)
    {
        return t;
    }
}
class BirinciLig extends FutbolTakimi
{
    FutbolTakimi Gs=new FutbolTakimi();
}
public class WhatIsInheritance {
    public static void main(String[] args) {
       BirinciLig gs=new BirinciLig();
       gs.EnDegerliOyuncusu=33;
    }
   
}

FLİP-FLOP DEVRELERİ

Flip-Floplar, çift kararlı ve eşzamanlı aygıtlardır. Eşzamanlı terimi burada, çıkışın
yalnızca saat (clock )denilen tetikleme sinyalinin belirli bir noktasında durum
değiştirdiğini anlatmaktadır.Çift kararlı olmasının nedeni de budur.Saat sinyali geldiğinde çalışacaktır.O saat sinyalini ya sizin vermeniz gerekir yada bunu otomatik yapabilecek bir aygıtınız olmalıdır.

FLİP FLOP TİPLERİ

1-S-R TİPİ FF
2-J-K TİPİ FF
3-D TİPİ FF
4-T TİPİ FF


(a) Yükselen kenar tetiklemeli
(b) Düşen kenar tetiklemeli

Yükselen ve düşen kenar tetiklemelerinin mantığı basittir.Bir önceki konumuzda gördüğümüz multivibratörlerdeki sinyal tetiklemeleri,0'dan 1'e tetikleniyorsa yükselen,1'den 0'a tetikleniyorsa düşen kenar tetiklemelidir,denir.Gösterimleri şekildeki gibi..


1-S-R TİPİ FF

S-R tipi ff daha önceki kaydımızda gördüğümüz latch devresinin clok'lu hali yani saat sinyali ile çalışıyor.Yükselen ve düşen kenar tetiklemeli saat sinyali ile..


Saat sinyalimiz olmadığında set ve resetin ne olduğu önemli değildir.Flip-flopumuz çalışmayacaktır.
Saat sinyalimiz olduğunda set 1 reset 0 olduğunda kurma set 0 reset 1 olduğunda ise resetleme yapacaktır..



2-J-K TİPİ FF

J-K tipi ff'un set,reset ve  S=0 R=0 durumları R-S tipi ff ile aynıdır.Fakat S=1 R=1 durumunda tanımsız olan durum J-K flip flop'ta tümleyen oluyor.Yani o durum tanımsız olmuyorda bir önceki durumun tersi alınıyor.       J-K tipi ff''ta  J=SET----K=RESET gibi düşünebiliriz..








3-D TİPİ FF
   
      DATA tipi flip flop tek bir bit saklanacağında kullanılır.Bilgisayardaki depolama birimleri olan registerlar D tipi ff'tan oluşuyor.



Şekilde de göründüğü gibi ne verirseniz o çıkıyor yani bildiğiniz banka.Ama veri bankası :)

4-T TİPİ FF

  J-K Flip-Flopun J ve K girişleri birbirine bağlanarak elde edilen flip-flop
türüdür. J = K = 0 iken saat işareti uygulansa da çıkışlar durum değiştirmez. J=K= 1 olduğunda ise her tetikleme de çıkışlar bir önceki durumlarının tümleyenine dönüşürler. Flip-flop adını bu özelliğinden (toggle) alır.






















TABLOLARI ÇİZECEK ZAMANIM OLMADIĞINDAN AŞAĞIDAKİ KAYNAKTAN FAYDALANDIM..
EGE ÜNİVERSİTESİ
EGE MESLEK YÜKSEKOKULU
Yrd.Doç.Dr. MUSTAFA ENGİN Yrd.Doç.Dr. DİLŞAD ENGİN


















TUTUCU (LATCH)

TUTUCU DEVRELERİ

   Tutucu, Flip-Floptan ayrı olarak değerlendirilen çift kararlı bir veri saklama aygıtıdır.Flip-Floplarla tutucular arasındaki benzerlik,tutucunun da Flip-Flop gibi iki ayrı kararlı durumda bulunabilmesidir.
Tutucunun S (set) ve R (reset) adında 2 girişi Q ve Q' adında da 2 çıkışı bulunur.

   Flip-Floplarla tutucular arasındaki benzerlik,

tutucunun da Flip-Flop gibi iki ayrı kararlı durumda bulunabilmesidir.

S R Qn+1 Q'n+1 YORUM
0 0  Qn     Q'       Tutucu önceki durumunda kalır.
0 1  0        1         Tutucu sıfırlanır.
1 0  1        0         Tutucu kurulur.
1 1  1        1         TANIMSIZ

Doğruluk tablosu yukarıda görüldüğü gibidir.
  S=0,R=1 olduğunda sıfırlama, S=1,R=0 olduğunda kurma yapılır.

MULTİVİBRATÖRLER

Multivibratör nedir ?

    Multivibratörler devrelerde gerekli olan kare dalga sinyalini yani tetikleme sinyalini üreten devrelerdir.

1-Kararsız multivibratörler

Kararsız multivibratör devrelerinde, girişe enerji verildiğinde çıkış durmadan "0" ve "1" olmaktadır. Kararsız denilmesinin sebebi çıkışın "0" mı "1" mi olacağına karar verememesi ve bu iki durum arasında sürekli olarak gelgit yapmasıdır.

Örneğin trafik ışıkları orada belirli bir saniyeler aralıklarında renklerin değişmesi gerekiyor.Bunun otomatik olması için kararsız multivibratör kullanılmalıdır.


Burada butona hiç basılmayacağı için dalgalar halinde yani belirlenen saniye aralıklarında sinyal üreteceğinden devremizde ona göre davranacaktır.

2-Tek kararlı multivibratörler

Tek kararlı multivibratörlere default olarak 0 değeri atanmıştır.Yani her butona basıldığında 1 sinyali üretilecektir.Butona basılmaz ise sinyal üretilmeyecektir.Kumandalı oyuncak araba gibi düşünebilirsiniz.Butona bastığınızda araba hareket ediyor.Sürekli gitmesi için basılı kalmanız gerekiyordur.








Butona basılmadığında sürekli 0 sinyali üretecektir.

3-Çift kararlı multivibratörler

Çift kararlı multivibratörlerde ise her butona basıldığında sinyal üretir.Sinyal kullanıcının elindedir.Butonlar kontrolü ile dalga üretirlir.Herhangi bir default değeri yoktur.Tamamen kendiniz kontrol edersiniz..

APARTMAN AİDAT OTOMASYONU(C#-MsSQL PROJE-1)



using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace ApartmanYonetim
{
    public partial class Giris : Form
    {
        public Giris()
        {
            InitializeComponent();
        }
        private void simpleButton3_Click(object sender, EventArgs e)
        {
            MessageBox.Show("Yeni Şifrenizi almak için uygulama programcısını arayın...");
        private void Giris_Load(object sender, EventArgs e)
        {

        }
        private void simpleButton1_Click(object sender, EventArgs e)
        {
            Aidat a = new Aidat();
            if (kullaniciAdi.Text == "Gokhan" && sifre.Text == "123456")
            {
                a.Show();
            }
        }
    }
}



using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Data.SqlClient;
using System.Data;

namespace ApartmanYonetim
{
    public partial class Aidat : Form
    {
        public Aidat()
        {
            InitializeComponent();
        }
        void griddoldur()
        {
           SqlConnection con = new SqlConnection("server=LOCALHOST; Initial Catalog=ApartmanYonetim;Integrated Security=SSPI");
           SqlDataAdapter da = new SqlDataAdapter("Select *FROM aidat order by blok,daireNo", con);
           DataSet ds = new DataSet();
           con.Open();
           da.Fill(ds, "aidat");
           dataGridView1.DataSource = ds.Tables["aidat"];
           con.Close();
        }
        private void dataGridView1_CellContentClick(object sender, DataGridViewCellEventArgs e)
        {

        }

        private void Aidat_Load(object sender, EventArgs e)
        {
           
        }

        private void veriGirisi_Click(object sender, EventArgs e)
        {
            ListeyeEkle l = new ListeyeEkle();
            l.Show();
        }

        private void sil_Click(object sender, EventArgs e)
        {
            ListedenSil sil = new ListedenSil();
            sil.Show();
       
        }

        private void yazdir_Click(object sender, EventArgs e)
        {
            griddoldur();
        }

        private void simpleButton1_Click(object sender, EventArgs e)
        {
            Guncelle g = new Guncelle();
            g.Show();

        }

        private void ode_Click(object sender, EventArgs e)
        {
            ekleOde ek = new ekleOde();
            ek.ShowDialog();
        }

        private void dataGridView1_CellClick(object sender, DataGridViewCellEventArgs e)
        {

        }
    }
}

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Data.SqlClient;
namespace ApartmanYonetim
{
    public partial class ListeyeEkle : Form
    {
        public ListeyeEkle()
        {
            InitializeComponent();
        }
        private void simpleButton1_Click(object sender, EventArgs e)
        {
            string sorgu = "insert into aidat(blok,kat,daireNo,borc,borcSahibi) values (@blok,@kat,@daireNo,@borc,@borcSahibi)";
            SqlConnection con = new SqlConnection("server=LOCALHOST; Initial Catalog=ApartmanYonetim;Integrated Security=SSPI");
            SqlCommand cmd = new SqlCommand(sorgu,con);
            cmd.Parameters.AddWithValue("@blok", tBlok.Text);
            cmd.Parameters.AddWithValue("@kat", tKat.Text);
            cmd.Parameters.AddWithValue("@daireNo", tDaire.Text);
            cmd.Parameters.AddWithValue("@borc", tBorc.Text);
            cmd.Parameters.AddWithValue("@borcSahibi", tBorcSahibi.Text);
            con.Open();
            cmd.Connection = con;
            try
            {
                cmd.ExecuteNonQuery();
            }
            catch (Exception ex) {
                MessageBox.Show("Bu daire dolu!!!");
            }
            con.Close();
        }
        private void simpleButton2_Click(object sender, EventArgs e)
        {
            Close();
        }
    }
}


using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Data.SqlClient;
namespace ApartmanYonetim
{
    public partial class ListedenSil : Form
    {
        public ListedenSil()
        {
            InitializeComponent();
        }

        private void simpleButton1_Click(object sender, EventArgs e)
        {
            SqlConnection con = new SqlConnection("server=LOCALHOST; Initial Catalog=ApartmanYonetim;Integrated Security=SSPI");
            string sorgu = "Delete From aidat Where daireNo=@no";
            SqlCommand cmd = new SqlCommand(sorgu, con);
            cmd.Parameters.AddWithValue("@no", Convert.ToInt32(tdaireNo.Text));
            con.Open();
            cmd.ExecuteNonQuery();
            con.Close();
        }

        private void simpleButton2_Click(object sender, EventArgs e)
        {
            Close();
        }
    }
}


using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Data.SqlClient;
namespace ApartmanYonetim
{
    public partial class ekleOde : Form
    {
        public ekleOde()
        {
            InitializeComponent();
        }

        private void groupControl1_Paint(object sender, PaintEventArgs e)
        {

        }

        private void simpleButton1_Click(object sender, EventArgs e)
        {

            string sorgu = "update aidat set borc=borc+@eklenecek";
            SqlConnection con = new SqlConnection("server=LOCALHOST; Initial Catalog=ApartmanYonetim;Integrated Security=SSPI");
            SqlCommand cmd = new SqlCommand(sorgu, con);
            int aidat=Convert.ToInt32(tBekle.Text);
            cmd.Parameters.AddWithValue("@eklenecek",aidat);
            con.Open();
            cmd.Connection = con;
            cmd.ExecuteNonQuery();
            con.Close();
        }

        private void simpleButton2_Click(object sender, EventArgs e)
        {
            string sorgu = "update aidat set borc=borc-@odenecek where daireno=@daireNo";
            SqlConnection con = new SqlConnection("server=LOCALHOST; Initial Catalog=ApartmanYonetim;Integrated Security=SSPI");
            SqlCommand cmd = new SqlCommand(sorgu, con);
            int aidat = Convert.ToInt32(tOdenecek.Text);
            cmd.Parameters.AddWithValue("@odenecek", aidat);
            cmd.Parameters.AddWithValue("@daireNo", tDaireNo.Text);
            con.Open();
            cmd.Connection = con;
            cmd.ExecuteNonQuery();
            con.Close();
        }
    }
}


using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Data.SqlClient;
namespace ApartmanYonetim
{
    public partial class Guncelle : Form
    {
        public Guncelle()
        {
            InitializeComponent();
        }
        private void simpleButton1_Click(object sender, EventArgs e)
        {
             SqlConnection con = new SqlConnection("server=LOCALHOST; Initial Catalog=ApartmanYonetim;Integrated Security=SSPI");
            
            if(cKayit.Text=="Borc"){
               
                int cevir = Convert.ToInt32(tDeger.Text);
                string sorgu="Update aidat set borc=@borc where daireNo=@daireNo";
                SqlCommand cmd = new SqlCommand(sorgu, con);
                con.Open();
                cmd.Connection = con;
                cmd.Parameters.AddWithValue("@borc",cevir);
                cmd.Parameters.AddWithValue("@daireNo", tdaireNO.Text);
                cmd.ExecuteNonQuery();
                con.Close();

        }
            else if (cKayit.Text=="BorcSahibi")
            {
             
                string sorgu="Update aidat set borcSahibi=@borcSahibi where daireNo=@daireNo";
                SqlCommand cmd = new SqlCommand(sorgu, con);
                con.Open();
                cmd.Connection = con;
                cmd.Parameters.AddWithValue("@borcSahibi",tDeger.Text);
                cmd.Parameters.AddWithValue("@daireNo", tdaireNO.Text);
                cmd.ExecuteNonQuery();
                con.Close();
            }
            else if (cKayit.Text == "Blok")
            {

                string sorgu = "Update aidat set blok=@blok where daireNo=@daireNo";
                SqlCommand cmd = new SqlCommand(sorgu, con);
                con.Open();
                cmd.Connection = con;
                cmd.Parameters.AddWithValue("@blok", tDeger.Text);
                cmd.Parameters.AddWithValue("@daireNo", tdaireNO.Text);
                cmd.ExecuteNonQuery();
                con.Close();
            }
            else if (cKayit.Text == "Kat")
            {

                string sorgu = "Update aidat set kat=@kat where daireNo=@daireNo";
                SqlCommand cmd = new SqlCommand(sorgu, con);
                con.Open();
                cmd.Connection = con;
                cmd.Parameters.AddWithValue("@kat", tDeger.Text);
                cmd.Parameters.AddWithValue("@daireNo", tdaireNO.Text);
                cmd.ExecuteNonQuery();
                con.Close();
            }
            else if (cKayit.Text == "DaireNo")
            {

                string sorgu = "Update aidat set daireNo=@daireNoo where daireNo=@daireNo";
                SqlCommand cmd = new SqlCommand(sorgu, con);
                con.Open();
                cmd.Connection = con;
                cmd.Parameters.AddWithValue("@daireNoo", tDeger.Text);
                cmd.Parameters.AddWithValue("@daireNo", tdaireNO.Text);
                cmd.ExecuteNonQuery();
                con.Close();
            }
        }
    }
}






Spring Boot Uygulamasını Heroku üzerinde Deploy Etme

Bu yazımızda sizlere spring boot ile yazılmış basit bir Rest api'nin heroku üzerinde nasıl deploy edebileceğimizi göstereceğim. Önce ...