現在の要件は、QQ などのコミュニケーション ツールに使用されるアプリでは、以前にログインした場合はブロックされています。これを実装する方法がわかりません。 ?
返信内容:
現在の要件は、QQ などのコミュニケーション ツールに使用されるアプリでは、以前にログインした場合はブロックされています。これを実装する方法がわかりません。 ?
アプリが配置されているデバイス情報を収集し、そのデバイス情報をユーザーにバインドします。1 人のユーザーが 1 つのデバイスでそのアプリを使用することが許可され、前のデバイスのユーザーはログイン時にキックオフされます。
過去 6 か月間、私たちはシングル サインオン システム (TnSSO) を設計し、実装してきました。これは非常に一般的なシステムですが、機能と経験について多くの詳細な調査を行いました。まとめと記録。以下では、SSO ともこのシステムを指します。
TnSSO は、PC 版とモバイル版で複数のログイン方法を提供します。ログインには通常のメール アカウントまたは携帯電話番号、Sina、QQ などのアカウントを使用した共同ログイン、および携帯電話の動的パスワード ログインがあります。また、プラットフォームごとに異なるログイン方法も用意されており、ユーザーエクスペリエンスを向上させるためにいくつかの特別なログイン方法が提供されています。たとえば、WeChat で会社の共有リンクを開くと、PC ページでは WeChat 認証を使用して直接ログインできます。ログインするためのQRコード。
現在のモバイル アプリ ページの多くは、通常のモバイル Web ページをアプリに直接埋め込んでいます。言うまでもなく、これには利点があります。アプリのネイティブ ページを介してログインするエクスペリエンスは、アプリで Web ページを開いてログインするよりも優れているため、アプリへのログインには引き続きネイティブ ページを使用します。 TnSSO はアプリのネイティブ ログイン方法と互換性があり、アプリ内のユーザーのログイン ステータスを識別できます。さらに、アプリを使用して QR コードをスキャンし、PC 版の SSO にログインすることもできます。
以下は、シングル サインオンのシーケンス図です。詳細については説明しません。これまでに使用したことのない人は、図を見れば何が起こっているかを理解できるはずです。
TnSSO は、システムのセキュリティを確保することを前提として、セキュリティとエクスペリエンスに関して非常に詳細な考慮事項を備えており、ユーザー エクスペリエンスを最大限に最適化します。
1. クライアントとサーバー間の通信が盗聴されるのを防ぐために、プロセス全体が HTTPS です。
2. コールバック URL とホワイトリストを設定する。SSO にアクセスするには、まずクライアント サブシステムを SSO に登録する必要があります。
3. トークンは 1 回だけ有効で、クライアント サブシステムにバインドされ、使用後すぐに破棄されます。
4. ユーザー エクスペリエンスを向上させるため、ユーザーは IP ごとに 1 日あたり最初の 3 回のログイン、または携帯電話番号ごとに 1 日に初めて動的パスワードが送信されるときに確認コードを入力する必要がありません。
5. 確認コードは携帯電話の動的パスワードに 3 回以上送信されると無効になります。
6. 待ってください...
アプリユーザーのログイン情報はアプリ内に別途保存され、SSOが提供するパブリックログインサービスは利用しません。では、ユーザーがアプリを通じて埋め込み Web ページにアクセスするとき、Web ページはどのようにしてユーザーのログイン ステータスを認識し、埋め込み Web ページとアプリのログイン ステータスをどのように共有できるのでしょうか?
セキュリティ上の理由から、アプリはユーザー ID を直接設定するのではなく、Cookie にハッシュ値を設定します。SSO 独自のインターフェース調整を通じてアプリサーバーから取得したユーザー ID のみが正当性を保証し、信頼できます。
タイミング図は次のとおりです:
QR コードをスキャンしてログインする
QR コードをスキャンしてログインすることは、現在、携帯電話やその他のモバイル デバイスでログインしている場合に非常に一般的であり、これを使用して PC 版ログインのショートカットを提供することができます。ユーザーは、ユーザー自身が覚えていない可能性のある長くて複雑なパスワードを入力する必要がなく、シンプルで高速です。したがって、このログイン方法も、まだ正式にはリリースされていませんが、すでに計画され、設計されているものです。
具体的な実装方法は、まず SSO サーバーが競合しないコードをランダムに生成してデータベースに保存し、それを QR コード画像に描画して PC 版ログイン ページに表示します。ページは Javascript ショート ポーリングを使用してクエリを実行します。このコードのサーバーのログイン情報。アプリは、内蔵のコードスキャン機能を使用して画像内のコードを識別し、コードと上記のユーザーログイン情報のハッシュ値をパラメータとして使用して、アプリサーバーを介してSSOインターフェースをリクエストします。 SSO はリクエストを受信すると、まずデータベースにコードが存在するかどうかを判断し、存在する場合は正当なリクエストであることを示し、ハッシュ値を使用してユーザー ID を取得するようにアプリ サーバーに要求します。前述のアプリログインとの接続と同様です。 JS は、ユーザーがログインしていることをポーリングして確認し、ページを更新するか、元のページに戻ります。
最後に、TnSSO は、実際には統合ログイン サービスを提供するだけでなく、ユーザー登録、パスワード検索などの機能も統合しているため、パス システムと呼ぶのが適切であり、安定性とセキュリティの要件が最も高いシステムです。会社。
http://atlantisplus.net/articles/570.html
上の階で行われた多くのことを見ると、ログインに成功するとタイムスタンプが記録され、ログイン時にそのタイムスタンプに基づいて Cookie が解析され、タイムスタンプと比較されるようです。実際には、これはトークンを取得するだけであり、ログインに成功するたびにこのトークンを更新するだけです
1 つは、uid とデバイスをバインドする上記のようなもので、各操作で uid が現在のデバイスと一致するかどうかを検出します。
シングル サインイン関数とコールバック処理を提供する Huanxin などのサードパーティもあります。自分で長いリンクを作成する必要はありません。

