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

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

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

OAuth(Open Authorization)は、APIを通して保護されたリソース(サードパーティのアプリケーション)へアクセスする為のオープンプロトコルです。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

オブジェクト指向

オブジェクト指向プログラミング(Object-oriented programming;OOP)は「オブジェクト」を使用するプログラミングの概念です。オブジェクト指向プログラムは、カプセル化(情報隠蔽)とポリモーフィズム(多態性)で構成されています。

Q&A

1回答

2155閲覧

リダイレクトする処理をクラスに分けるには?

退会済みユーザー

退会済みユーザー

総合スコア0

OAuth

OAuth(Open Authorization)は、APIを通して保護されたリソース(サードパーティのアプリケーション)へアクセスする為のオープンプロトコルです。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

オブジェクト指向

オブジェクト指向プログラミング(Object-oriented programming;OOP)は「オブジェクト」を使用するプログラミングの概念です。オブジェクト指向プログラムは、カプセル化(情報隠蔽)とポリモーフィズム(多態性)で構成されています。

0グッド

1クリップ

投稿2014/12/07 04:34

oauth2.0を勉強中です。
アクセストークンを取得するために、認証ページにリダイレクトさせる必要があります。
ただ、認証部分、api利用部分などとクラスに分けようとする時に、書き方がよくわかりません。

例えば以下のように、functon内でただリダイレクトさせればいいのでしょうか?

lang

1<?php 2 3class OAuth2 { 4 function __construct() { 5 // クライアントIDとかの設定 6 } 7 8 function authorize() { 9 // 認証ページにリダイレクト 10 header('Location: xxxxx'); 11 } 12 13 // 認証ページからコールバックするページで、 14 // 付与されたトークンを取得し、設定する。 15 function setToken($token) { 16 // 交換用トークン設定 17 } 18 19 function getAccessToken() { 20 // setTokenで設定された交換用トークンを 21 // post送信し、アクセストークンを取得する。 22 } 23}

authroize()を呼んで認証ページにリダイレクトた後、認証されてコールバックページに戻ってきたページでアクセストークンと交換するトークンを取得し、setToken($token)を呼び、getAccessToken()でアクセストークンを取得という流れを考えました。

しかし、これだとコールバックされてから、交換用トークンを設定するsetToken($token)を呼ぶまでの処理が、このクラスから別の場所に移ってしまいます。
うまくクラスに認証部分をまとめるようにできないでしょうか?

わかりづらい説明かもしれませんが、よろしくお願いします。

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

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

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

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

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

guest

回答1

0

このクラスを利用する側の、こう使いたいというコード例があると良いかも。
たとえば、

lang

1//認証処理 2$oauth = new OAuth2(); 3$oauth->authorize(); 4 5//トークン取得 6$oauth = new OAuth2(); 7$oauth->setToken($_REQUEST['交換トークン名']); //これがカッコ悪い? 8$oauth->getAccessToken();

投稿2015/02/05 19:06

shinosan

総合スコア209

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問