以下のエディターでは、SpringMVC でのセッションの使用法と詳細なレコードについて簡単に説明します。編集者はこれがとても良いものだと思ったので、皆さんの参考として今から共有します。編集者をフォローして一緒に見てみましょう
前書き
最近、会社用に構築したシステムにログインするためにセッションを使用する必要があります。
インターネット上で多くの情報を見つけ、セッションを保存する方法を大まかに 2 つ挙げました:
1. javaWeb プロジェクトに共通の HttpSession
2. 私は個人的にはもっとお金を払っています。 @SessionAttributes の使用法に注意してください。結局のところ、私たちは現在 SpringMVC を使用しています。しかし、ネット上の記事を読んでも基本的な使い方しか解説されておらず、詳しい使い方や詳細は基本的に書かれていないので、これでは物足りないと思い、自分でいくつかテストしてコードをコンパイルして作成しました。デモを録音して共有してください。欠点がある場合は、遠慮なく話し合ってください。
さて、くだらない話はこれくらいにして、これから本当のショーが始まります!
結論 さて、コードを読むのが嫌いな一部のお客様が結論を読む手間を省くために、テスト後の結論をここにリストします。
1. SpringMVC の独自の ModelMap と Model を使用してコントローラーにデータを自動的に保存することも、従来の HttpSession やその他のパラメーターを使用してセッション データを保存することもできます2. セッション データの保存には @SessionAttributes アノテーションを使用する必要があります。このアノテーションはパラメータを宣言する方法 (値と型) が 2 つあり、アノテーションの宣言はメソッドではなくクラスに記述する必要があります
3。宣言されていない SessionAttributes アノテーション パラメータをセッションに保存できません
4. SessionStatus を使用して、セッションに保存されているデータをすべて削除します。指定されたセッション データは個別に削除できないことに注意してください。同時に、クリア時の有効な権限は、上記の 2 番目と 3 番目のルールに従います (このルールは、指定されたセッション データを削除する効果を人為的に実現するために使用できます)
5. ModelMap などを通じてセッション内のデータを読み取るとき。 .
6. ModelMap または Model を使用してセッション データを保存する場合、ModelMap をメソッド パラメーターとして渡す必要があり、メソッド内で新しく定義されたものは無効です。同時に、ModelMap がパラメーターとして渡されている限り、他のメソッドによって呼び出されても機能します
7。 @ResponseBody アノテーション (通常は ajax で使用されます) を使用する場合、セッション データは保存できません
8、@ SessionAttributes アノテーションは、値と型の 2 つのパラメータ リストを使用できます
9。HttpSession を使用する従来の方法には、上記のアノテーションと権限の制限がありません。以下に簡単なテストがあります。 、しかし、具体的な説明はありません
以下にさらにいくつかあります 常識的な知識ポイントと考えるべきです
10. 11. 同じセッション値を操作すると、後の値が前の値を上書きします
テストコードと簡単な手順
開発ツール: Spring Tool Suite。SpringはEclipse
をベースにMavenとTomcatを統合したIDE開発ツールを最近開発しました。まず、プロジェクト構造のスクリーンショットを撮りましょう
ajaxの@ResponseBodyアノテーションは後続のテストで使用されるため、jarパッケージをpom.xmlファイルで構成する必要があります。<!-- 使用@ResponseBody注解所需的2个包 --> <dependency> <groupId>org.codehaus.jackson</groupId> <artifactId>jackson-core-asl</artifactId> <version>1.9.13</version> </dependency> <dependency> <groupId>org.codehaus.jackson</groupId> <artifactId>jackson-mapper-asl</artifactId> <version>1.9.13</version> </dependency>以下はメインのテストコードです
package test.dmh.session; import java.util.Enumeration; import javax.servlet.http.HttpSession; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.ui.ModelMap; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.SessionAttributes; import org.springframework.web.bind.support.SessionStatus; /** * @SessionAttributes 只声明了参数test1 */ @Controller @SessionAttributes(value={"test1"}) public class HomeController { private static final Logger logger = LoggerFactory.getLogger(HomeController.class); @RequestMapping(value = "/show1") public String show(ModelMap modelMap, HttpSession session) { logger.info("show session"); for (Object key : modelMap.keySet()) { Object value = modelMap.get(key); System.out.println(key + " = " + value); } System.out.println("***********************************"); Enumeration<String> e = session.getAttributeNames(); while (e.hasMoreElements()) { String s = e.nextElement(); System.out.println(s + " == " + session.getAttribute(s)); } System.out.println("***********************************"); return "home"; } @RequestMapping("/set1") public String setSession(ModelMap modelMap) { logger.info("set session 1"); modelMap.addAttribute("test1", "value 1"); //设置一个在@SessionAttributes中声明过的参数 modelMap.addAttribute("test2", "value 2"); //设置一个未在@SessionAttributes中声明过的参数 return "home"; } @RequestMapping("/setM") public String setSessionM(Model model) { logger.info("set session 1"); model.addAttribute("test1", "value 1"); //设置一个在@SessionAttributes中声明过的参数 model.addAttribute("test2", "value 2"); //设置一个未在@SessionAttributes中声明过的参数 return "home"; } @RequestMapping("/clear1") public String clear(SessionStatus status) { logger.info("clear session 1"); status.setComplete(); return "home"; } }
package test.dmh.session.controller; import javax.servlet.http.HttpSession; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.stereotype.Controller; import org.springframework.ui.ModelMap; import org.springframework.web.bind.annotation.RequestMapping; /** * 没有使用@SessionAttributes注解 */ @Controller public class IndexController { private static final Logger logger = LoggerFactory.getLogger(IndexController.class); @RequestMapping("/set2") public String setSession(ModelMap modelMap, HttpSession session) { logger.info("set session 2 : without @SessionAttributes"); modelMap.addAttribute("test3", "value 3"); session.setAttribute("test4", "value 4"); return "home"; } }
package test.dmh.session.controller; import java.util.Enumeration; import java.util.HashMap; import java.util.Map; import javax.servlet.http.HttpSession; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.stereotype.Controller; import org.springframework.ui.ModelMap; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.ResponseBody; import org.springframework.web.bind.annotation.SessionAttributes; import org.springframework.web.bind.support.SessionStatus; @Controller @SessionAttributes(value={"test5", "index"}) public class IndexController2 { private static final Logger logger = LoggerFactory.getLogger(IndexController2.class); @RequestMapping("/set3") public String setSession(ModelMap modelMap, HttpSession session) { logger.info("set session 3"); modelMap.addAttribute("test5", "value 5"); session.setAttribute("test6", "value 6"); ModelMap map = new ModelMap(); map.addAttribute("test7", "value 7"); this.setValueToSession(modelMap, session, "Hello World"); return "home"; } @ResponseBody @RequestMapping(value="/login") public Map<String, Object> login(ModelMap modelMap, HttpSession session) { logger.info("login"); Map<String, Object> map = new HashMap<String, Object>(); map.put("success", true); map.put("info", "登录成功!"); modelMap.addAttribute("testAjax", "test ajax value"); session.setAttribute("httpTestAjax", "http test ajax Value"); setValueToSession(modelMap, session, "This is Ajax"); return map; } private void setValueToSession(ModelMap modelMap, HttpSession session, String value) { logger.info("set session private"); modelMap.addAttribute("index", value); session.setAttribute("httpIndex", value); } @RequestMapping("/clear2") public String clear(SessionStatus status) { logger.info("clear session 2"); status.setComplete(); return "home"; } @RequestMapping(value = "/show2") public String show(ModelMap modelMap, HttpSession session) { logger.info("show session"); for (Object key : modelMap.keySet()) { Object value = modelMap.get(key); System.out.println(key + " = " + value); } System.out.println("***********************************"); Enumeration<String> e = session.getAttributeNames(); while (e.hasMoreElements()) { String s = e.nextElement(); System.out.println(s + " == " + session.getAttribute(s)); } System.out.println("***********************************"); return "home"; } }これが私のように STS でビルドされたプロジェクトの場合、デフォルトの JSP ファイルには設定 が含まれており、これは削除する必要がありますまたはコメント付き
ドロップします。そうしないと、セッション内のデータをページに表示できません。もちろん、ここで書いた /show テストを通じて背景コードを直接表示することもできます。
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> 4 <html> <head> <title>Home</title> </head> <body> <h1> Hello world! </h1> <p> The test1 is ${sessionScope.test1}. </p> <p> The test2 is ${sessionScope.test2}. </p> <p> The test3 is ${sessionScope.test3}. </p> <p> The test4 is ${sessionScope.test4}. </p> <p> The test5 is ${sessionScope.test5}. </p> <p> The test6 is ${sessionScope.test6}. </p> <p> The test7 is ${sessionScope.test7}. </p> <p> The index is ${sessionScope.index}. </p> <p> The httpIndex is ${sessionScope.httpIndex}. </p> <br> <input type="button" value="test" onclick="test();"> <script src="resources/js/jquery.min.js"></script> <script type="text/javascript"> function test() { $.ajax({ type : "POST", url : "login", dataType : "json", success : function(data) { console.log(data); window.open("/session/test", "_self"); }, error : function() { alert("出错了!"); } }); } </script> </body> </html>@SessionAttributesパラメータ設定専用のテストコードもあります
package test.dmh.session.controller; import java.util.Enumeration; import javax.servlet.http.HttpSession; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.stereotype.Controller; import org.springframework.ui.ModelMap; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.SessionAttributes; import org.springframework.web.bind.support.SessionStatus; @Controller @SessionAttributes(value={"index1", "index2"}, types={String.class, Integer.class}) public class IndexController3 { private static final Logger logger = LoggerFactory.getLogger(IndexController3.class); @RequestMapping("/setIndex") public String setSession(ModelMap modelMap) { logger.info("set session index"); modelMap.addAttribute("index1", "aaa"); modelMap.addAttribute("index2", "bbb"); modelMap.addAttribute("index2", "ccc"); modelMap.addAttribute("DDD"); modelMap.addAttribute("FFF"); modelMap.addAttribute(22); return "home"; } @RequestMapping(value = "/showIndex") public String show(ModelMap modelMap, HttpSession session) { logger.info("show session"); for (Object key : modelMap.keySet()) { Object value = modelMap.get(key); System.out.println(key + " = " + value); } System.out.println("***********************************"); Enumeration<String> e = session.getAttributeNames(); while (e.hasMoreElements()) { String s = e.nextElement(); System.out.println(s + " == " + session.getAttribute(s)); } System.out.println("***********************************"); return "home"; } @RequestMapping("/clearIndex") public String clear(SessionStatus status) { logger.info("clear session index"); status.setComplete(); return "home"; } }テストプロセスの簡単な説明:パラメータが多いので名前を考えるのが面倒なので、シリアル化されたtest1、 2、3、終わりました。 テストするときは、ブラウザに URL を入力します: localhost:8080/session/show1
次に、サフィックス show1 を set1、set2、clear1、clear2 などの別の値に変更します。詳細については、コード内の @ を参照してください。 .RequestMapping 構成。 set1 と set2 を入力するたびに、コンソールを通じてセッション内のコンテンツを表示するには show1 と show2 を入力する必要があります。 もちろん、ブラウザ上で表示情報を直接表示することもできます。 ここで主な結論について説明します: 1. ModelMap を使用してデータをセッションに自動的に保存するには、@SessionAttributes アノテーションを設定する必要があります 2。宣言後、このクラスのメソッドは、保存、クリア、読み取りなど、 @SessionAttributes で構成されたパラメーターに対してのみ操作できます。 最後に、@SessionAttributes のパラメータ設定についていくつかの結論が得られます: 1. 設定パラメータは値と型を提供し、すべては arraytype に格納されます。 (パラメータが 1 つだけの場合は、@SessionAttributes(value="test1",types=Integer.class) のように配列形式で記述する必要はありません) 2. value を使用してパラメータを設定する方法は、 Map 3 のキーと値のペアのキー。実際の型のパラメータを設定した後、バックグラウンドで保存されるキーはその型です。個人的には、型などのカスタム クラス オブジェクトを保存する場合にのみ役立つと思います。 =User.class。String などの一般的なクラス オブジェクトにはまだ役立つと思います。値のキーと値のペアを使用することをお勧めします。もちろん、特定の状況については、ケースバイケースで分析する必要があります。 【関連おすすめ】 1.
以上がセッションの使用状況と詳細な記録を Java で簡単に説明しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。