PHPは、特にWeb開発の分野で、最新のプログラミングで強力で広く使用されているツールのままです。 1)PHPは使いやすく、データベースとシームレスに統合されており、多くの開発者にとって最初の選択肢です。 2)動的コンテンツ生成とオブジェクト指向プログラミングをサポートし、Webサイトを迅速に作成および保守するのに適しています。 3)PHPのパフォーマンスは、データベースクエリをキャッシュおよび最適化することで改善でき、その広範なコミュニティと豊富なエコシステムにより、今日のテクノロジースタックでは依然として重要になります。

PHPでは、弱い参照クラスを通じて弱い参照が実装され、ガベージコレクターがオブジェクトの回収を妨げません。弱い参照は、キャッシュシステムやイベントリスナーなどのシナリオに適しています。オブジェクトの生存を保証することはできず、ごみ収集が遅れる可能性があることに注意する必要があります。

\ _ \ _ Invokeメソッドを使用すると、オブジェクトを関数のように呼び出すことができます。 1。オブジェクトを呼び出すことができるように\ _ \ _呼び出しメソッドを定義します。 2。$ obj(...)構文を使用すると、PHPは\ _ \ _ Invokeメソッドを実行します。 3。ロギングや計算機、コードの柔軟性の向上、読みやすさなどのシナリオに適しています。

繊維はPhp8.1で導入され、同時処理機能が改善されました。 1)繊維は、コルーチンと同様の軽量の並行性モデルです。 2)開発者がタスクの実行フローを手動で制御できるようにし、I/O集約型タスクの処理に適しています。 3)繊維を使用すると、より効率的で応答性の高いコードを書き込むことができます。

PHPコミュニティは、開発者の成長を支援するための豊富なリソースとサポートを提供します。 1)リソースには、公式のドキュメント、チュートリアル、ブログ、LaravelやSymfonyなどのオープンソースプロジェクトが含まれます。 2)StackOverFlow、Reddit、およびSlackチャネルを通じてサポートを取得できます。 3)開発動向は、RFCに従うことで学ぶことができます。 4)コミュニティへの統合は、積極的な参加、コード共有への貢献、および学習共有への貢献を通じて達成できます。

PHP and Python each have their own advantages, and the choice should be based on project requirements. 1.PHPは、シンプルな構文と高い実行効率を備えたWeb開発に適しています。 2。Pythonは、簡潔な構文とリッチライブラリを備えたデータサイエンスと機械学習に適しています。

PHPは死にかけていませんが、常に適応して進化しています。 1)PHPは、1994年以来、新しいテクノロジーの傾向に適応するために複数のバージョンの反復を受けています。 2)現在、電子商取引、コンテンツ管理システム、その他の分野で広く使用されています。 3)PHP8は、パフォーマンスと近代化を改善するために、JITコンパイラおよびその他の機能を導入します。 4)Opcacheを使用してPSR-12標準に従って、パフォーマンスとコードの品質を最適化します。

PHPの将来は、新しいテクノロジーの傾向に適応し、革新的な機能を導入することで達成されます。1)クラウドコンピューティング、コンテナ化、マイクロサービスアーキテクチャに適応し、DockerとKubernetesをサポートします。 2)パフォーマンスとデータ処理の効率を改善するために、JITコンパイラと列挙タイプを導入します。 3)パフォーマンスを継続的に最適化し、ベストプラクティスを促進します。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

WebStorm Mac版
便利なJavaScript開発ツール

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境
