イントラネットシステムでは、注文番号を送信する際に重複防止判定を行いますが、同じ注文番号が二度送信されるのではなく、一度だけ送信されます。
イントラネット システム、
サーバーサイド PHP+MYSQL
データ テーブルのフィールドの値は、書き込み時に PHP で判断されます。 通常、同じ注文番号でデータを繰り返し挿入することはできないというメッセージが表示されますが、操作時に明らかに 1 回のみ送信する場合があります。しかし、データはまったく同じであり、2 つの部分が同時に同じ秒に書き込まれていることがわかりました。
あのヒーローは何が起こっているか知っています。
ディスカッションに返信 (解決策)
送信を 2 回連続してクリックしたと推定されます
現在、この状況に対してフロントエンドとバックエンドの 2 つの制限があります
フロントエンドが送信ボタンをクリックすると、最初に送信ボタンが灰色になり、クリックできなくなり、結果を返した後、プログラムのロジックがジャンプまたは復元されます
バックグラウンドで挿入する前に、最初にボタンがあるかどうかを判断します。すでにこのデータ (繰り返しできない 1 つまたは複数のフィールドに基づいて判断します) そうでない場合は、それを挿入します
まあ、フォーム送信の場合は、クリックした後、js を使用してボタンを無効にすることもできます。最初に js を使用して送信します
私は一度だけクリックしましたが、この機会は毎月 1 回または 2 回発生します。まず、現在の注文番号が存在するかどうかを確認します。データベースに書き込むジョブを実行できます。それで何が起こったのか混乱しています。 。 。
それはあなたが書くコードに依存し、ソースから問題を解決します。
2 番目の同時実行の問題。
たとえば、
AB に同時に到着する A と B の 2 つのリクエストがあり、両方のリクエストがその位置を繰り返すかどうかの判断を通過します。その後、A が挿入されると、それに応じて B が挿入されます。
繰り返し挿入を避けるために、このように書くことができます。
たとえば、テスト テーブルには名前と値の 2 つのフィールドがあります
INSERT INTO test(name, value) SELECT 'fdipzone', '123' FROM DUAL WHERE 'fdipzone' NOT IN (SELECT name FROM test);
イントラネット システムであるため、同時実行の量は決して高くはなく、複数のユーザーが同時にボタンをクリックする確率は均等ですより低い。
繰り返しの送信を防ぐためにフロントエンドで適切な作業を行い、バックグラウンドで送信を検証するだけにしてください。
2 番目の同時実行の問題。
たとえば、
AB に同時に到着した 2 つのリクエスト A と B があり、どちらもその位置を繰り返すかどうかの判断を通過しました。その後、A が挿入されると、それに応じて B が挿入されます。
繰り返し挿入を避けるために、このように書くことができます。
たとえば、テストテーブルには名前、値の 2 つのフィールドがあります
INSERT INTO test(name, value) SELECT 'fdipzone', '123' FROM DUAL WHERE 'fdipzone' NOT IN (SELECT name FROM test);
あなたの書き方が賢明だと思います、そして、insert ステートメントで別の判断をすることができます。
複数のユーザーが同時に同じコンテンツを投稿する確率は非常に低いですが、投稿者は「時々」しか起こりません
プログラムの問題はさておき、この状況は 10 年前にはよく起こりました。その理由は、ブラウザのアップグレードされたバージョンが不安定で、1 つのリクエストでデータが 2 回送信されるためです。もちろん、これは修正されています。ただし、懐かしい人がそれを使用することに固執すると、問題が発生するのが普通です
別の状況としては、フォームがこのページに送信されていないか、この時点でユーザーのマウスが疲れすぎている場合です。をクリックすると、シングルクリックがダブルクリックになります。これにより、二次投稿も可能です
こういった人為的失敗を防ぐため、受信時に判断していただくことも可能です
session_start();if(isset($_SESSION['post']) && $_SESSION['post'] == md5(serialize($_POST))) return;$_SESSION['post'] = md5(serialize($_POST));//正常的提交处理

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

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

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

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

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

ホットトピック











多くの場合、キーワードと追跡パラメーターで散らかった長いURLは、訪問者を阻止できます。 URL短縮スクリプトはソリューションを提供し、ソーシャルメディアやその他のプラットフォームに最適な簡潔なリンクを作成します。 これらのスクリプトは、個々のWebサイトにとって価値があります

2012年のFacebookによる有名な買収に続いて、Instagramはサードパーティの使用のために2セットのAPIを採用しました。これらはInstagramグラフAPIとInstagram Basic Display APIです。

Laravelは、直感的なフラッシュメソッドを使用して、一時的なセッションデータの処理を簡素化します。これは、アプリケーション内に簡単なメッセージ、アラート、または通知を表示するのに最適です。 データは、デフォルトで次の要求のためにのみ持続します。 $リクエスト -

これは、LaravelバックエンドとのReactアプリケーションの構築に関するシリーズの2番目と最終部分です。シリーズの最初の部分では、基本的な製品上場アプリケーションのためにLaravelを使用してRESTFUL APIを作成しました。このチュートリアルでは、開発者になります

Laravelは簡潔なHTTP応答シミュレーション構文を提供し、HTTP相互作用テストを簡素化します。このアプローチは、テストシミュレーションをより直感的にしながら、コード冗長性を大幅に削減します。 基本的な実装は、さまざまな応答タイプのショートカットを提供します。 Illuminate \ support \ facades \ httpを使用します。 http :: fake([[ 'google.com' => 'hello world'、 'github.com' => ['foo' => 'bar']、 'forge.laravel.com' =>

PHPクライアントURL(CURL)拡張機能は、開発者にとって強力なツールであり、リモートサーバーやREST APIとのシームレスな対話を可能にします。尊敬されるマルチプロトコルファイル転送ライブラリであるLibcurlを活用することにより、PHP Curlは効率的なexecuを促進します

顧客の最も差し迫った問題にリアルタイムでインスタントソリューションを提供したいですか? ライブチャットを使用すると、顧客とのリアルタイムな会話を行い、すぐに問題を解決できます。それはあなたがあなたのカスタムにより速いサービスを提供することを可能にします

2025 PHP Landscape Surveyは、現在のPHP開発動向を調査しています。 開発者や企業に洞察を提供することを目的とした、フレームワークの使用、展開方法、および課題を調査します。 この調査では、現代のPHP Versioの成長が予想されています
