Yii2 urlManager

config/main.php dosyasında bulunan UrlMaanger componenti ile Yii projelerinizde görünen Url yapınızı biçimlendirebilirsiniz.
basit haliyle :

‘urlManager’ => [

‘enablePrettyUrl’ => true,
‘showScriptName’ => false,

],

Burada yaptıgımız işlemler;

‘enablePrettyUrl’ => true,

Pretty url yi etkinleştimek : sadece bu işlemi yaptıgınızda projenizde var olan linklere tıkladıgınızda “?r=site/about” şeklinde değil “/site/about” şeklinde yönlendirilmeye başladığını göreceksiniz.

ancak bazı yönlendirmeler hala çalışmıyor:

çözümü için “web/” dizininde yeni bir “.htaccess” dosyası oluştuyoruz.

ve içeriği:

RewriteEngine On
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(.*)\?*$ index.php?r=$1 [L,QSA]

ve artık linklerimiz çalışıyor.

ancak id veya parametre içeren sayfalara gittiğinizde hala “/user/update?id=2” urller görüyoruz. Hadi bunları da yönlendirelim,

bunun için yine config/main.php dosyamıza gidelim ve rules kısmına;

‘urlManager’ => [
‘enablePrettyUrl’ => true,
‘showScriptName’ => false,
‘rules’ => [

&#8216;<controller:\w+>/<id:\d+>&#8216;=>&#8217;<controller>/view&#8217;,
&#8216;<controller:\w+>/<action:\w+>/<id:\d+>&#8216;=>&#8217;<controller>/<action>&#8216;,
&#8216;<controller:\w+>/<action:\w+>&#8216;=>&#8217;<controller>/<action>&#8216;,

],
],

şeklinde ekleyelim.

artık urllerimiz sağlıklı çalışıyor.

Composer Kurulumu ve Kullanımı (macOs)

Composer; php uygulamaları ve uygulama içerisinde kullanılan kütüphaneler için bağımlılık yönetimi sağlayan bir paket yöneticisidir.

Composer Nasıl Kurulur (macOs)

php -r “copy(‘https://getcomposer.org/installer’, ‘composer-setup.php’);”

Composer-setup.php dosyasını indirdik, çalıştıralım;

php composer-setup.php

sonuç:

All settings correct for using Composer
Downloading…

Composer (version 2.1.12) successfully installed to: /Users/userfilename/composer.phar
Use it: php composer.phar

Evet Compposer başarıyla yüklendi.

php composer.phar –version

komutuyla versiyon teyidi yapabilirsiniz.

Composer version 2.1.12 2021-11-09 16:02:04

çıktısıyla işlemin başarılı oldugunu teyid ettik.

İndirdiğimiz dosyayı temizleyebiliriz:

php -r “unlink(‘composer-setup.php’);”

ancak hala composer komutu ile global olarak çalıştıtramıyoruz. Bunun için ;

mv composer.phar /usr/local/bin/composer

komutuyla dosyamızı taşıyoruz.

“/usr/local/bin/” dosyanız henüz yoksa bu adımda

mv: rename composer.phar to /usr/local/bin/composer: No such file or directory

şeklinde bir hata ile karşılaşıyorsanız;

sudo mkdir -p /usr/local/bin

komutu ile ilgili dizini oluşturabilirsiniz. ve tekrar

mv composer.phar /usr/local/bin/composer

komutunu çalıştırmayı deneyebilirsiniz.

işlem başarılı ise

composer

yazdığınızda çalışacaktır.

Php xml okuma

Merhaba sistemler arası veri akatarımlarında hala en yaygın kullanılan yöntemlerden birisi de xml ile veri aktarımıdır. Stok güncelleme, güncel fiyatları alma, ürün güncelleme gibi birçok süreçte
yazılımcı arkadaşların karşısına çıkan bir süreçtir.

Bu yazımızda php ile xml okuma konusuna değineceğiz.

Devamı

aşağıdaki gibi bir xml yapımız olduğunu varsayalım.

“< ?xml version='1.0'?> HYN-73737-11
Hyundai
0
Test ProductName-1 225.4318
HYN-73737-12
Dacia
3
Test ProductName-1 2354.457
HYN-73737-13
Dacia
3
Test ProductName-1 2354.457

php ile bu dosyayı okuyabilmek için;

header(“Content-Type: text/html; charset=utf8”);
$xml=simplexml_load_file(“http://xmlyolu”);
$rowNo=0;
foreach ($xml->Product $urun) {
$rowNo++;
echo $rowNo.’ ‘;
echo $stokKodu=$urun->StockCode.’
‘;

}

örnek kodu ile xml dosyamızı okuyabiliriz. Buradaki önemli olan nokta “$xml->Product” kısmı xml ağacınızdaki kırılıma göre ve xml den okumak istediğiniz verilere göre bu kısmı
düzenlemeniz gerekir.

faydalı olması dileğiyle.

Php mb_convert_encoding fonksiyonu ve türkçe karakter düzeltme

Projelerde özellikle farklı dosya tiplerinden (excel, csv) veri okuyup yazdığımız veya farklı veritabanından veri aktarırken sık karşılaşılan problemlerden birisi de Türkçe karakter hatasıdır.
Bunun birçok çözüm yolu mevcuttur, eğer veritabından çektiğiniz verilerde türkçe karakter sorunu yaşıyorsanız mysql bağlantınıza charset set etmek, php dosyanıza header content-type eklemek bunlardan bazılarıdır. Ancak zaman olur ki herşey yapılmışken hala bazı verilerinizde türkçe karakterler bozuk gözükür buna örnek olarak “ş” karfi düzgün gözükürken “Ö” harfi hatalı karakter olarak gelebilmektedir.
Devamı

Burada geriye verilerimizi ayrıştırdıktan sonra değişken olarak kontrol sağlamak kalıyor ve yardımımıza “mb_convert_encoding” fonkisyonu yetişiyor.

Bu fonksiyonun görevi önceden kodlaması bilinen veya bilinmeyen bir değişkeni sizin belirlediğiniz karakter setine çevirme.

Kullanımı: (Gelen değişkenin kodlamasını biliyorsak)

$iyiKod= mb_convert_encoding($kotuKod, “UTF-8”, “ISO-8859-1”);

Kullanımı: (Gelen değişkenin kodlamasını bilmiyorsak)

$iyiKod= mb_convert_encoding($kotuKod, “UTF-8”, “auto”);