ホームページ バックエンド開発 PHPチュートリアル Curl は、OAuth 承認ユーザー センターへのログインをシミュレートして、その下の各サブサイトにログインする方法を教えてください。

Curl は、OAuth 承認ユーザー センターへのログインをシミュレートして、その下の各サブサイトにログインする方法を教えてください。

Dec 01, 2016 am 12:56 AM
curl java php ssl

問題の概要:
PHP CURL を介して http://www.aaa.com などの Web サイトへのログインをシミュレートし、フィドラーを介してパケットをキャプチャし、次のように分析します。
1. フォームを http に送信します。 //POST モードの www.aaa.com /dologin、ここでトークンが生成されます: xxx,
2. サーバーは、ログインするためにこのトークンを使用して次のアドレスにジャンプします:
https://account.usercenter.com/login?token=xxx&target_url=http://www.aaa.com (ドメイン名が異なることに注意してください)また、トークンが含まれる URL を任意のコンピュータにコピーします。正常にログインできますが、ログインに成功すると無効になります)
3. ログインに成功すると、アドレスは target_url: http:// にリダイレクトされます。 www.aaa.com

問題分析:私の理解: 認証サーバーが存在し、有効なトークンを保持する URL にアクセスします。このトークンは PC とサーバー間の Cookie によって維持されます。

質問する:

PHP CURL を使用してこのログイン シミュレーションを実装するにはどうすればよいですか?
私のコードは次のとおりです:

リーリー

この種のログインは Cookie を通じて実現できるのでしょうか?親愛なる英雄の皆さん、アドバイスをお願いします~~

返信内容:

問題の概要:

PHP CURL を介して http://www.aaa.com などの Web サイトへのログインをシミュレートし、フィドラーを介してパケットをキャプチャし、次のように分析します。 1. フォームを http に送信します。 //POST モードの www.aaa.com /dologin、ここでトークンが生成されます: xxx,
2. サーバーは、ログインするためにこのトークンを使用して次のアドレスにジャンプします:

(ドメイン名が異なることに注意してください)また、トークンが含まれる URL を任意のコンピュータにコピーします。正常にログインできますが、ログインに成功すると無効になります)
3. ログインに成功すると、アドレスは target_url: http:// にリダイレクトされます。 www.aaa.comhttps://account.usercenter.com/login?token=xxx&target_url=http://www.aaa.com

問題分析:

私の理解: 認証サーバーが存在し、有効なトークンを保持する URL にアクセスします。このトークンは PC とサーバー間の Cookie によって維持されます。 質問する:

PHP CURL を使用してこのログイン シミュレーションを実装するにはどうすればよいですか?

私のコードは次のとおりです: リーリー
この種のログインは Cookie を通じて実現できるのでしょうか?親愛なる英雄の皆さん、アドバイスをお願いします~~

前のコードでCookieを運ぶ方法を何度もデバッグしましたが、Cookieファイルとうまく関連付けられたことがないようです。Cookieを運ぶコードの書き方がわかりません。しかし、さらにデバッグを行った結果、http://www.aaa.com/dologin を呼び出した後、この URL は、他のサブサーバーにログインするための単なる sso であることがわかりました。 -サイト。

ご回答ありがとうございます~~

もちろん達成可能です、あなたの理解は正しいです。一意のトークンは Cookie に保存され、ログインに成功すると、そのトークンは送信されるたびに保持される必要があります。

プロセスによれば、それは正しいはずです

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

作曲家:AIを介したPHP開発の援助 作曲家:AIを介したPHP開発の援助 Apr 29, 2025 am 12:27 AM

AIは、作曲家の使用を最適化するのに役立ちます。特定の方法には次のものが含まれます。1。依存関係管理の最適化:AIは依存関係を分析し、最適なバージョンの組み合わせを推奨し、競合を減らします。 2。自動コード生成:AIは、ベストプラクティスに準拠したComposer.jsonファイルを生成します。 3.コードの品質を改善する:AIは潜在的な問題を検出し、最適化の提案を提供し、コードの品質を向上させます。これらの方法は、開発者が効率とコードの品質を向上させるのに役立つ機械学習および自然言語処理技術を通じて実装されています。

session_start()関数の重要性は何ですか? session_start()関数の重要性は何ですか? May 03, 2025 am 12:18 AM

