cake routing

なぜかroutingの設定は好きですね。

app/config/routes.php

Router::scope('/', function (RouteBuilder $routes) {
    /**
     * Here, we are connecting '/' (base path) to a controller called 'Pages',
     * its action called 'display', and we pass a param to select the view file
     * to use (in this case, src/Template/Pages/home.ctp)...
     */
    // $routes->connect('/', ['controller' => 'Pages', 'action' => 'display', 'home']);
    $routes->connect('/', ['controller' => 'Posts', 'action' => 'index']);

actionがなぜindexなのでしょう???

controllerのsqlのorder byは以下のように書くようです。

$posts = $this->Posts->find('all')->order(['title' => 'DESC']);

SELECT * FROM posts LIMIT 10;は

$posts = $this->Posts->find('all')->limit(2);

ですね。

<?php

// /post/index
// /(controller)/(action)/(options)

namespace App\Controller;

class PostsController extends AppController
{
	public function  index()
	{
		// modelからデータを取得し、postsに入れる
		$posts = $this->Posts->find('all')->order(['title' => 'DESC'])
		->limit(2)
		->where(['title like' => '%3']);
		$this->set('posts', $posts);
	}
?>

cake Controllerを作成

テーブル名 + Controller.php
app/src/Controller
PostsController.php

modelからviewへの受け渡しを記載

<?php
// /post/index
// /(controller)/(action)/(options)
namespace App\Controller;

class PostsController extends AppController
{
	public function  index()
	{
		// modelからデータを取得し、postsに入れる
		$posts = $this->Posts->find('all');
		$this->set('posts', $posts);
	}
}
?>

さーバーで見てみると、あれ、小文字になってますね。。

cake Viewを作成

App/src/Template/

テーブル名のフォルダを作成

index.ctpファイルを作成
App/src/Template/Post/index.ctp

テーブルの配列がテーブル名で渡される。例えば、tableがteasなら、viewには、$teasでレコードがobjectで渡される。すげー。

<h1>Blog Posts</h1>

<ul>
	<?php foreach($posts as $post):?>
		<li><?= h($post->title); ?></li>
	<?php endforeach; ?> 
</ul>

cake DBtableのModelを作成

テーブル名は複数形
src/Model/Table/
HogesTable.php

ここでは
PostsTable.php

<?php
namespace App\Model\Table;
use Cake\ORM\Table;
class PostsTable extends Table
{
	public function initialize(array $config)
	{
		$this->addBehavior('Timestamp');
	}
}

やばい、完全に眠くなってきた。

composerを入れてcakeをインストール

まずローカルにcomposerを入れます。

curl -sS https://getcomposer.org/installer | php

続いて、cakeをインストール

php composer.phar create-project --prefer-dist cakephp/app myapp

cd myapp

サーバーを立てます。

bin/cake server -H 192.168.33.10 -p 8000

準備が出来ました。

DBの設定
config/app.php

'Datasources' => [
        'default' => [
            'className' => 'Cake\Database\Connection',
            'driver' => 'Cake\Database\Driver\Mysql',
            'persistent' => false,
            'host' => 'localhost',
            /**
             * CakePHP will use the default DB port based on the driver selected
             * MySQL on MAMP uses port 8889, MAMP users will want to uncomment
             * the following line and set the port accordingly
             */
            //'port' => 'non_standard_port_number',
            'username' => 'my_app',
            'password' => 'secret',
            'database' => 'my_app',
            'encoding' => 'utf8',
            'timezone' => 'UTC',
            'flags' => [],
            'cacheMetadata' => true,
            'log' => false,

mvcをつくる
bin/cake bake all posts
(※postsはDBのテーブル名)

そして、192.168.33.10:8000/posts をたたくと、DBのテーブルのカラム・レコード一覧が表示される。

create table cake.posts(
	id int unsigned auto_increment primary key,
	title varchar(255),
	body text,
	created datetime default null,
	modified datetime default null
);

ImageJPEGとファイルパーミッション

こちらは画像生成が可能で

ImageJPEG($out, '$hoge');

こちらは出来ないので、何故か紋々としていたら、

    
ImageJPEG($out, 'img/'.$hoge.'');  

フォルダのパーミッションが
RWX
R X
R X
755 になっていたからですね。

RWX
RWX
RWX
777 に変更したところ、上手くいきました。

危ない危ない、もう少しでやけ酒(現実逃避)コースでした。

RGBヒートマップ

<?php

function getR($i){
    if($i < 128){
        $ret = 0;
    } else if($i > 127 && $i < 191){
        $ret = ($i-127)*4;
    } else if ($i > 190){
        $ret = 255;
    }
    return $ret;
}
function getG($i){
    if($i >= 64 && $i <= 191){
        $ret = 255;
    } else if ($i < 64){
        $ret = $i * 4;
    } else {
        $ret = 256-($i-191)*4;
    }
    return $ret;
}
function getB($i){
    if($i <= 64){
        $ret = 255;
    }else if($i > 64 && $i < 127){
        $ret = 255-($i-64)*4;
    } else if($i >= 127){
        $ret = 0;
    }
    return $ret;
}
header("content-type: image/png");
$image = imagecreate(512,100);
for($i = 0; $i < 256; $i++){
    $tmp = imagecolorallocate($image, getR($i), getG($i), getB($i));
    imagefilledrectangle($image, $i * 2, 0, ($i*2)+2, 99, $tmp);
}
imagepng($image);
imagedestroy($image);
?>

ページングに合わせたコンテンツ表示

<style>
 .current{
	font-weight: bold;
 }
</style>
<?php

$logdata = array("a","b","c","d","e","f","g","h","i","j","k","l","m","n","o","p","q","r","s","t","u","v","w","x","y","z");
$count = count($logdata);
$max = 5;
$limit = ceil($count/$max);

$page = empty($_GET&#91;"page"&#93;)? 1: $_GET&#91;"page"&#93;;

$pstart = ($page == 1)? 0: ($page-1)* $max;
$pend = ($page * $max);


print"<p>";

for($i=$pstart;$i<$pend;$i++){
	if($i >= $count){break;}

	print $logdata[$i]." ";
}

print "</p>";

$page = empty($_GET["page"])? 1:$_GET["page"];
$disp=3;

$next = $page+1;
$prev = $page-1;

$start = ($page-floor($disp / 2) > 0) ? ($page-floor($disp/2)) : 1;
$end = ($start > 1) ? ($page+floor($disp/2)) : $disp; //55
$start = ($limit < $end) ? $start-($end-$limit):$start;

if($page != 1 ) {
         print '<a href="?page='.$prev.'">&laquo; 前へ</a> ';
 }

if(($page - $disp) > 0 | $page == $disp){
	if($start >= floor($disp/2)){
        print '<a href="?page=1">1</a>';
        if($start > floor($disp/2) and $page != $disp){
        	print "..."; 
        }
        if($page == $disp){
        	print " ";
        } 
  }
}
for($i=$start; $i <= $end ; $i++){
        $class = ($page == $i) ? ' class="current"':"";
        if($i <= $limit && $i > 0 )
            print '<a href="?page='.$i.'"'.$class.'>'.$i.'</a> ';
    }

if($limit > $end){
	if($limit - 1 > $end) print "...";
	print '<a href="?page='.$limit.'">'.$limit.'</a>';
}
if($page < $limit){
        print ' <a href="?page='.$next.'">次へ &raquo;</a>';
}
?>

想像してたより、早かった。