codepen.io/ebykdrms/pen/zYRJKmw
Başlangıç olarak Adana > Ceyhan seçimi yapıyor. setSelectBoxes() fonksiyonuna göndereceğiniz veriye göre başlangıçta seçim yapacaktır.
Bunu başka siteler üzerinden değil de doğrudan kendi siteniz üzerinden yapmak istiyorsanız şöyle bir yol kullanabilirsiniz:
1) Veritabanında bir tablo açın ve tüm kısa linkleri ve bunların normal hallerini burada tutun.
2) Kısa linkleri kendinizce bir algoritmaya göre oluşturun. Çözülebilecek herhangi bir hash algoritması kullanabilir veya basit bir şifreleme oluşturabilirsiniz. Burada güvenlik problemimiz yok zaten. Belli bir url bilgisini şifreleyen ve şifrelenmiş url bilgisini çözebilen fonksiyonlar yazın.
3) Sayfala gelen tüm istekleri tek bir sayfa karşılayacak şekilde yönlendirin. (PHP için .htaccess ayarlamaları yaparak tüm istekleri index.php'ye yönlendirin.)
4) Sayfaya gelen tüm GET parametrelerini belli bir değişkene bağlayın. (PHP için, .htaccess'te tüm parametreleri url adında bir anahtara bağlayın.)
5) Sayfaya gelen bu parametreyi okuyun ve bir kontrolden geçirerek kısa kod algoritmanıza uyup uymadığını kontrol edin.
6) Değerin şifresini çözün ve gerçek url'yi elde edin.
7) Sayfayı gerçek url'ye yönlendirin. (PHP için header()
fonksiyonu ile yönlendirme yapın.)
Tabii ki burada yönlendirme işi sizin domain'inize bağlı. Yani sizin domaininiz "prototurk.com" ise kısa linkiniz de mesela "proturk.com/sl1345" gibi bi'şey olacak. Domain'i bizzat kısaltmanız mümkün değil diye biliyorum. Bunun yerine kısa linkleri yönetmek için ayrı bir domain satın alabilirsiniz. mesela "pt.xyz" gibi bir domain'iniz olursa, bu domain'den gelen istekleri belli bir sayfaya yönlendirirsiniz ve o sayfa da sizi doğru link'e yönlendirir. "pt.zyz/sh1234" gibi bir link kullanabilir hale gelirsiniz.
Tüm bunları kendiniz yapmak istemiyorsanız bu hizmeti sunan sitelerden faydalanabilirsiniz. Google'a "kısa link oluşturma" diye yazdığınızda karşınıza birkaç tane çıkacaktır. Muhtemelen onlar da bu mantığı kullanıyorlardır. Bu hizmetin ücretli, ücretsiz ama süre kısıtlamalı versiyonları var sanırım.
Biraz da pratik bir örnek vermek gerekirse:
Diyelim ki "prototurk.com" domaini sizin. Paylaşımlı bir hosting üzerinde PHP ile çalışıyorsunuz. Veritabanını falan araya sokmadan şöyle bir örnek yapalım:
1) Kök klasörünüzde shortlinks.php adında bir dosya oluşturun ve içine şu diziyi ekleyin:
$shortLinks = ["sl1" => "akis", "sl2" => "kesfet", "sl3" => "makaleler"];
Böylece hangi kısa link'in hangi sayfaya gideceğini belirledik.
2) Kök klasörünüzde .htaccess dosyası oluşturun ve içine şunları yazın:
RewriteEngine on
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(.*)$ index.php?url=$1 [QSA,L]
Böylece domain'e gelen tüm istekleri index.php dosyasına yönlendirdik ve parametre değerlerini url key'ine topladık.
3) Kök klasörünüzde index.php dosyası oluşturun ve içine şunları yazın:
<?php
// Artık tüm istekler bu sayfada karşılanacak ve gerekli sayfalar buraya include edilecek.
// Diğer sayfalarda url hiyerarşisi sorunu yaşamamak için url'leri hep kök dizinden başlatacağız.
// Bu nedenle sabit değişkenler oluşturuyoruz.
define('ROOT_PATH', $_SERVER['DOCUMENT_ROOT']);
define('ROOT_URL', (!empty($_SERVER['HTTPS']) ? 'https' : 'http') . '://' . $_SERVER['HTTP_HOST']);
// Eğer bir php sayfasına url üzerinden doğrudan erişilmek istenirse istenmeyen açıklar doğabilir.
// Çağırılan sayfanın doğrudan mı çağırıldığı yoksa index.php'ye include edilerek mi çağırıldığını kontrol edebilmek için her sayfada kontrol edeceğimiz bir sabit değişken oluşturuyoruz.
define('PAGE_ACCESS',true);
// "prototurk.com/soru/5982-domain-nasil-kisa-link-olustururum" gibi bir istek geldiyse
// $_GET['url'] = 'soru/5982-domain-nasil-kisa-link-olustururum' olur.
// Biz bu değeri alıp "/" karakterlerinden parçalayıp ona göre hangi sayfanın istendiğini bulacağız ve bu sayfaya include ile çağıracağız.
$urlLink = isset($_GET['url']) ? $_GET['url'] : "homepage";
$urlLink = trim($urlLink, '/\t\r\0\x08');
$urlLink = explode('/', $urlLink); // $urlLink = ['soru','5982-domain-nasil-kisa-link-olustururum'] şeklinde bir dizi elde etmiş olduk.
// Sayfamızın adını tutacak değişkenimizi oluşturalım. Varsayılan olarak şimdilik ilk parametreyi atayalım.
$pageName = $urlLink[0];
// İlk parametreye bakalım ve bizim kısa linklerimizden biri olup olmadığını kontrol edelim.
// Eğer bu sayfalardan biriyse gerçek sayfa adını alalım ve işlemi burada durdurarak gerçek link'e yönlendirme yapalım.
include('shortlinks.php');
if(isset($shortLinks[$pageName])) {
$pageName = ROOT_URL."/".$shortLinks[$pageName];
header("Location:$pageName");
exit("Yönlendiriliyor...");
}
// Bu satıra kadar gelindiyse linkteki değer bizim kısa linklerimizden biri değilmiş demektir.
// Buradan sonra $urlLinks dizisindeki değerlere göre hangi sayfanın istendiği tespit edilip o sayfa include edilecek.
$pageName = $urlLinks[0];
// Mesela hiç parametre gelmediyse, yani direkt "prototurk.com" olarak istek atıldıysa biz $pageName'e şu an varsayılan olarak "homepage" değerini atadık.
// Başka bi'şey de gelmiş olabilirdi. Mesela "prototurk.com/makaleler" gelmiş olsaydı $pageName'e "makaleler" değerini atamış olacaktık.
// Elde ettiğimiz ada sahip php uzantılı bir dosya var mı diye kontrol edelim.
// Eğer kök klasörümüzde php uzantılı böyle bir dosya yoksa sayfa adımız 404 olsun.
if(!file_exist("$pageName.php")) $pageName = "404";
// Bu satıra kadar geldiysek dosyamıza da var demektir.
// Mesela "prototurk.com" veya "prototurk.com/homepage" şeklinde gelen istekler için "homepage.php" dosyamız var.
// Mesela "prototurk.com/makaleler" şeklinde gelen istekler için "makaleler.php" dosyamız var.
// Mesela "prototurk.com/asdkfjşasldfj" şeklinde gelen istekler için "404.php" dosyamız var. (Var mı diye kontrol etmedik ama olmalı.)
// Artık sayfayı include edebiliriz:
include("$pageName.php");
Daha sonra homepage.php, makaleler.php, 404.php gibi sayfalarımızı kök dizine oluşturabiliriz. Bu sayfaların her birinin başında PAGE_ACCESS
sabitinin oluşturulup oluşturulmadığını da kontol etmeliyiz.
Mesela 404.php sayfası şöyle olabilir:
<?php if(!defined('PAGE_ACCESS')) exit("Bu sayfaya doğrudan erişim yetkiniz yok."); ?>
<html>
<head>
<title>Sayfa Bulunamadı</title>
<style>
* { margin:0; padding:0; box-sizing:border-box; }
html,body { height:100%; }
body { display:flex; align-items:center; justify-content:center; }
h1 { display:flex; text-align:center; line-height:1; color:#333; }
</style>
</head>
<body>
<h1>404 - SAYFA BULUNAMADI!</h1>
</body>
</html>
Elbette bu yolu kullanarak sadece kısa linklerin değil, aslında MVC altyapılı bir sistemin de temelini atmış oluyorsunuz. Ayrıca SEO dostu url meselesine de el atmış oluyorsunuz.
Kodları test etmeden yazdığım için sorunlar, hatalı yazımlar, mantık hataları vs. olabilir. Ama temelde anlatmak istediğimi anlatabildiğimi umuyorum.
Sorunuzun benzeri stackoverflow.com'da sorulmuş.
Cevaben şöyle yazılmış:
Dokümantasyonda doğrudan bununla ilgili bir örnek var:
SELECT * FROM table WHERE SUBSTRING(field, -4) = '.png'
Burada son 4 hanesi ".png" olanları seçmiş. Siz "JPG" olmayanları seçmek istiyorsunuz:
SELECT
ptc.product_id,
p.sort_order
FROM
my_product_to_category ptc
INNER JOIN
my_product p ON p.product_id=ptc.product_id
WHERE
ptc.category_id=20
AND LENGTH(p.image)>2
AND p.status=1
AND p.quantity>0
AND SUBSTRING(p.image, -3) <> 'JPG'
ORDER BY
p.sort_order
Bu sorunun çok detaylar içeren cevapları var. Burada yazmak zor. Ama Youtube üzerinde "php haber sitesi yapımı" diye yazdığımda 2-3 ilgili sonuç çıktığını gördüm. "php yönetim paneli yapımı" üzerine daha da çok içerik var. Bunları izlemeli, denemelisiniz. Blog yapmak ile haber sitesi yapmak aynı mantığa dayanır: Bir wysiwyg editör yardımıyla sayfa oluşturup veritabanına kaydetmek.
Kabaca söylemek gerekirse:
Veritabanınızda her haber için bir satır kayıt tutarsınız. Bu satırda string halde haberin içeriğinin html kodlarını tutarsınız.
Haberi görüntülemek istediğinizde id'si ile haberi veritabanından çeker, html'i sayfaya basarsınız.
Şimdi böyle söyleyince anlamak zor. Eğitimleri izlemeli ve aynen yaparak kendiniz görmelisiniz.
$forbidden = ['2022-06-11', '2022-06-12', '2022-06-18', '2022-06-19', '2022-06-25', '2022-06-26'];
$allDatesExceptForbidens = [];
$now = date('Y-m-d');
for($i=0; $i<30; $i++) {
$thisDate = date('Y-m-d', strtotime("$now + $i days"));
if(in_array($thisDate, $forbidden)) continue;
$allDatesExceptForbiddens[] = $thisDate;
}
Bu şekilde bugünden itibaren 30 günü (?) $allDatesExceptForbiddens
dizisine aktarmış olursunuz.
Ama tabi 30 günden mesela 4 forbidden tarih denk gelmişse 30 değil 26 günü elde etmiş olursunuz.
Peki tam 30 gün elde etmek için ne yapabiliriz?
$forbidden = ['2022-06-11', '2022-06-12', '2022-06-18', '2022-06-19', '2022-06-25', '2022-06-26'];
$allDatesExceptForbidens = [];
$now = date('Y-m-d');
$targetDateCount = 30;
for($i=0; $i<$targetDateCount; $i++) {
$thisDate = date('Y-m-d', strtotime("$now + $i days"));
if(in_array($thisDate, $forbidden)) { $targetDateCount++; continue; }
$allDatesExceptForbiddens[] = $thisDate;
}
Hedef tarih sayısı olarak 30 dedik. Eğer for döngüsü istenmeyen bir tarihe denk geldiyse hedef tarih sayısını 1 artırarak döngünün fazladan 1 kere daha dönmesini sağladık. Böylece tam olarak 30 gün elde edene kadar dönmeye devam edecek.
Peki mesela tam 30 gün değil de bulunduğumuz ayın son gününe kadar olan bütün tarihleri elde etmek isteseydik?
$forbidden = ['2022-06-11', '2022-06-12', '2022-06-18', '2022-06-19', '2022-06-25', '2022-06-26'];
$allDatesExceptForbidens = [];
$now = date('Y-m-d');
$targetDateCount = (int)date('t',strtotime($now));
$dayOfToday = (int)date('d', strtotime($now));
$targetDateCount -= $dayOfToday;
for($i=0; $i<=$targetDateCount; $i++) {
$thisDate = date('Y-m-d', strtotime("$now + $i days"));
if(in_array($thisDate, $forbidden)) continue;
$allDatesExceptForbiddens[] = $thisDate;
}
Bu sefer de ayın son gününden bugünü çıkarıp döngünün bu sayıda dönmesini sağladık. Ayın son gününe kaç gün varsa, forbidden date'ler hariç, hepsini elde ettik.
Sonuç olarak elde ettiğimiz tarihleri echo ile yazdırmak istiyorsak:
// html içine alt alta yazmak için:
echo implode('<br>', $allDatesExceptForbiddens);
// textarea gibi bir yere yazmak için:
// echo implode('\n', $allDatesExceptForbiddens);
Not: Kodları onlinephp.io sitesinde test ettim.
Kullanıcı "kaan" yazdığı zaman hangi ürünleri veya hizmetleri göstereceksiniz? "kaan" burada bir ürün/hizmet sağlayıcısı mı?
Varsayımsal olarak cevap vereceğim. Diyelim ki:
Kullanıcı geldi ve "kaan" adlı ürün/hizmet sağlayıcısının tüm ürünlerini/hizmetlerini görmek istedi ve arama kutusuna "kaan" yazdı.
MySQL'deki products tablonuz:
id
item_title
item_supplier
item_price
MySQL'deki services tablonuz:
id
service_title
service_supplier
service_price
SELECT
products.id ad item_id, products.item_title, products.item_supplier, products.item_price,
services.id as service_id, services.service_title, services.service_supplier, services.service_price
FROM
products
INNER JOIN
services ON products.item_supplier = services.service_supplier
WHERE
products.item_supplier LIKE '%kaan%'
Bu sorguda products tablosuyla services tablosunu products.item_supplier = services.service_supplier
koşulunu sağlayacak şekilde birleştirdik sağlayıcı ifadesinin içinde "kaan" ifadesinin geçmesi gerektiğini söyledik.
Emin değilim ama sanırım sorun şurada olabilir:
$_SESSION["kullanici_giris"]
değerine "yes"
veya "no"
değerlerinden birini atıyorsunuz. Yani $_SESSION
'a "kullanici_giris"
key'i atıyorsunuz.
Ama kontrolü yaparken $_SESSION["guvenlik"]["kullanici_giris"]
şeklinde kontrol ediyorsunuz. Yani $_SESSION
'ın "guvenlik"
key'inin "kullanici_giris"
key'ine bakıyorsunuz.
Algoritmanızı bilmiyorum ama gözünüzden kaçmış olabilir.
$_SESSION["kullanici_giris"] = "yes";
ve $_SESSION["kullanici_giris"] = "no";
yazan yerleri
$_SESSION["guvenlik"]["kullanici_giris"] = "yes";
ve $_SESSION["guvenlik"]["kullanici_giris"] = "no";
olarak düzeltmeniz gerekiyor olabilir.
isset()
fonksiyonu true veya false döner ve sadece değişkenin varlığını ve varsa değerinin null olup olmadığını kontrol eder.
Ayrıca ""
ifadesi de if içinde false kabul edilir. Çünkü ""
ifadesi PHP tarafından 0 elemanlı bir dizi olarak algılanır. Zaten elemanı olmayan bir array de PHP'de if içinde false kabul edilir.
Kodunuzu, yorumlayıcının anladığı şekilde adım adım bakacak olursak,
$_SESSION["guvenlik"]["kullanici_giris"]
değişkeninde null haricinde bir değer varsa:
if (isset($_SESSION["guvenlik"]["kullanici_giris"]) == "") { exit("izinsiz işlem tespit edildi."); }
if(true == "") { exit("izinsiz işlem tespit edildi."); }
if(true == false) { exit("izinsiz işlem tespit edildi."); }
if(false) { exit("izinsiz işlem tespit edildi."); }
- koşul sağlanmadığı için if bloğu atlandı.
Veya $_SESSION["guvenlik"]["kullanici_giris"]
değişkeninde null haricinde bir yoksa veya bu değişken hiç oluşturulmamışsa:
if (isset($_SESSION["guvenlik"]["kullanici_giris"]) == "") { exit("izinsiz işlem tespit edildi."); }
if(false == "") { exit("izinsiz işlem tespit edildi."); }
if(false == false) { exit("izinsiz işlem tespit edildi."); }
if(true) { exit("izinsiz işlem tespit edildi."); }
- koşul sağlandığı için if bloğuna girildi ve
exit
ile yorumlama durduruldu.
Yani aslında kodlar istediğiniz işi yapıyor gibi görünüyor. Büyük ihtimalle siz bi'yerlerde $_SESSION["guvenlik"]["kullanici_giris"]
değişkenine "" değeri atıyorsunuz. Yani session'ı oluşturuyorsunuz ama içine "" değeri atıyorsunuz. isset()
fonksiyonu "" değeri de olsa bu durumda true
döner. Yani isset()
e göre değişken oluşturulmuştur ve değeri de sonuçta değer null
değildir.
Eğer tek sorun buradaysa büyük ihtimalle paylaştığınız kodun yerine şunu yazarsanız sorun ortadan kalkacaktır:
// session hiç oluşturulmamışsa durdur. Oluşturulmuş ama değeri "" ise yine durdur:
if (!isset($_SESSION["guvenlik"]["kullanici_giris"])) exit("izinsiz işlem tespit edildi.");
if ($_SESSION["guvenlik"]["kullanici_giris"]=="") exit("izinsiz işlem tespit edildi.");
Elinizdeki verinin çıktısını nasıl elde ettiniz? Bu bir array mı yoksa object mi?
Sorunuzu #php ve #javascript şeklinde etiketlemişsiniz. Javascript'in bu sorudaki yeri nedir?
Ben varsayımsal olarak PHP'ye göre 2 cevap vereceğim.
Cevap 1:
Diyelim ki normalde elinizde key'leri belli olan böyle bir veri var:
$arr = [
["id"=>1, "location"=>'Abana', "locationId"=>37],
["id"=>2, "location"=>'Acıgöl', "locationId"=>50],
["id"=>3, "location"=>'Acıpayam', "locationId"=>20],
["id"=>4, "location"=>'Adaklı', "locationId"=>12],
["id"=>5, "location"=>'Adalar', "locationId"=>34],
["id"=>6, "location"=>'Adapazarı', "locationId"=>54],
["id"=>7, "location"=>'Adıyaman', "locationId"=>2],
["id"=>8, "location"=>'Adilcevaz', "locationId"=>13],
["id"=>9, "location"=>'Afşin', "locationId"=>46],
["id"=>10, "location"=>'Afyonkarahisar', "locationId"=>3],
["id"=>11, "location"=>'Ağaçören', "locationId"=>68],
["id"=>12, "location"=>'Ağın', "locationId"=>23]
];
Bahsettiğiniz şekilde bir dizi elde etmek için şu fonksiyonu kullanabilirsiniz:
$groupedArr = ["ilceler"=>[], "sehirID"=>[]];
for($i=0; $i < count($arr); $i++) {
$thisRecord = $arr[$i];
$groupedArr["ilceler"][] = $thisRecord["location"];
$gropedArr["sehirID"][] => $thisRecors["locationId"];
}
Cevap 2:
Diyelim ki normalde elinizde key'leri belli olmayan ama sıraları belli olan böyle bir veri var:
$arr = [
[1, 'Abana', 37],
[2, 'Acıgöl', 50],
[3, 'Acıpayam', 20],
[4, 'Adaklı', 12],
[5, 'Adalar', 34],
[6, 'Adapazarı', 54],
[7, 'Adıyaman', 2],
[8, 'Adilcevaz', 13],
[9, 'Afşin', 46],
[10, 'Afyonkarahisar', 3],
[11, 'Ağaçören', 68],
[12, 'Ağın', 23]
];
Bahsettiğiniz şekilde bir dizi elde etmek için şu fonksiyonu kullanabilirsiniz:
$groupedArr = ["ilceler"=>[], "sehirID"=>[]];
for($i=0; $i < count($arr); $i++) {
$thisRecord = $arr[$i];
$groupedArr["ilceler"][] = $thisRecord[1];
$groupedArr["sehirID"][] => $thisRecors[2];
}
isset()
fonksiyonu ile bir değişkenin varlığını kontrol edebilirsiniz.
Bkz. PHP.net > isset
isset()
fonksiyonu PHP 4.0 ve üstü sürümlerde çalışır.
Parametresinde verilen değişken varsa ve değeri null
değilse true
döner. Aksi halde false
döner.
Uyarı: Sabitlerin tanımlı olup olmadığını öğrenmek için isset yerine defined()
, fonksiyonu kullanın.
if (!isset($_SESSION['dil'])) {
header('Location:dil-sec.php');
exit();
}else{
require("dil/".$_SESSION["dil"].".php");
}