Skip to content

Latest commit

 

History

History
302 lines (211 loc) · 8.02 KB

README.md

File metadata and controls

302 lines (211 loc) · 8.02 KB

PHP'den NodeJS'e Geçiş

Bildiğiniz gibi yıllardır PROTOTURK youtube kanalında PHP programlama dili ile ilgili içerikler ürettim. Biraz da NodeJS içerikleri üretmek istediğim için ve kanalın neredeyse tamamı PHP geliştirdiği için PHP'den NodeJS'e soft bir geçiş için bir rehber hazırlamak istiyorum.

Aynı zamanda zaten bu işlemi videolu olarak yapıyoruz, burada da yazılı kalsın.

Gereksinimler

Bu rehber sizin PHP'yi zaten bildiğinizi ve temel JavaScript'e hakim olduğunuzu kabul eder. O yüzden değişkenler, fonksiyonlar, döngüler, diziler, nesneler gibi kavramları ele almadan NodeJS ve Express ile web uygulamaları geliştirmeye odaklanır.

Ancak elbette bazı durumlarda PHP'de nasıldı, NodeJS'de nasıl gibi sorulara cevap vereceğimiz bölümler olacak.

Hello World!

PHP

PHP'de bir işleme başlamak istediğinizde .php uzantılı bir dosya açıp echo ile bir çıktı verebiliyorsunuz. ,

<?php

echo "Hello, world!";

NodeJS

NodeJS'de ise önce bir proje initialize etmeniz gerekiyor. Bunun için ilk olarak şu komutu çalıştırıyorsunuz:

npm init -y

bu bize bir package.json dosyası oluşturuyor. NPM node'un paket yöneticisi, PHP'deki composer gibi düşünebilirsiniz. package.json ise php'deki composer.json gibi düşünebilirsiniz.

Daha sonra bir app.js dosyası oluşturup şu kodları yazın:

console.log('Hello, world!')

Ve çalıştırıp test edin:

node app.js

Elbete, PHP'de yazılanı tarayıcıda, NodeJS'de yazılanı konsol'da görüyoruz şu an. O yüzden biraz daha anlamlı örnek verelim.

Routing Islemleri

PHP

PHP'de routing işlemleri için bir sürü paket var kullanabileceğimiz. Ama temelde aslında URL'i parse ederek hangi alanda hangi kodun çalıştıracağını söylüyoruz. Örneğin:

Route::get('/', function() {
  return 'anasayfa'
});

Route::get('/iletisim', '\Controllers\Contact');

Route::get('/user/:url', '\Controllers\User\Detail');

gibi. Tabi bu kod doğrudan çalışmaz ancak PHP developer olarak ne demek istediğimi anladınız bence :D

NodeJS

NodeJS'de web uygulamaları geliştirilirken en yaygın kullanılan express çatısı. Elbette bir sürü alternatifi var ama soft geçişte sanırım en mantıklısı bu. Dolayısı ile routing'ler ile çalışmak için ilk olarak express paketini kuralım.

npm i express

Ve daha sonra app.js dosyamızı şöyle güncelleyelim.

import express from "express"

const app = express()

app.get('/', (req, res) => {
  res.send('anasayfa')
})

app.get('/iletisim', (req, res) => {
  res.send('iletisim')
})

app.listen(3000, () => console.log('Uygulama 3000 portundan dinleniyor'))

Ve bunu çalıştıralım.

node app.js

Artık http://localhost:3000 ve http://localhost:3000/iletisim adreslerinden yazdığınız kodları görebilirsiniz.

Bir başka örnekte dinamik değerleri almakla ilgili olsun. Örneğin /user/tayfunerbilen adresine girdiğimizde tayfunerbilen değeri dinamik olacağı için bunu almak gerekiyor. Onun içinde şöyle bir route ekleyebilirdik:

app.get('/user/:slug', (req, res) => {
  res.send('hoşgeldin ' + req.params.slug)
})

Burada :slug olarak belirttiğimiz değeri req.params içinde slug olarak erişebiliyor. Yani buraya :adana yazsaydım req.params.adana olarak alıp kullanacaktım.

HTML ile Kullanımı

PHP

Elbette php'nin html'e gömülebilen bir dil olduğunu biliyoruz. Örneğin:

$title = 'deneme baslik';
$content = 'deneme content';

require __DIR__ . '/home.php/';

ve home.php şöyle olsun:

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title><?=$title?></title>
</head>
<body>

<div>
   <?=$content?>
</div>

</body>
</html>