session_start()iscrucialinphpformangingusersions.1)itInitiateSanewsessionifnoneExists、2)resumesanexistingsession、および3)SetSessionCookieforcontinuityAcrossRequests、ApplicationslicationSliviseSlikeUserauthicationAnticatent。

データ処理と計算にMySQL関数を使用する方法 データ処理と計算にMySQL関数を使用する方法 Apr 29, 2025 pm 04:21 PM

MySQL関数は、データ処理と計算に使用できます。 1.基本的な使用には、文字列処理、日付計算、数学操作が含まれます。 2。高度な使用法には、複数の関数を組み合わせて複雑な操作を実装することが含まれます。 3.パフォーマンスの最適化では、Where句での機能の使用を回避し、GroupByおよび一時テーブルを使用する必要があります。

作曲家:PHP開発者のパッケージマネージャー 作曲家:PHP開発者のパッケージマネージャー May 02, 2025 am 12:23 AM

Composerは、PHPの依存関係管理ツールであり、Composer.jsonファイルを介してプロジェクトの依存関係を管理しています。 1)依存関係情報を取得するためのComposer.jsonを解析する。 2)依存関係を解析して、依存性ツリーを形成します。 3)PackagistからVendorディレクトリへの依存関係をダウンロードしてインストールします。 4)Composer.Lockファイルを生成して、依存関係バージョンをロックして、チームの一貫性とプロジェクトの保守性を確保します。

cでタイプの特性を使用する方法は? cでタイプの特性を使用する方法は? Apr 28, 2025 pm 08:18 PM

Typetraitsは、Cでコンパイル時間タイプのチェックと操作に使用され、コードの柔軟性とタイプの安全性が向上します。 1)タイプの判断は、STD :: iS_integralおよびstd :: is_floating_pointを介して実行され、効率的なタイプチェックと出力を達成します。 2)std :: is_triviely_copyableを使用して、ベクトルコピーを最適化し、タイプに従って異なるコピー戦略を選択します。 3)コンパイル時間の意思決定、タイプの安全性、パフォーマンスの最適化、コードの複雑さに注意してください。タイプトライトの合理的な使用は、コードの品質を大幅に改善できます。

mysqlの文字セットと照合ルールを構成する方法 mysqlの文字セットと照合ルールを構成する方法 Apr 29, 2025 pm 04:06 PM

MySQLで文字セットと照合を構成する方法は次のとおりです。1。サーバーレベルでの文字セットとコレクションの設定:setNames'utf8 '; setCharacterSetutf8; setCollat​​ion_connection = 'utf8_general_ci'; 2。特定の文字セットと照合を使用するデータベースを作成します:createdatabaseexample_dbcharactersetutf8collat​​eutf8_general_ci; 3.テーブルを作成するときに文字セットとコレクションを指定:createTableExample_table(idint

MySQLのデータベースの名前を変更する方法 MySQLのデータベースの名前を変更する方法 Apr 29, 2025 pm 04:00 PM

MySQLでデータベースを変更するには、間接的な方法が必要です。手順は次のとおりです。1。新しいデータベースを作成します。 2。mysqldumpを使用して、古いデータベースをエクスポートします。 3.データを新しいデータベースにインポートします。 4.古いデータベースを削除します。

CにSingletonパターンを実装する方法は? CにSingletonパターンを実装する方法は? Apr 28, 2025 pm 10:03 PM

CにSingletonパターンを実装すると、静的メンバー変数と静的メンバー関数を介してクラスのインスタンスが1つしかないことを保証できます。特定の手順には次のものが含まれます。1。プライベートコンストラクターを使用し、コピーコンストラクターと課題演算子を削除して、外部の直接インスタンス化を防ぎます。 2.静的メソッドGetInstanceを介してグローバルアクセスポイントを提供して、1つのインスタンスのみが作成されるようにします。 3。スレッドの安全性のために、再チェックロックモードを使用できます。 4。メモリの漏れを避けるために、STD :: shared_ptrなどのスマートポインターを使用します。 5。高性能要件については、静的なローカル変数を実装できます。シングルトンのパターンはグローバルな国家の乱用につながる可能性があることに注意する必要があり、それを慎重に使用して代替案を考慮することをお勧めします。

See all articles