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

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

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

HTTPにおけるCookieとは、クライアントのウェブブラウザ上に保存された一時的なデータを指します。クライアント側のJavaScriptでも、サーバー側のHTTPヘッダーでもクッキーの読み書き・修正・削除が可能です。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

servlet

Servletとは、Webページの動的な生成やデータ処理などをサーバ上で実行するために、Javaで作成されたプログラムです。 ショッピングサイトやオンラインバンキングといった、動的なウェブサイトの構築に用いられています。

Tomcat

TomcatはApache Software Foundation (ASF)で開発されたオープンソースのWebコンテナです。

Q&A

解決済

2回答

5566閲覧

servlet でクッキーが勝手に消される現象?に困っています

anonymous001

総合スコア96

Cookie

HTTPにおけるCookieとは、クライアントのウェブブラウザ上に保存された一時的なデータを指します。クライアント側のJavaScriptでも、サーバー側のHTTPヘッダーでもクッキーの読み書き・修正・削除が可能です。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

servlet

Servletとは、Webページの動的な生成やデータ処理などをサーバ上で実行するために、Javaで作成されたプログラムです。 ショッピングサイトやオンラインバンキングといった、動的なウェブサイトの構築に用いられています。

Tomcat

TomcatはApache Software Foundation (ASF)で開発されたオープンソースのWebコンテナです。

0グッド

0クリップ

投稿2015/01/17 08:17

tomcat7系
java7で開発しております。
ログイン処理の際に次回から自動ログインをする際にこのようにクッキーにログイン情報を載せるようにしています(セキュリティ的にアンチパターンという回答は今回はなしでおねがいします)

lang

1Cookie[] cookies = request.getCookies(); 2 String user = null; 3 String auth = null; 4 5 if (cookies != null) { 6 for (int i = 0; i < cookies.length; i++) { 7 if ("user".equals(cookies[i].getName())) { 8 user = cookies[i].getValue(); 9 } 10 if ("auth".equals(cookies[i].getName())) { 11 auth = cookies[i].getValue(); 12 } 13 } 14 }

このようなコードを/login等でURI設定したservlet内に書いております。
これによりクッキーがあるときは自動ログインが可能になったのですが、

そのユーザーの登録情報を変更するURIが別にあり(仮に/change)、そのURIを
スマホのアプリで叩くと
PC上でログインしていたサイトをリロードすると、クッキー情報が消され?再度ログインが求められます。
/change ないのservletにはcookieを扱うような処理をしていなく、不思議に思っています。
どのへんを分析したらいいのか等教えていただけたら幸いです!

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

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

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

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

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

guest

回答2

0

どのようにCookieが作られているかどうかが分かりませんので、一般的な回答しかできませんが...

  1. Cookieの有効期限はどうなっていますか。
  2. Servlet側ではなく、JavaScriptでCookieの操作をしているところはありませんか。
  3. Webブラウザーの開発者ツール(デベロッパーツール)を使って、Cookieの通信をトレースして、どこでCookieの情報が消えるのか、確認してみてください。

投稿2015/01/17 13:19

argius

総合スコア9388

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

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

anonymous001

2015/01/17 14:00

Cookieの期限は30日になっています。JavascriptでCookieを操作しているような箇所はありません。Cookieをディベロッパーツール等で監視すると、ログイン時にCookieが付与されているのが確認取れます。そこでスマホから/change URIをたたいて、PCブラウザ側で更新するとなくなっております。ですのでCookieの遷移は測れないのです。サーバーのSessionが切れるとなにか不具合がでるとかですかね。Sessionを取得するようなプログラムは書いていないんですが、それがCookieに影響があるとか。。。ちなみにCookieは/のみで登録しております
argius

2015/01/17 14:27

基本的なところは問題なさそうですね。 CookieはServletとのセッションとは関係なく使えるものなので、サーバー側の制御だけで他の端末のCookieが消えるというのは意図的に消しているのでなければ考えにくいですね。 あとはWebサーバー側の設定とか、プロキシーサーバーの有無あたりですかね。
anonymous001

2015/01/17 14:37

サーバーはtomcatとapatchを使用しております。Webサーバー側の設定とか、プロキシーサーバーはどのへんを確認したらよろしいでしょうか?プロキシーサーバーの設定はたぶんしていません><
argius

2015/01/17 14:47

Apacheの設定はhttp://httpd.apache.org/docs/2.2/ja/configuring.htmlなどでCookie関連の項目を探してみてください。 プロキシーサーバーは、直接ブラウザーに設定している場合は、「設定」→「ネットワーク」辺りで設定します。
anonymous001

2015/01/18 05:15

Cookieは消されていませんでした。DBちぇっくのところでなぜかFalseをかえしているようですね。。
guest

0

自己解決

Cause: com.mysql.jdbc.exceptions.jdbc4.CommunicationsException
このようなエラーが出ていたことが問題でした。質問のような現象は起きてないようです。ありがとうございました!

投稿2015/01/19 15:50

anonymous001

総合スコア96

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問