2016-05-20 85 views
2

我正在寻求帮助来配置Spring Boot来在不使用Spring Security的情况下坚持Spring会话。没有Spring Security的坚持Spring会话

我从HttpSession JDBC Spring Boot sample app开始,为Spring Boot应用程序坚持Spring会话。但是这使用Spring Security。在删除Spring Security时,会话不再保存在H2数据库中。 XML configJava config示例应用程序不使用Spring Security。因此,不是一个要求。

guide指出springSessionRepositoryFilter将创建Spring会话。但是,在删除Spring Security并调试此过滤器(SessionRepositoryFilter)后,传递给的布尔值SessionRepositoryFilter $ SessionRepositoryRequestWrapper.getSession(布尔值)永远不会设置为true。因此,Spring Session永远不会被创建和保存。

对于没有Spring Security的Spring Boot应用程序需要额外配置的持久化Spring Session的任何建议?

下面是相关的类,pom.xml的,而application.property文件:

@SpringBootApplication 
public class SbWebSessionJdbcApplication { 

    public static void main(String[] args) { 
     SpringApplication.run(SbWebSessionJdbcApplication.class, args); 
    } 
} 

@EnableJdbcHttpSession 
public class HttpSessionConfig { 
} 

的pom.xml

<parent> 
    <groupId>org.springframework.boot</groupId> 
    <artifactId>spring-boot-starter-parent</artifactId> 
    <version>1.3.5.RELEASE</version> 
    <relativePath/> 
</parent> 

<properties> 
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> 
    <java.version>1.8</java.version> 
</properties> 

<dependencies> 
    <dependency> 
     <groupId>org.springframework.boot</groupId> 
     <artifactId>spring-boot-starter-web</artifactId> 
    </dependency> 
    <dependency> 
     <groupId>org.springframework.session</groupId> 
     <artifactId>spring-session-jdbc</artifactId> 
     <version>1.2.0.RELEASE</version> 
    </dependency> 
    <dependency> 
     <groupId>org.springframework.session</groupId> 
     <artifactId>spring-session</artifactId> 
     <version>1.2.0.RELEASE</version> 
    </dependency> 
    <dependency> 
     <groupId>org.springframework.boot</groupId> 
     <artifactId>spring-boot-starter-jdbc</artifactId> 
    </dependency> 

    <dependency> 
     <groupId>com.h2database</groupId> 
     <artifactId>h2</artifactId> 
     <scope>runtime</scope> 
    </dependency> 
    <dependency> 
     <groupId>org.springframework.boot</groupId> 
     <artifactId>spring-boot-starter-test</artifactId> 
     <scope>test</scope> 
    </dependency> 
</dependencies> 

<build> 
    <plugins> 
     <plugin> 
      <groupId>org.springframework.boot</groupId> 
      <artifactId>spring-boot-maven-plugin</artifactId> 
     </plugin> 
    </plugins> 
</build> 

application.properties

spring.thymeleaf.cache=false 
spring.template.cache=false 
spring.datasource.schema=classpath:org/springframework/session/jdbc/schema-h2.sql 
spring.h2.console.enabled=true 
logging.level.org.springframework.web=DEBUG 

回答

1

其实,有没有什么更特别的,你需要配置 - 你只需要开始创建HttpSession并根据您的需要使用它。例如,实现此目的的最简单方法是将Spring MVC控制器方法以HttpSession作为参数。

检出this repo on Github,特别是basic-jdbc模块。这正是你正在寻找的示例 - Spring Spring应用程序,但没有Spring Security。

相关问题