Управление HTTP-сессией в springMVC

Я новичок в Spring MVC и начал делать пример приложения, делая то, чему научился. Я планирую внедрить управление сессиями весной MVC. Я нашел это полезным.

Но я не могу понять это ясно. Мы добавляем значения в сеанс, например

HttpSession session = request.getSession(false);
session.setAttribute("key", value);
session.setAttribute("key1",  value1);

а позже мы извлекаем значения на основе таких ключей, как

session.getAttrubute("key");

но в весеннем MVC я не видел ничего подобного, и это меня совершенно смущает.

@Controller
@SessionAttributes("thought")
public class SingleFieldController {

    @RequestMapping(value="/single-field")
    public ModelAndView singleFieldPage() {
        return new ModelAndView("single-field-page");
    }

    @RequestMapping(value="/remember")  
    public ModelAndView rememberThought(@RequestParam String thoughtParam) {
        ModelAndView modelAndView = new ModelAndView();
        modelAndView.addObject("thought", thoughtParam);
        modelAndView.setViewName("single-field-page");
        return modelAndView;
    }

}

В приведенном выше коде @SessionAttributes("thought") полностью сбивает меня с толку, как то, что это thought определено, и мне не нужно возвращать ModelAndView, так как я использую backbone.marionette.js

Итак, как я могу установить значения в сеансе и использовать их при необходимости? Мне также нужно преобразовать объект сеанса в мой пользовательский объект, поскольку при возврате значений на экран я возвращаю только список объектов UserDefined, доступных в сеансе.

Поэтому, пожалуйста, помогите мне понять это лучше. Возможно, меня смущает то, как я использовал jsp/servlet.

ОБНОВЛЕНИЕ

Ниже приведен контроллер, который у меня есть, и предоставлены комментарии

package com.hexgen.puppet;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.SessionAttributes;

import com.hexgen.puppet.CreatePuppet;

import java.util.ArrayList;
import java.util.List;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;

@Controller
public class PuppetService {

    @RequestMapping(method = RequestMethod.POST, value = "/create")
    public @ResponseBody
    void createOrder(@RequestBody CreatePuppet request) {
        //logic to add/update values in session
    }

    @RequestMapping(method = RequestMethod.GET, value = "/list")
    public @ResponseBody
    List<Puppet> getGroups() {
        //logic to retrive objects from session and convert it as List and send it back

        return puppets;
    }


}

и преобразовать объект, если это необходимо, и продолжить


person Java Questions    schedule 17.06.2013    source источник


Ответы (2)


@SessionAttributes не полностью заменяет традиционное управление сеансом HttpServlet. Используйте его, если два или более метода контроллера должны передавать некоторые данные. Но, используя это, мы можем добиться связи только в пределах одного класса контроллера. Вы не используете явное чтение и запись из сеанса и в сеанс, если используете @SessionAttributes. Использование @SessionAttributes рекомендуется только для краткосрочной связи. Если вам нужно хранить долгосрочные данные в сеансе, рекомендуется явно использовать session.setAttribute и session.getAttribute вместо @SessionAttributes. . Для получения дополнительной информации проверьте это.

person Vaibhav Raj    schedule 17.06.2013

Вы можете обрабатывать управление сеансом в springmvc следующим образом. вот метод контроллера

@RequestMapping(value = { "/login" }, method = RequestMethod.POST)
@ResponseBody
public String login(HttpSession session,String username,String password) throws Exception {
    Member member=userService.authenticateUser(username, password);
    if(member!=null) {
        session.setAttribute("MEMBER", member);
    } else {
        throw new Exception("Invalid username or password");
    }
    return Utils.toJson("SUCCESS");
}

пользователь будет передавать имя пользователя и пароль, в то время как Spring автоматически введет атрибут сеанса. мы будем аутентифицировать это имя пользователя и пароль от db. Для этого мы будем использовать некоторый служебный метод, который, в свою очередь, вызовет некоторый метод репозитория, чтобы получить класс Object of Member и вернуть его сюда, в контроллер. Где бы в вашем методе приложения вам ни потребовалась информация, хранящаяся в сеансе, передайте ее в аргументе обработчику. Вы можете найти более подробную информацию о том, как эту информацию можно проверить при каждом вызове метода, по адресу http://faisalbhagat.blogspot.com/2014/09/session-management-with-spring-mvc.html

person faisalbhagat    schedule 17.09.2014
comment
Этот пример помог мне.. Мне было интересно, как объявить и использовать HttpSession и код мира, просветите меня, спасибо... - person Malek Boubakri; 01.04.2016