前後にユーザー ログイン セッション ハンドラーはありますか?
管理者がバックエンドでログインするシステムを作成しました
一般の登録ユーザーがフロントエンドでログインするようにしました
フロントエンドとバックエンドで書いたセッションはすべてこのように記述され、自動ログインも作成しました。ログインしたセッションのみが存在できるということです。
if(empty($_SESSION['username']) && empty($_SESSION['uid'])){ $this->error("您还没有登陆",U("/Admin/Login/index"),3);}
その後、フロントデスクでユーザーを登録してログインしました。PHP は $_SESSION['username'] を記録し、バックエンドにログインしてバックエンドに入りました。
このように書いたことに何か問題があるのですが、解決方法を聞いてもよろしいでしょうか?
これが私の考えです: フロントエンドとバックエンドのセッション名は異なるままであるべきです。
たとえば、フロントエンドでは $_SESSION['username_index']
バックエンドでは $_SESSION['username_admin'] ですが、それでよいでしょうか?
ディスカッションに返信(解決策)
フロントエンドとバックエンドに保存されたセッション変数が矛盾しています。どうすれば自動的にログインできますか?
もう 1 つの問題は、ログイン時に、ログイン ユーザー テーブルでユーザー情報をクエリする必要があることです。
もう 1 つの問題は、ログイン時に、ログイン ユーザー テーブルでユーザー情報をクエリする必要があることです。
まず最初に言っておきますが、それは私の間違いでした、
1. フロントエンドとバックエンドのセッション名が同じであることに最初は気づきませんでした。それらを矛盾させることが正式な慣行であるかどうかを尋ねたいです。 ?
2. バックグラウンドでの自動ログインを作成しました。これは大まかに次のように書かれています: バックグラウンドでセッションを検出する限り、認証なしで直接ログインできます
あなたの状況では、判断ロジックを堂々巡りしないことをお勧めします
代わりに、思い切って追加します許可ワードの許可
フロントデスクの許可を 0 に設定します (もともと許可ワードがないため) バックグラウンドの許可は 1 です
ユーザーテーブルに許可フィールドを追加し、管理者ユーザーの許可を 1 に設定するだけです
ログインするときは、$_SESSION['permit'] のように権限を取り出してセッションに保存します
判定するときは、if($permit == ($permit & $_SESSION['permit'])) だけです
ここで、$permit はレイアウトに必要な権限です
代わりに、思い切って許可ワード Permit を追加します
フロントエンドの権限を 0 に設定します (元々は許可ワードを持っていませんでした) とバックエンド許可を 1 にします
ユーザーテーブルに許可フィールドを追加し、管理者ユーザー許可を 1 に設定するだけです
ログインするときに、許可を取り出して保存します$_SESSION['permit'] などのセッション
判定する場合は、if($permit == ($permit & $_SESSION['permit'])) で可能です
式中の$permitはレイアウトです 必要な権限です
モデレーターv5!

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック











セッションハイジャックは、次の手順で達成できます。1。セッションIDを取得します。2。セッションIDを使用します。3。セッションをアクティブに保ちます。 PHPでのセッションハイジャックを防ぐための方法には次のものが含まれます。1。セッション_regenerate_id()関数を使用して、セッションIDを再生します。2。データベースを介してストアセッションデータを3。

PHPには4つの主要なエラータイプがあります。1。notice:わずかなものは、未定義の変数へのアクセスなど、プログラムを中断しません。 2。警告:通知よりも深刻で、ファイルを含むなど、プログラムを終了しません。 3。ファタラー:最も深刻なのは、機能を呼び出すなど、プログラムを終了します。 4。ParseError:構文エラーは、エンドタグの追加を忘れるなど、プログラムの実行を防ぎます。

PHPとPythonにはそれぞれ独自の利点があり、プロジェクトの要件に従って選択します。 1.PHPは、特にWebサイトの迅速な開発とメンテナンスに適しています。 2。Pythonは、データサイエンス、機械学習、人工知能に適しており、簡潔な構文を備えており、初心者に適しています。

HTTPリクエストメソッドには、それぞれリソースを取得、送信、更新、削除するために使用されるGET、POST、PUT、および削除が含まれます。 1. GETメソッドは、リソースを取得するために使用され、読み取り操作に適しています。 2. POSTメソッドはデータの送信に使用され、新しいリソースを作成するためによく使用されます。 3. PUTメソッドは、リソースの更新に使用され、完全な更新に適しています。 4.削除メソッドは、リソースの削除に使用され、削除操作に適しています。

PHPでは、Password_hashとpassword_verify関数を使用して安全なパスワードハッシュを実装する必要があり、MD5またはSHA1を使用しないでください。 1)password_hashセキュリティを強化するために、塩値を含むハッシュを生成します。 2)password_verifyハッシュ値を比較して、パスワードを確認し、セキュリティを確保します。 3)MD5とSHA1は脆弱であり、塩の値が不足しており、最新のパスワードセキュリティには適していません。

矢印関数はPhp7.4で導入され、短い閉鎖の単純化された形式です。 1)=>演算子を使用して定義され、機能を省略し、キーワードを使用します。 2)矢印関数は、キーワードを使用せずに現在のスコープ変数を自動的にキャプチャします。 3)コールバック関数と短い計算でしばしば使用され、コードのシンプルさと読みやすさを改善します。

PHPは、電子商取引、コンテンツ管理システム、API開発で広く使用されています。 1)eコマース:ショッピングカート機能と支払い処理に使用。 2)コンテンツ管理システム:動的コンテンツの生成とユーザー管理に使用されます。 3)API開発:RESTFUL API開発とAPIセキュリティに使用されます。パフォーマンスの最適化とベストプラクティスを通じて、PHPアプリケーションの効率と保守性が向上します。

PHPは、サーバー側で広く使用されているスクリプト言語で、特にWeb開発に適しています。 1.PHPは、HTMLを埋め込み、HTTP要求と応答を処理し、さまざまなデータベースをサポートできます。 2.PHPは、ダイナミックWebコンテンツ、プロセスフォームデータ、アクセスデータベースなどを生成するために使用され、強力なコミュニティサポートとオープンソースリソースを備えています。 3。PHPは解釈された言語であり、実行プロセスには語彙分析、文法分析、編集、実行が含まれます。 4.PHPは、ユーザー登録システムなどの高度なアプリケーションについてMySQLと組み合わせることができます。 5。PHPをデバッグするときは、error_reporting()やvar_dump()などの関数を使用できます。 6. PHPコードを最適化して、キャッシュメカニズムを使用し、データベースクエリを最適化し、組み込み関数を使用します。 7
