asklife

IT&Life

Category: CakePHP (page 2 of 6)

CakePHPでごりごり実装したので作業メモ

CakePHPでごりごり実装したので作業メモ

・RequestはPOST/GET/

$this->request->is('post')

・テーブルにカラムを追加する

ALTER TABLE events add etname varchar(10);

・hidden()をつかう

echo $this->Form->hidden('Event.etname',array('value' => $etname));

・viewからConrtorllerを呼ぶ

$etname = $this->requestAction('events/generateRandomString');

・CakePHPのセッション

$this->Session->write('etname',$etname);
if ($this->Session->check('etname')){
    	echo $this->Session->read('etname');
}

・Controllerの実行前に処理するメソッド

public function beforeFileter(){
	parent::beforeFileter();
	$this->Auth->allow();
}

・ログの出力

// app/Config/bootstrap.php
App::uses('CakeLog', 'Log');

//Controllerのメソッドの先頭等で
$this->log('[HogeController/hoge()] REQUEST', 'debug');

・SimplePasswordHasher()を使う

App::uses('SimplePasswordHasher', 'Controller/Component/Auth');

MacのMAMPでCakePHP入門

MacのMAMPでCakePHPのチュートリアルを実装

MAMPのDocument Rootは
/Applications/MAMP/htdocs
です。

CakePHPチュートリアルをやっていきます。
http://book.cakephp.org/2.0/ja……d.html#id2

以下は自分用のメモ

まずはCakePHPをgit cloneします。

cd /Applications/MAMP/htdocs
git clone git://github.com/cakephp/cakephp.git

次にDB・テーブル作成

/* まず、postsテーブルを作成します: */
CREATE TABLE posts (
    id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
    title VARCHAR(50),
    body TEXT,
    created DATETIME DEFAULT NULL,
    modified DATETIME DEFAULT NULL
);

/* それから、テスト用に記事をいくつか入れておきます: */
INSERT INTO posts (title,body,created)
    VALUES ('タイトル', 'これは、記事の本文です。', NOW());
INSERT INTO posts (title,body,created)
    VALUES ('またタイトル', 'そこに本文が続きます。', NOW());
INSERT INTO posts (title,body,created)
    VALUES ('タイトルの逆襲', 'こりゃ本当にわくわくする!うそ。', NOW());

database.phpをリネームコピーし、中身を書き換える。

cp -p app/Config/database.php.default app/Config/database.php

DB設定をあわせます。

public $default = array(
         'datasource' => 'Database/Mysql',
         'persistent' => false,
         'host' => 'localhost',
         'login' => 'user',
         'password' => 'password',
         'database' => 'cakephp',
         'prefix' => '',
         //'encoding' => 'utf8',
);

セキュリティ用のSaltを書き換え、ハッシュ生成用にランダムな値をセット

vi app/Config/core.php
Configure::write('Security.salt', 'hogehogehogehoge');
Configure::write('Security.cipherSeed', 'hogehogehogehoge');

最後にapp/tmpの権限を変更

chmod -R 755 app/tmp

DebugKitをインストール
https://github.com/cakephp/debug_kit

上記からZipをダウンロードし、解凍しapp/Plugin/DebugKitとして展開します。

app/Config/bootstrap.php

CakePlugin::load('DebugKit');

app/Controller/AppController.php

class AppController extends Controller {
	public $components = array('DebugKit.Toolbar');
}

app/Config/core.php

Configure::write('debug',2);

さて、ここまででCakePHPの準備完了

ブログチュートリアル開始

Postモデル作成

touch app/Model/Post.php
vi app/Model/Post.php

<?php
class Post extends AppModel {
    public $validate = array(
        'title' => array(
            'rule' => 'notEmpty'
        ),
        'body' => array(
            'rule' => 'notEmpty'
        )
    );
}

ここでPostクラスとするのはPostテーブルを作ったからです。

Postコントローラ作成

touch app/Controller/PostsController.php
vi app/Controller/PostsController.php

<?php
class PostsController extends AppController {
    public $helpers = array('Html', 'Form', 'Session');
    public $components = array('Session');

    public function index() {
        $this->set('posts', $this->Post->find('all'));
    }

