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

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

ただいまの
回答率

90.62%

  • PHP

    19892questions

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

  • JavaScript

    15980questions

    JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

  • Twitter

    643questions

    Twitterは、140文字以内の「ツイート」と呼ばれる短文を投稿できるサービスです。Twitter上のほぼ全ての機能に対応するAPIが存在し、その関連サービスが多く公開されています。

Twitter api で1つの端末やブラウザで複数のユーザーを使い分けたい

解決済

回答 3

投稿

  • 評価
  • クリップ 1
  • VIEW 835

tal

score 14

ツイッターを利用したサービスを作っています。

ここまでやったこと、
・aユーザーで、Twitter apiの認証をしてログイン
・ログインしたユーザーをデータベースに登録
・前回ログインしたユーザーのデータをセッションに保存
・bでforce_loginして他のユーザーに切り替えて認証、ログイン
・セッションに保存したユーザーデータと比較して、2個目のアカウントを保存

見た目上は、2つのアカウントが保存されている状態になっています。

この上で2点質問です。
・このアカウントをさらに複数登録する方法
・一度認証しているので、認証せずにアカウントを切り替える方法
が知りたいです。

  // twitter api から取得
  $userName = $user->name;
  $screenName = $user->screen_name;
  $urlImg = $user->profile_image_url_https;

  // 今ログインしているユーザーデータの重複が歩かないかのチェック
  $result = mysql_query("SELECT * from table WHERE screen_name = '$screenName'");

  if (isset($_SESSION["before_id"])) {

    // 前のログイン時のユーザーデータの取得
    // 前のユーザーが登録されているかチェック
    $beforeResult = mysql_query("SELECT * from table WHERE screen_name = '$id'");
  }

  if (!isset($_SESSION["before_id"]) && mysql_num_rows($result) == 0) {
    $_SESSION["before_id"] = $userid;

    // ログインしているユーザーが1に重複してなかったら挿入する
    $sql = "INSERT INTO `table`(`screen_name`, `name`, `thumb_url`) VALUES ('$screenName','$userName', '$urlImg')";
    $result = mysql_query($sql);

    // 登録情報と、前のIDがあるかどうか
  } elseif ($id && mysql_num_rows($beforeResult) != 0) {
    // 2回目以降はこちらを通るように
    // ログインしているユーザーが1に重複してなかったら挿入する
    $sql = "UPDATE `table` SET `screen_name2`='$screenName', `name2`='$userName',`thumb_url2`='$urlImg' WHERE screen_name='$id'";
    $result = mysql_query($sql);
    // echo $sql;
  }
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 3

checkベストアンサー

+2

アプリケーションの認証とユーザの認証の区別がついていないようです。
また、OAuth による権限委譲の知識も必要です。

OAuth の挙動が理解できれば、実現方法は自然と見えてくると思いますが、ざっくりと言うと以下のような実装になります。

・まずアプリケーションの認証を受けます
・その際、token を持てば、ユーザの権限の一部を触れるよう認可を受けます
・次に、ユーザの権限委譲を受けます(token 入手)
・その token を利用して、ユーザのリソースにアクセスします
・token を切り替えることで、ユーザを切り替えることが出来ます

token はアプリケーションとセットでないと意味を持たないので、DB にれて問題ないです(というか、そのための仕組みです)

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/09/19 02:01

    こちらありがとうございます。

    >token はアプリケーションとセットでないと意味を持たないので、DB にれて問題ないです(というか、そのための仕組みです)

    まさにこの流れで実装に悩んでいたので、理解できました。
    ありがとうございました。

    キャンセル

0

どのようにプログラムされているのか分かりませんが、マルチユーザに対応した Twitter 連携 Web アプリのイメージで手順を書きます。

大まかな動作としては、