NodeJS

Bunun nodejs karşılığında birden fazla alternatif template engine olsada ben EJS ile örneğini göstereceğim çünkü PHP yazan birisine çok daha yakın hissettiriyor :D Önce paketi kuralım:

npm i ejs

Daha sonra express'de template engine olarak ejs kullanacağımızı söyleyelim.

app.set('view engine', 'ejs')

ve views klasörü oluşturup içine bir tane index.ejs dosyası açalım. Evet ejs kodlarımızı .ejs uzantılı dosyada yazıyoruz :D

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title><%=title%></title>
</head>
<body>

<div>
   <%=content%>
</div>

</body>
</html>

son olarakta bunu / anasayfaya girdiğinde render edelim.

app.get('/', (req, res) => {
	res.render('index', {
		title: 'Site Basligi',
		content: 'Hosgeldin gardas!'
	})
})

sonuç olarak localhost:3000 adresine girdiğimizde dinamik değerleri güzel bir şekilde kullandığımız ve php'den çokta farklı olmadığını göreceksiniz kullanımın.

Static Dosyalar

PHP'de tarayıcıdan bir dosyaya erişmek için ek bir ayar yapmanıza gerek yok. Ancak bir nodejs projesinde bunun ayarını express çatısını kullanıyorsak şöyle yapıyoruz:

app.use('/assets', express.static('assets'))

böylece assets içinde css, image, js gibi dosyaları tutabilir ve erişebilirsiniz. Örneğin dosyalar yüklendiği upload klösörünü de 2. bir tanımla ayarlayabilirsiniz.

app.use('/upload', express.static('upload'))

Form Validasyon İşlemleri

Validasyon işlemleri için kullanabileceğiniz bir sürü paket mevcut. Ben bunların arasından express-validator paketini kullanmaya karar verdim.

Kurmak için:

npm i express-validator

Kullanırkende, validasyon işlemi yapacağınız route'da middleware mantığında kullanıyorsunuz. Örneğin username, email, password ve passwordConfirmation alanlarına sahip form değerlerimiz olsun. Bunların kontrolünü /register post işleminde kontrol edelim.

import { body, validationResult } from 'express-validator';

// diger app kodlari

app.post(
  '/register',
  [
    // Kullanıcı adı en az 3 karakter olmalı ve alfanümerik olmalıdır.
    body('username')
      .isLength({ min: 3 })
      .withMessage('Kullanıcı adı en az 3 karakter olmalıdır.')
      .isAlphanumeric()
      .withMessage('Kullanıcı adı sadece alfanümerik karakterler içermelidir.'),

    // E-posta geçerli olmalıdır.
    body('email')
      .isEmail()
      .withMessage('Geçerli bir e-posta adresi girin.'),

    // Şifre en az 6 karakter uzunluğunda olmalıdır.
    body('password')
      .isLength({ min: 6 })
      .withMessage('Şifre en az 6 karakter uzunluğunda olmalıdır.'),

    // Şifre ve şifre doğrulama alanları eşleşmelidir.
    body('passwordConfirmation').custom((value, { req }) => {
      if (value !== req.body.password) {
        throw new Error('Şifre doğrulama eşleşmiyor.');
      }
      return true;
    }),
  ],
  (req, res) => {
    const errors = validationResult(req);
    if (!errors.isEmpty()) {
      return res.status(400).json({ errors: errors.array() });
    }

    // Veriler doğrulandıktan sonra kayıt işlemi gerçekleştirin.
    const { username, email, password } = req.body;
    res.send(`Kullanıcı ${username} başarıyla kaydedildi.`);
  }
);

Oturum Yönetimi (SESSION)

Oturum yönetimi için express-session paketini kullanıyoruz. Önce paketi kuralım:

npm i express-session

daha sonra app.js de yani main javascript dosyanızda bunu içeri alın.

import session from "express-session"

ve kullanırken express de middleware olarak şöyle kullanın:

app.use(
	session({
		secret: 'benzersiz_bir_anahtar', // session sifrelemesi icin
		resave: false,
		saveUninitialized: true
	})
)

artık routing'de req altında req.session olarak session'lara erişebilir ya da yeni session'lar tanımlayabilirsiniz. Örneğin:

app.get('/', (req, res) => {
	req.session.user_id = 3 // artik session islemim basladi
})

oturumu sonlandırmak içinde destroy() metodunu kullanabilirsiniz. Örneğin:

app.get('/logout', (req, res) => {
	req.session.destroy() // oturum sonlandırıldı
})