添加了 Spring Security CORS 过滤器 - 从 DB 检索的日期显示在数值中

Posted

技术标签:

【中文标题】添加了 Spring Security CORS 过滤器 - 从 DB 检索的日期显示在数值中【英文标题】:Added Spring Security CORS Filter- Dates retrieved from DB appear in Numeric Values 【发布时间】:2020-11-24 02:02:18 【问题描述】:

我添加了这两个确切的类来解决 Hendy Irawan 建议的 CORS 问题: Spring security CORS Filter(第 1 次)回答

二等舱(public class MyFilter extends OncePerRequestFilter)只有一个区别,我用Arrays.asList("...")而不是ImmutableList.of("...")

这是我的休息控制器

@RestController
public class UsersProfileController 
   @Autowired UserProfInterface userProfInterface;

   @GetMapping("/connector/username/users")
    public List<UserProfilesEntity> getAllUsers(
            @PathVariable String username) 
        return userProfInterface.getAllUsers();
    

这会返回一个 JSON,如下所示: 4: idUserProfiles: 10, firstName: "Aris2", lastName: "Testy", dateOfBirth: 28936800000 mysql DB 上的dateOfBirth 如下所示:1970-12-02

一旦我禁用 Spring-Security 依赖项,出生日期就会正确显示在 JSON 文件和我的前端视图中(我正在使用 Reactjs)。

我的pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.3.2.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.bootcamp</groupId>
    <artifactId>connector</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>war</packaging>
    <name>connector</name>
    <description>Demo project for Spring Boot</description>

    <properties>
        <java.version>11</java.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>
<!--        <dependency>-->
<!--            <groupId>org.springframework.boot</groupId>-->
<!--            <artifactId>spring-boot-starter-data-rest</artifactId>-->
<!--        </dependency>-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-security</artifactId>
        </dependency>
        <dependency>
            <groupId>com.h2database</groupId>
            <artifactId>h2</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-tomcat</artifactId>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
            <exclusions>
                <exclusion>
                    <groupId>org.junit.vintage</groupId>
                    <artifactId>junit-vintage-engine</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-thymeleaf</artifactId>
        </dependency>
    </dependencies>

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

</project>

我使用的是Spring Security 5.3.3 版

我是 *** 的长期访问者,这是我第一次询问,因此我们将不胜感激。

【问题讨论】:

【参考方案1】:

您可以使用“@JsonFormat”按您的预期显示。关于spring security,我不确定它是否会影响日期的格式

【讨论】:

以上是关于添加了 Spring Security CORS 过滤器 - 从 DB 检索的日期显示在数值中的主要内容,如果未能解决你的问题,请参考以下文章

添加了 Spring Security CORS 过滤器 - 从 DB 检索的日期显示在数值中

Spring Boot 中的 CORS 与 Spring Security + React

如何在 Spring Boot 中使用 Spring Security 启用 CORS

Spring boot、jwt、jersey、spring security和CORS问题

spring security CORS 过滤器允许没有“Origin”标头的请求

Spring Security CORS:来源已被 CORS 策略阻止