    public function view($id) {
        if (!$id) {
            throw new NotFoundException(__('Invalid post'));
        }

        $post = $this->Post->findById($id);
        if (!$post) {
            throw new NotFoundException(__('Invalid post'));
        }
        $this->set('post', $post);
    }

    public function add() {
        if ($this->request->is('post')) {
            $this->Post->create();
            if ($this->Post->save($this->request->data)) {
                $this->Session->setFlash(__('Your post has been saved.'));
                return $this->redirect(array('action' => 'index'));
            }
            $this->Session->setFlash(__('Unable to add your post.'));
        }
    }
    public function edit($id = null) {
    	if (!$id) {
        	throw new NotFoundException(__('Invalid post'));
    	}

    	$post = $this->Post->findById($id);
    	if (!$post) {
    	    throw new NotFoundException(__('Invalid post'));
    	}

    	if ($this->request->is(array('post', 'put'))) {
        	$this->Post->id = $id;
        	if ($this->Post->save($this->request->data)) {
        	    $this->Session->setFlash(__('Your post has been updated.'));
        	    return $this->redirect(array('action' => 'index'));
        	}
        	$this->Session->setFlash(__('Unable to update your post.'));
    	}

    	if (!$this->request->data) {
        	$this->request->data = $post;
    	}
    }

public function delete($id) {
    if ($this->request->is('get')) {
        throw new MethodNotAllowedException();
    }

    if ($this->Post->delete($id)) {
        $this->Session->setFlash(__('The post with id: %s has been deleted.', h($id)));
        return $this->redirect(array('action' => 'index'));
    }
}


}

ここでindex()メソッドは
example.com/posts/index
というHTTPリクエストで呼ぶことになる。

set()はControllerからViewへデータを渡す。

Postビュー作成

mkdir app/View/Posts
touch app/View/Posts/index.ctp
vi app/View/Posts/index.ctp

<!-- File: /app/View/Posts/index.ctp -->

<h1>Blog posts</h1>
<p><?php echo $this->Html->link('Add Post', array('action' => 'add')); ?></p>
<table>
    <tr>
        <th>Id</th>
        <th>Title</th>
        <th>Actions</th>
        <th>Created</th>
    </tr>

<!-- ここで$posts配列をループして、投稿情報を表示 -->

    <?php foreach ($posts as $post): ?>
    <tr>
        <td><?php echo $post['Post']['id']; ?></td>
        <td>
            <?php echo $this->Html->link($post['Post']['title'], array('action' => 'view', $post['Post']['id']));?>
        </td>
        <td>
            <?php echo $this->Form->postLink(
                'Delete',
                array('action' => 'delete', $post['Post']['id']),
                array('confirm' => 'Are you sure?'));
            ?>
            <?php echo $this->Html->link('Edit', array('action' => 'edit', $post['Post']['id'])); ?>
        </td>
        <td>
            <?php echo $post['Post']['created']; ?>
        </td>
    </tr>
    <?php endforeach; ?>

</table>

viewビューを作成
※わかりにくい。。。笑


touch app/View/Posts/view.ctp
vi app/View/Posts/view.ctp

<!-- File: /app/View/Posts/view.ctp -->

<h1><?php echo h($post['Post']['title']); ?></h1>

<p><small>Created: <?php echo $post['Post']['created']; ?></small></p>

<p><?php echo h($post['Post']['body']); ?></p>

addビューを作成

touch app/View/Posts/add.ctp
vi app/View/Posts/add.ctp

<!-- File: /app/View/Posts/add.ctp -->

<h1>Add Post</h1>
<?php
echo $this->Form->create('Post');
echo $this->Form->input('title');
echo $this->Form->input('body', array('rows' => '3'));
echo $this->Form->end('Save Post');
?>

editビューを作成

touch app/View/Posts/edit.ctp
vi app/View/Posts/edit.ctp

<!-- File: /app/View/Posts/edit.ctp -->

<h1>Edit Post</h1>
<?php
echo $this->Form->create('Post');
echo $this->Form->input('title');
echo $this->Form->input('body', array('rows' => '3'));
echo $this->Form->input('id', array('type' => 'hidden'));
echo $this->Form->end('Save Post');
?>

