Подтвердить что ты не робот

Управление Httpsession весной MVC

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

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

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

а затем мы извлекаем значения на основе таких клавиш, как

session.getAttrubute("key");

но в spring 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

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

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

UPDATE

Ниже приведен контроллер и предоставил комментарии

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;
    }


}

и при необходимости конвертируйте объект и продолжайте

4b9b3361

Ответ 1

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

Ответ 2

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