質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

Q&A

解決済

1回答

5276閲覧

アクションごとにアクセス制限

atsupoooon

総合スコア47

CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

0グッド

1クリップ

投稿2016/08/12 08:50

cakephp 2.7

会員登録しているユーザが投稿した記事のみ削除・編集ができるようしたいと
思っております。

現在の状況としては、下記になります。

  1. opauthでFBとTWでログイン・会員登録できるように実装完了。
  2. ユーザ1が投稿した記事は、編集・削除が実装完了。
  3. 2.を実装してから他のページに推移できない状況。

3.を解決したいと思っております。

コードとしては、下記のようになります。
公式ドキュメントの内容を参考に実装しました。

PostsController

php

1public function isAuthorized($userId) { 2 // 登録済ユーザーは投稿できる 3 if ($this->action === 'add') { 4 return true; 5 } 6 7 // 投稿のオーナーは編集や削除ができる 8 $userId = $this->Auth->user('id'); 9 if (in_array($this->action, array('edit', 'delete'))) { 10 $postId = (int) $this->request->params['pass'][0]; 11 if ($this->Post->isOwnedBy($postId, $userId)) { 12 return true; 13 } 14 } 15 echo 'アクセス不可'; 16 }

Post.php

php

1 public function isOwnedBy($postId, $userId) { 2 return $this->field('id', array('id' => $postId, 'Post.user_id' => $userId)) !== false; 3}

AppController

php

1public $components = array( 2 'Session', 3 'Auth' => array('authorize' => array('Controller')) 4 ); 5 6 public function beforefilter(){ 7 parent::beforeFilter(); 8 $this->Auth->allow('index','view','login','callback','opauthComplete'); 9 }

任意で追加したtest.ctpが表示できません。
アクセス不可と表示されます。

よろしくお願い致します。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

肝心なところのソースがなさそうなのでよくわからないですが、isOwnedBy()メソッドの引数をログに出してみたら何かわかるのでは?

投稿2016/08/12 15:23

CodeLab

総合スコア1939

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

atsupoooon

2016/08/13 12:24

ありがとうございます。 $postId = (int) $this->request->params['pass'][0]; がnullになっているので、これが原因なのは、判明しましたが どのように解決すればよいか、困っています。
atsupoooon

2016/08/13 12:24

肝心なところのソースとは、どこらへんのソースになるのでしょうか?
CodeLab

2016/08/13 14:07

test.ctpを表示しているアクション(メソッド)のソースを書いてください。
CodeLab

2016/08/13 14:09

また、test.ctpを表示する際のURLはどうなっていますか?
atsupoooon

2016/08/13 15:21

コメントありがとうございます! URLはこのようになっております。 http://localhost/cakephp/posts/test test.ctpのメソッド内は現状空です。 $postId = (int) $this->request->params['pass'][0]; では、上記のURLでは取得できないことはわかりました。 なんとなく私の考えで今下記のようなことを実施してみましたが、 どうもうまくいきません。。。 パラメータなどでpostのidをtest.ctpへ渡す必要があると思っています。 しかし、パラメータでtest.ctpに 下記のようなURLにして、testc.ctpから取得はできるのですが、 isAuthorizedメソッドが関係するとわかりません。 http://localhost/cakephp/posts/test?id=2 そもそも、この考えで合っているのかも疑問です。。。
CodeLab

2016/08/14 13:26

どうも、CakePHPのURLのルールを根本的に理解されていないように見受けられますが MVCフレームワークの構造はご理解いただいていますでしょうか? まずこのあたりをご一読いただいたほうが良いかと思います。 http://book.cakephp.org/2.0/ja/getting-started/a-typical-cakephp-request.html 合わせて、ブログチュートリアルも一読いただければ、どこでどういうことが行われているかも理解できるかと思います。 http://book.cakephp.org/2.0/ja/getting-started.html ここを理解できれば、パラメータがどのようにわたってきているかが理解できるかと思います。
atsupoooon

2016/08/14 14:23

ありがとうございます。 もう一度、しっかりと読み直してみます。
atsupoooon

2016/08/15 06:05

再度、チュートリアルを読んで解決しました。 ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問