ルーティングを変える
※これはやらなくてもOK

vi /app/Config/routes.php

// Router::connect('/', array('controller' => 'pages', 'action' => 'display', 'home'));
Router::connect('/', array('controller' => 'posts', 'action' => 'index'));

http://localhost:8888/
http://localhost:8888/cakephp/posts/index

を確認してみる。

WEBサーバにあげて動かしてみると権限とかいろいろ詰まった。

Warning (512): CakePHPのフォルダ/app/tmp/cache/ is not writable [CORE/Cake/Cache/Engine/FileEngine.php, line 320]

chmod -R o+w app/tmp/cache/

つぎはCSSが反映されていない問題を解決

sudo vim /etc/apache2/apache2.conf

<Directory "CakePHPのパス(環境に合わせて変えましょう)">
    AllowOverride all
</Directory>

sudo service apache2 restart

次はこれを実装してみよう。
#CakePHP 爆速でAPIを実装するチュートリアル
http://slywalker.hateblo.jp/en……/15/115907

git clone https://github.com/slywalker/cakephp-app-api_sample

CakePHPのシェル機能でバッチ処理

シェルクラスを作る。

class BatchShell extends Shell {
	public function main(){
		$this->log('test shell', LOG_DEBUG);
	}
}

ディレクトリは
/app/vendors/shells/batch.php

実行時のコマンド(mainメソッド実行)は

[Cakeアプリケーションのパス]/cake/console/cake test -app [Cakeアプリケーションのパス]/app >/dev/null 2>&1

method1を叩くコマンドは

[Cakeアプリケーションのパス]/cake/console/cake test method1 -app [Cakeアプリケーションのパス]/app >/dev/null 2>&1

cron登録コマンド

crontab -e

そして

10 * * * * php  /path/cake/console/cake.php batch

これでbatch.phpが叩かれる。

CakePHPでブログ作成チュートリアル

CakePHPでDBの設定

/* まず、postsテーブルを作成します: */
CREATE TABLE posts (
    id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
    title VARCHAR(50),
    body TEXT,
    created DATETIME DEFAULT NULL,
    modified DATETIME DEFAULT NULL
);

/* それから、テスト用に記事をいくつか入れておきます: */
INSERT INTO posts (title,body,created)
    VALUES ('タイトル', 'これは、記事の本文です。', NOW());
INSERT INTO posts (title,body,created)
    VALUES ('またタイトル', 'そこに本文が続きます。', NOW());
INSERT INTO posts (title,body,created)
    VALUES ('タイトルの逆襲', 'こりゃ本当にわくわくする!うそ。', NOW());
public $default = array(
    'datasource' => 'Database/Mysql',
    'persistent' => false,
    'host' => 'localhost',
    'port' => '',
    'login' => 'cakeBlog',
    'password' => 'c4k3-rUl3Z',
    'database' => 'cake_blog_tutorial',
    'schema' => '',
    'prefix' => '',
    'encoding' => 'utf8' //日本語ではencodingを指定しましょう。
);

Postsモデルの設定

ここでMVCを作り、CRUDメソッドを作っておきます。
詳細はリンク先で。

さて本題、ログイン認証設定です。

CREATE TABLE users (
    id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
    username VARCHAR(50),
    password VARCHAR(50),
    role VARCHAR(20),
    created DATETIME DEFAULT NULL,
    modified DATETIME DEFAULT NULL
);

認証用のMVCを作成します。詳細はリンク先で。

年末にかけてコーディングするためのインプット-CakePHP編

Google Feed APIの基礎 (全5回) – ドットインストール.

CakePHPでEmailコンポーネントを使ってメールを送ってみる | helog.

CakePHPのCakeEmailでメール送信してみた | GNJYOブログ.

CakePHPのRSSヘルパーの使い方まとめ – 頭ん中.

CakePHP1.2でRSS2.0を出力する[RSS][CakePHP] | QUALL – blog.

CakePHP RSSフィードの取得 | HAPPY*TRAP.

順次追加

Older posts Newer posts

© 2017 asklife

Theme by Anders NorenUp ↑