(事前準備)
1.twitter Application Management (https://apps.twitter.com/)で、「Consumer Key」「Consumer secret」を取得しておく。

(Webアプリ)
1.ユーザーを選択する。
2.データベースにアカウントとアクセストークンが登録されているかチェックする。(未登録は3へ 登録済みなら6へ)
3.未登録の場合は、Twitter 認証画面を呼び出す。
(ユーザが 認証画面にログインして、承認する。)
4.認証に成功する(ユーザーから承認される)と Twitter 側から Callback で、ユーザーに対応したアクセストークンが渡される。
5.渡された情報をデータベースに保存する。
6.カスタマーキーとアクセストークンを使って、Twitter API にアクセスして、タイムライン取得や検索・投稿をします。


別の回答のコメントで聞かれたので、過去に書いたソースから探してきました。

Twitter アプリ連携して、アクセストークンの取得、投稿まわりはこんな感じでしょうか。
エラーチェック等も含めて、かなり省略していますので、適宜追加してください。

Twitter ライブラリとして、PHPでは、メジャーと思う TwitterOAuth を使っています。

login.php (Twitter ログイン&アプリ連携処理)

session_start(); 
require_once "twitteroauth.php";
$connection = new TwitterOAuth(CONSUMER_KEY, CONSUMER_SECRET);

// リクエストトークン取得(コールバックで使います)
$request_token   = $connection->getRequestToken();
$_SESSION['request_token']        = $request_token['oauth_token'];
$_SESSION['request_token_secret'] = $request_token['oauth_token_secret'];

// 認証用URLの取得
if ($connection->http_code == 200) {
   $url = $connection->getAuthorizeURL($request_token['oauth_token']);
}

// Twitter Login 画面にジャンプ
header('Location: ' . $url) ;
exit();

callback.php (アクセストークンの取得)

session_start(); 
require_once "twitteroauth.php";  

$connection = new TwitterOAuth(CONSUMER_KEY,CONSUMER_SECRET, $_SESSION["request_token"],$_SESSION["request_token_secret"]);
$access_token = $connection->getAccessToken($_GET['oauth_verifier']);

// ここにアクセストークンを保存する処理を書く。 (ここではサンプルなので、情報表示だけです。)
echo "<pre>";
var_dump($access_token);
echo "</pre>";

tweet.php (Twitter 投稿/検索)

session_start(); 
require_once "twitteroauth.php";


// ユーザーを判定して、アクセストークンを呼び出す処理を書く。 $access_token, $access_token_secret をセットする。


// アプリ連携で、取得したアクセストークンで、twitter 認証
$connection = new TwitterOAuth(CONSUMER_KEY, CONSUMER_SECRET, $access_token, $access_token_secret);

// 投稿
$statues = $connection->post("statuses/update", ["status" => "hello world!"]);

// 検索
$statuses = $connection->get("search/tweets", ["q" => "hello world!"]);

// タイムライン取得
$statuses = $connection->get('statuses/home_timeline', ['count' => '20']);

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

-1

>一度認証しているので、認証せずにアカウントを切り替える方法

ないでしょう。
それができたら簡単になりすましができてしまいませんか?

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/09/14 08:43

    グーグル等の大手企業が実装しているじょ
    複数アカウントの切り替え

    キャンセル

  • 2017/09/14 09:24 編集

    サードパーティ製のマルチユーザに対応した Hootsuite や Crowy 等のTwitter クライアント(Webアプリ)が存在していますから、問題なくできます。(というか そのような仕組みが、Twitter API に用意されています。)

    キャンセル

  • 2017/09/14 10:13

    そうなんですね
    パスワードとアカウントなしで複数アカウント切り替えられるのは知りませんでした。
    具体的にどのAPIかご教授くださいませ

    キャンセル

  • 2017/09/14 11:32 編集

    一度APIで認証して、アクセストークンを取得しておけば、次回からそのユーザでのアクセスはアクセストークンで、処理できます。認証時にアクセストークンを取得していないのあれば、毎回認証が必要ですが。

    キャンセル

  • 2017/09/14 12:26

    コメント有難うございます。非常にわかりやすく、勉強になりました。

    >次回からそのユーザでのアクセスはアクセストークンで、処理できます。
    こちらは認識しておりましたが、DBに入れるべきではないと思っておりましたが、
    その場合セッションIDで管理するべきなのでしょうか。

    >(というか そのような仕組みが、Twitter API に用意されています。)
    もしこちらあればご教授ください。

    キャンセル

  • 2017/09/14 12:50 編集

    >(というか そのような仕組みが、Twitter API に用意されています。)
    これは、APIに対して、アクセストークンを使ってアクセスするとパスワード認証がいらないという意味で書いてます。分かりにくくてすいません。

    キャンセル

  • 2017/09/19 02:01

    こちらこそ申し訳ございません。
    コメントなのでベストアンサーにできませんが、
    ご丁寧にありがとうございました。

    キャンセル

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

  • ただいまの回答率 90.62%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • PHP

    19892questions

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

  • JavaScript

    15980questions

    JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

  • Twitter

    643questions

    Twitterは、140文字以内の「ツイート」と呼ばれる短文を投稿できるサービスです。Twitter上のほぼ全ての機能に対応するAPIが存在し、その関連サービスが多く公開されています。