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

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

新規登録して質問してみよう
ただいま回答率
85.48%
排他制御

排他制御とは、特定のファイル・データへのアクセスや更新を制御することです。特にファイルやデータベースへ書き込みを行う際、データの整合性を保つため別のプログラムによる書き込みを一時的に制御することを指します。

Internet Explorer

Internet Explorer(IE;MSIE)はマイクロソフトが開発したウェブブラウザです。Microsoft Windowsに組み込まれています。

PHP

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

ウェブアプリケーション

ウェブアプリケーションとは、ウェブ上でアクセスされるアプリケーションのことを呼びます。この場合におけるウェブとは、インターネットやイントラネット上を意味します。

Q&A

解決済

4回答

1763閲覧

WEBアプリの排他制御について(ブラウザ閉じるボタンで閉じられることを考慮)

xxhiroxx_chan

総合スコア41

排他制御

排他制御とは、特定のファイル・データへのアクセスや更新を制御することです。特にファイルやデータベースへ書き込みを行う際、データの整合性を保つため別のプログラムによる書き込みを一時的に制御することを指します。

Internet Explorer

Internet Explorer(IE;MSIE)はマイクロソフトが開発したウェブブラウザです。Microsoft Windowsに組み込まれています。

PHP

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

ウェブアプリケーション

ウェブアプリケーションとは、ウェブ上でアクセスされるアプリケーションのことを呼びます。この場合におけるウェブとは、インターネットやイントラネット上を意味します。

0グッド

0クリップ

投稿2022/07/14 09:45

IE11で使用するWEBアプリの排他制御について教えてください。
具体的には、ブラウザの閉じるボタンを押したときの制御です。

環境)
ブラウザ:Internet Explorer 11(インターネットに接続されていない閉鎖系ネットワーク内)
WEBアプリ:php5.6で開発

Aさんが、登録画面(例:電話対応内容)を開いたときに、
DB上の排他テーブルにレコードを作成し、
画面上の「閉じる」ボタンまたは「保存」ボタンを押下したときに、
上記のレコードを削除するという実装をしています。
これにより、Aさんが編集している間、それ以外の人は参照のみとしています。

私の知る限り、ブラウザの閉じるボタンを押したときに、
上記の「閉じる」ボタンまたは「保存」ボタンを押下したときのような
制御をおこなうことができません。
つまり、排他テーブルのレコードは残ったままで、意図せず、他の人が編集できない状態が続きます。

上記の点を解決するような、または全く別の方法でもよいですが、
WEBツールにおいてアプリケーションレベルで排他制御をおこなう設計を教えてください。

よろしくお願いいたします。

気になる質問をクリップする

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答4

0

閉じるボタンを押す、のだけではなくて、いきなり停電することも考えられる(掃除のおばちゃんインシデント)ため、そこらへんの手当も考えないといけないですね
やっぱり定期的に死活通信しといて、それが途絶えたらどーこーという感じでしょうね

投稿2022/07/14 10:42

y_waiwai

総合スコア87774

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ベストアンサー

手元にIEが無いので試していませんが、beforeunload イベントで似たようなことができそうな気がします。
beforeunload 以外は、定期的に「開いている」という情報をサーバに送り、それがこなくなったら処理とかでしょうか。

【Window: beforeunload イベント - Web API | MDN】
https://developer.mozilla.org/ja/docs/Web/API/Window/beforeunload_event

【onunload時にPOSTしたい時。 - Qiita】
https://qiita.com/xxxkurosukexxx/items/d5cf85ecedef4ed7c9bd

投稿2022/07/14 10:06

kei344

総合スコア69407

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

多くの回答をいただき本当にありがとうございました。
どの回答も参考となったのですが、最終的に、
Window: beforeunload イベント内で、「ajax」で、排他を解除するロジックに処理を渡す設計としました。
ポイントとしては、async: false(同期通信)としたことです。
これが、async: true(非同期通信)とすると、排他を解除する処理が行われる前にブラウザが閉じるようで、排他解除ができません。

なお、この方法はIE11を使う際のもので、現在使われているブラウザでは、
Navigator.sendBeacon
を使えばよいようです。
https://developer.mozilla.org/ja/docs/Web/API/Navigator/sendBeacon

また、複数の方に回答いただいたように、根本的には、ブラウザからサーバに向かって定期的に「開いている」か確認する、という方法があるということが分かったのは大きな収穫でした。
今回はアプリケーションの利用者頻度や場所が限定されるため、ブラウザの異常終了などの際は、手動で排他を解除することとし、この方法は使いませんでした。

ありがとうございました。

投稿2022/07/15 09:10

xxhiroxx_chan

総合スコア41

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

Windowsのリモートデスクトップの様な仕組みが良いと思います。
Aさんの排他が有効な時に、Bさんがログインする際、Aさんがログイン中(いつまで処理していたか)である旨を画面表示します。Bさんがログインした場合、Aさんのセッションを無効にします。

投稿2022/07/15 02:29

AndoJun

総合スコア41

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問