Inhaltsverzeichnis
OAuth3-Einführung
OAuth3-Rolle
Schritt 04: Nachdem der Autorisierungsserver überprüft hat, dass die Informationen korrekt sind, stellt er das Token an den Client aus.
2. 配置授权服务器
3. 配置资源服务器
4. 配置 Security
5. 验证测试
Heim Java javaLernprogramm So verwenden Sie das OAuth2-Framework der SpringBoot-Sicherheitsverwaltung

So verwenden Sie das OAuth2-Framework der SpringBoot-Sicherheitsverwaltung

May 18, 2023 am 08:08 AM
springboot oauth2

OAuth3-Einführung

OAuth ist ein offener Standard, der es Benutzern ermöglicht, Anwendungen von Drittanbietern Zugriff auf die privaten Ressourcen des Benutzers (wie Avatare, Fotos, Videos usw.) zu gewähren, die auf einer Website gespeichert sind. Bei diesem Vorgang ist es nicht erforderlich, Benutzernamen und Passwörter an Drittanwendungen weiterzugeben.

Der Zugriff auf Daten, die bei einem bestimmten Dienstanbieter gespeichert sind, erfolgt über einen Token anstelle eines Benutzernamens und eines Passworts. Jeder Token autorisiert eine bestimmte Website, für einen bestimmten Zeitraum auf bestimmte Ressourcen zuzugreifen.

OAuth ermöglicht es Benutzern, Drittanbieter-Websites zu autorisieren, flexibel auf bestimmte Informationen zuzugreifen, die auf anderen Ressourcenservern gespeichert sind, und nicht auf alle Informationen. Wenn sich ein Benutzer beispielsweise über QQ bei Zhihu anmelden möchte, ist Zhihu eine Drittanbieteranwendung. Wenn Zhihu auf einige grundlegende Informationen des Benutzers zugreifen möchte, benötigt es die Autorisierung des Benutzers, wenn der Benutzer Zhihu seinen QQ-Benutzer mitteilt Name und Passwort, dann kann Zhihu auf alle Daten des Benutzers zugreifen und nur der Benutzer kann die Berechtigung durch Ändern seines Passworts widerrufen. Diese Autorisierungsmethode birgt große Sicherheitsrisiken. Wenn Sie OAuth verwenden, kann dieses Problem gut gelöst werden.

Durch die Verwendung von Token können Benutzer Berechtigungen von Drittanbieteranwendungen flexibel autorisieren oder entziehen. OAuth 2 ist die nächste Version des OAuth-Protokolls, ist jedoch nicht abwärtskompatibel mit OAuth 1.0.

OAuth 2 konzentriert sich auf die Einfachheit für Client-Entwickler und bietet gleichzeitig spezielle Authentifizierungsprozesse für Webanwendungen, Desktop-Anwendungen, mobile Geräte und Wohnzimmergeräte. Die herkömmliche Anmeldeauthentifizierung für die Webentwicklung basiert im Allgemeinen auf der Sitzung. Die weitere Verwendung der Sitzung in einer Front-End- und Back-End-Architektur mit getrennten Front-End- und Back-End-Architekturen führt jedoch zu vielen Unannehmlichkeiten, da das mobile Endgerät (Android, IOS, WeChat-Applet usw.) dies nicht tut Unterstützt Cookies (WeChat-Applet) oder ist die Verwendung sehr unpraktisch. Diese Probleme können durch die Verwendung der OAuth 2-Authentifizierung gelöst werden.

OAuth3-Rolle

Verstehen Sie zunächst einige grundlegende Rollen in OAuth 2

  • Ressourcenbesitzer: Benutzer, mit Ressourcen B. Avatare, Fotos, Videos usw.: Wird verwendet, um zu überprüfen, ob die vom Benutzer bereitgestellten Informationen korrekt sind, und um ein Token an die Drittanbieteranwendung zurückzugeben

  • Ressource Server: Ein Server, der Benutzerressourcen wie Avatare und Fotos, Videos und andere Ressourcen bereitstellt

  • Im Allgemeinen können der Autorisierungsserver und der Ressourcenserver derselbe Server sein .

  • OAuth3-Autorisierungsprozess
  • Schritt 01: Der Client (Drittanbieteranwendung) fordert die Autorisierung vom Benutzer an.

  • Wenn der Benutzer auf der Dienstautorisierungsseite auf die Schaltfläche „Autorisierung zustimmen“ klickt, gibt der Server ein Autorisierungszertifikat an den Client zurück.

Schritt 03: Der Client bringt die Autorisierungslizenz zum Autorisierungsserver, um ein Token zu beantragen.

Schritt 04: Nachdem der Autorisierungsserver überprüft hat, dass die Informationen korrekt sind, stellt er das Token an den Client aus.

Schritt 05: Der Client bringt den Token zum Ressourcenserver, um auf Ressourcen zuzugreifen.

Schritt 06: Der Ressourcenserver öffnet die Ressource, nachdem er überprüft hat, dass das Token korrekt ist.

Autorisierungsmodus

Der Autorisierungsmodus des OAuth-Protokolls ist wie folgt in 4 Typen unterteilt

Autorisierung Code-Autorisierungsmodus Es handelt sich um die umfassendste Funktion und den strengsten Prozess unter den Autorisierungsmethoden, und sein Autorisierungscode ist der Schlüssel. Das Merkmal dieses Modus besteht darin, dass der Client-Server mit dem Autorisierungsserver interagiert. Gängige inländische Anmeldefunktionen von Drittanbieterplattformen übernehmen grundsätzlich diese Methode

Vereinfachter Modus: Vereinfachter Modus erfordert keine Beteiligung des Client-Servers. Sie beantragen ein Token direkt vom Autorisierungsserver im Browser. Wenn es sich um eine rein statische Seite handelt, können Sie diese Methode verwenden

    #🎜🎜 #
  • im Passwort In diesem Modus geben Benutzer ihren Benutzernamen und ihr Passwort direkt an den Client weiter, und der Client verwendet diese Informationen, um ein Zugriffstoken vom Autorisierungsserver anzufordern. Benutzer müssen wichtige Informationen über den Client kennen, z. B. ob die Client-Anwendung und der Dienstanbieter dasselbe Unternehmen sind

  • Im Client-Modus autorisiert der Dienstanbieter kundenspezifisch und nicht benutzerspezifisch. Streng genommen kann der Client-Modus nicht als Lösung für die Probleme angesehen werden, die das OAuth-Protokoll löst. Für Entwickler ist es jedoch nützlich, diese Methode in einigen Front-End- und Back-End-Trennanwendungen oder bereitgestellten Authentifizierungs- und Autorisierungsservern zu verwenden Für mobile Endgeräte ist der Modus immer noch sehr praktisch. 🎜🎜#

    Übung

  • Hier stellen wir vor, wie man einen OAuth-Dienst in einem Authentifizierungsserver erstellt, der von einer Front-End- und Back-End-Trennanwendung (oder für mobile Endgeräte, WeChat-Applets, usw.), daher wird hauptsächlich der Passwortmodus eingeführt.
  • 1. Erstellen Sie ein Projekt und fügen Sie Abhängigkeiten hinzu.

  • Erstellen Sie ein Spring Boot-Webprojekt und fügen Sie die folgenden Abhängigkeiten hinzu.
  • <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-data-redis</artifactId>
      <exclusions>
        <exclusion>
          <groupId>io.lettuce</groupId>
          <artifactId>lettuce-core</artifactId>
        </exclusion>
      </exclusions>
    </dependency>
    <dependency>
      <groupId>redis.clients</groupId>
      <artifactId>jedis</artifactId>
    </dependency>
    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-security</artifactId>
    </dependency>
    <dependency>
      <groupId>org.springframework.security.oauth</groupId>
      <artifactId>spring-security-oauth3</artifactId>
      <version>2.3.3.RELEASE</version>
    </dependency>
    Nach dem Login kopieren

    Seit dem OAuth-Protokoll im Frühjahr Der Startvorgang erfolgt im Frühjahr auf der Grundlage der Sicherheit. Daher müssen Sie zunächst die Abhängigkeit von Spring Security hinzufügen, sodass OAuth 2-bezogene Abhängigkeiten hinzugefügt werden können. Das Token kann gleichzeitig auf dem Redis-Cache-Server gespeichert werden , Redis verfügt über Funktionen wie Ablauf, die sich sehr gut für die Token-Speicherung eignen, sodass auch Redis-Abhängigkeiten hinzugefügt werden.

  • Konfiguration application.properties

spring.redis.database=0
spring.redis.host=ip地址
spring.redis.port=6379
spring.redis.password=root
spring.redis.jedis.pool.max-active=8
spring.redis.jedis.pool.max-idle=8
spring.redis.jedis.pool.max-wait=-1ms
spring.redis.jedis.pool.min-idle=0

2. 配置授权服务器

授权服务器和资源服务器可以是同一台服务器,也可以是不同服务器,此处假设是同一台服务器,通过不同的配置分别开启授权服务器和资源服务器,首先是授权服务器:

@Configuration
@EnableAuthorizationServer
public class AuthorizationServerConfig extends AuthorizationServerConfigurerAdapter {
    @Autowired
    AuthenticationManager authenticationManager;
    @Autowired
    RedisConnectionFactory redisConnectionFactory;
    @Autowired
    UserDetailsService userDetailsService;
    @Bean
    PasswordEncoder passwordEncoder() {
        return new BCryptPasswordEncoder();
    }
    @Override
    public void configure(ClientDetailsServiceConfigurer clients) throws Exception {
        clients.inMemory()
                .withClient("password")
                .authorizedGrantTypes("password", "refresh_token")
                .accessTokenValiditySeconds(1800)
                .resourceIds("rid")
                .scopes("all")
                .secret("$2a$10$RMuFXGQ5AtH4wOvkUqyvuecpqUSeoxZYqilXzbz50dceRsga.WYiq");
    }
    @Override
    public void configure(AuthorizationServerEndpointsConfigurer endpoints) throws Exception {
        endpoints.tokenStore(new RedisTokenStore(redisConnectionFactory))
                .authenticationManager(authenticationManager)
                .userDetailsService(userDetailsService);
    }
    @Override
    public void configure(AuthorizationServerSecurityConfigurer security) throws Exception {
        security.allowFormAuthenticationForClients();
    }
}
Nach dem Login kopieren

代码解释:

  • 自定义类继承自 AuthorizationServerConfigurerAdapter ,完成对授权服务器的配置,然后通过 @EnableAuthorizationServer 注解开启授权服务器

  • 注入 AuthenticationManager 用来支持 password 模式

  • 注入 RedisConnectionFactory 用来完成 Redis 缓存,将令牌信息储存到 Redis 缓存中

  • 注入 UserDetailsService 该对象为刷新 token 提供支持

  • 在 configure(ClientDetailsServiceConfigurer clients) 方法中配置 password 授权模式,authorizedGrantTypes 表示 OAuth 2 中的授权模式为 password 和 refresh_token 两种,在标准的 OAuth 2 协议中,授权模式并不包括 refresh_token ,但是在 Spring Security 的实现中将其归为一种,因此如果要实现 access_token 的刷新,就需要添加这样一种授权模式;accessTokenValiditySeconds 方法配置了 access_token 的过期时间;resourceIds 配置了资源 id;secret 方法配置了加密后的密码,明文是 123

  • configure(AuthorizationServerEndpointsConfigurer endpoints) 方法配置了令牌的存储,AuthenticationManager 和 UserDetailsService 主要用于支持 password 模式以及令牌的刷新

  • configure(AuthorizationServerSecurityConfigurer security) 方法配置表示支持 client_id 和 client_secret 做登录认证

3. 配置资源服务器

@Configuration
@EnableResourceServer
public class ResourceServerConfig extends ResourceServerConfigurerAdapter {
    @Override
    public void configure(ResourceServerSecurityConfigurer resources) throws Exception {
        resources.resourceId("rid").stateless(true);
    }
    @Override
    public void configure(HttpSecurity http) throws Exception {
        http.authorizeRequests()
                .antMatchers("/admin/**").hasRole("admin")
                .antMatchers("/user/**").hasRole("user")
                .anyRequest().authenticated();
    }
}
Nach dem Login kopieren

代码解释:

  • 自定义类继承自 ResourceServerConfigurerAdapter ,并添加 @EnableResourceServer 注解开启资源服务器配置

  • resources.resourceId(“rid”).stateless(true); 配置资源 id,这里的资源 id 和授权服务器中的资源 id 一直,然后设置这些资源仅基于令牌认证

  • configure(HttpSecurity http) 方法配置 HttpSecurity

4. 配置 Security

@Configuration
public class WebSecurityConfig extends WebSecurityConfigurerAdapter {
    @Bean
    @Override
    public AuthenticationManager authenticationManagerBean() throws Exception {
        return super.authenticationManagerBean();
    }
    @Bean
    @Override
    protected UserDetailsService userDetailsService() {
        return super.userDetailsService();
    }
    @Override
    protected void configure(AuthenticationManagerBuilder auth) throws Exception {
        auth.inMemoryAuthentication()
                .withUser("admin")
                .password("$2a$10$RMuFXGQ5AtH4wOvkUqyvuecpqUSeoxZYqilXzbz50dceRsga.WYiq")
                .roles("admin")
                .and()
                .withUser("sang")
                .password("$2a$10$RMuFXGQ5AtH4wOvkUqyvuecpqUSeoxZYqilXzbz50dceRsga.WYiq")
                .roles("user");
    }
    @Override
    protected void configure(HttpSecurity http) throws Exception {
        http.antMatcher("/oauth/**").authorizeRequests()
                .antMatchers("/oauth/**").permitAll()
                .and().csrf().disable();
    }
}
Nach dem Login kopieren

这里两个 Bean 将注入授权服务器配置类中使用,另外,这里的 HttpSecurity 配置主要是配置 /oauth/** 模式的 URL ,这一类的请求直接放行。在 Spring Security 配置和资源服务器配置中,一共涉及两个 HttpSecurity ,其中 Spring Security 中的配置优先级高于资源服务器中的配置,即请求地址先经过 Spring Security 的 HttpSecurity ,再经过资源服务器的 HttpSecurity。

5. 验证测试

首先创建三个简单的请求地址

@RestController
public class HelloController {
    @GetMapping("/admin/hello")
    public String admin() {
        return "Hello admin!";
    }
    @GetMapping("/user/hello")
    public String user() {
        return "Hello user!";
    }
    @GetMapping("/hello")
    public String hello() {
        return "hello";
    }
}
Nach dem Login kopieren

根据前文的配置,要请求这三个地址,分别需要 admin 角色、user 角色以及登录后访问。

所有都配置完成后,启动 Redis 服务器,再启动 Spring Boot 项目,首先发送一个 POST 请求获取 token,请求地址如下(注意这里是一个 POST 请求,为了显示方便,将参数写在地址栏中):http://localhost:8080/oauth/token?username=sang&password=123&grant_type=password&client_id=password&scope=all&client_secret=123

请求地址中包含的参数有用户名、密码、授权模式、客户端 id 、scope 以及客户端密码,基本就是授权服务器中所配置的数据,请求结果如图

So verwenden Sie das OAuth2-Framework der SpringBoot-Sicherheitsverwaltung

其中 access_token 是获取其它资源时要用的令牌,refresh_token 用来刷新令牌,expires_in 表示 access_token 过期时间,当 access_token 过期后,使用 refresh_token 重新获取新的 access_token (前提是 refresh_token 未过期),请求地址(注意也是POST请求):http://localhost:8080/oauth/token?grant_type=refresh_token&refresh_token=693b0e36-4515-442a-8c5d-90bade3c74d2&client_id=password&client_secret=123

获取新的 access_token 时需要携带上 refresh_token ,同事授权模式设置为 refresh_token ,在获取的结果中 access_token 会变化,同时 access_token 有效期也会变化,如图

So verwenden Sie das OAuth2-Framework der SpringBoot-Sicherheitsverwaltung

接下来访问所有资源,携带上 access_token 参数即可,例如 /user/hello 接口:http://localhost:8080/user/hello?access_token=0497e4bc-df37-460e-8755-b813b9dbf36a,访问结果如图

So verwenden Sie das OAuth2-Framework der SpringBoot-Sicherheitsverwaltung

Wenn illegal auf eine Ressource zugegriffen wird, beispielsweise wenn der Sang-Benutzer auf die Schnittstelle /admin/hello zugreift, sieht das Ergebnis wie in der Abbildung dargestellt aus.

So verwenden Sie das OAuth2-Framework der SpringBoot-Sicherheitsverwaltung

An diesem Punkt verfügt das OAuth-Authentifizierungssystem über einen Passwortmodus erfolgreich etabliert.

Es gibt 4 Authentifizierungsmodi in OAuth. Entwickler müssen einen davon basierend auf der tatsächlichen Situation ihrer eigenen Entwicklung auswählen. Hier werden auch andere Autorisierungsmodi vorgestellt haben ihre eigenen Nutzungsszenarien.

Im Allgemeinen ist die Verwendung von Spring Security OAuth 2 noch relativ kompliziert und auch die Konfiguration ist relativ umständlich. Wenn das Anwendungsszenario des Entwicklers relativ einfach ist, kann er sein eigenes OAuth 2-Authentifizierungssystem gemäß dem hier vorgestellten Autorisierungsprozess erstellen .

Das obige ist der detaillierte Inhalt vonSo verwenden Sie das OAuth2-Framework der SpringBoot-Sicherheitsverwaltung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Repo: Wie man Teamkollegen wiederbelebt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Wie Springboot Jasypt integriert, um die Verschlüsselung von Konfigurationsdateien zu implementieren Wie Springboot Jasypt integriert, um die Verschlüsselung von Konfigurationsdateien zu implementieren Jun 01, 2023 am 08:55 AM

Einführung in Jasypt Jasypt ist eine Java-Bibliothek, die es einem Entwickler ermöglicht, seinem Projekt mit minimalem Aufwand grundlegende Verschlüsselungsfunktionen hinzuzufügen und kein tiefes Verständnis der Funktionsweise der Verschlüsselung erfordert. standardbasierte Verschlüsselungstechnologie. Passwörter, Text, Zahlen, Binärdateien verschlüsseln ... Geeignet für die Integration in Spring-basierte Anwendungen, offene API, zur Verwendung mit jedem JCE-Anbieter ... Fügen Sie die folgende Abhängigkeit hinzu: com.github.ulisesbocchiojasypt-spring-boot-starter2 Die Vorteile von Jasypt schützen unsere Systemsicherheit. Selbst wenn der Code durchgesickert ist, kann die Datenquelle garantiert werden.

So implementieren Sie verteilte Sperren mit Redis in SpringBoot So implementieren Sie verteilte Sperren mit Redis in SpringBoot Jun 03, 2023 am 08:16 AM

1. Redis implementiert das Prinzip der verteilten Sperren und warum verteilte Sperren erforderlich sind. Bevor über verteilte Sperren gesprochen wird, muss erläutert werden, warum verteilte Sperren erforderlich sind. Das Gegenteil von verteilten Sperren sind eigenständige Sperren. Wenn wir Multithread-Programme schreiben, vermeiden wir Datenprobleme, die durch den gleichzeitigen Betrieb einer gemeinsam genutzten Variablen verursacht werden. Normalerweise verwenden wir eine Sperre, um die Richtigkeit der gemeinsam genutzten Variablen sicherzustellen Die gemeinsam genutzten Variablen liegen im gleichen Prozess. Wenn es mehrere Prozesse gibt, die gleichzeitig eine gemeinsam genutzte Ressource betreiben müssen, wie können sie sich dann gegenseitig ausschließen? Heutige Geschäftsanwendungen sind in der Regel Microservice-Architekturen, was auch bedeutet, dass eine Anwendung mehrere Prozesse bereitstellen muss. Wenn mehrere Prozesse dieselbe Datensatzzeile in MySQL ändern müssen, ist eine Verteilung erforderlich, um fehlerhafte Daten zu vermeiden wird zu diesem Zeitpunkt eingeführt. Der Stil ist gesperrt. Punkte erreichen wollen

Wie SpringBoot Redisson integriert, um eine Verzögerungswarteschlange zu implementieren Wie SpringBoot Redisson integriert, um eine Verzögerungswarteschlange zu implementieren May 30, 2023 pm 02:40 PM

Nutzungsszenario 1. Die Bestellung wurde erfolgreich aufgegeben, die Zahlung erfolgte jedoch nicht innerhalb von 30 Minuten. Die Zahlung ist abgelaufen und die Bestellung wurde automatisch storniert. 2. Die Bestellung wurde unterzeichnet und es wurde 7 Tage lang keine Bewertung durchgeführt. Wenn die Bestellung abläuft und nicht ausgewertet wird, wird die Bestellung standardmäßig positiv bewertet. Wenn der Händler die Bestellung innerhalb von 5 Minuten nicht erhält, wird die Bestellung abgebrochen Es wird eine SMS-Erinnerung gesendet ... Für Szenarien mit langen Verzögerungen und geringer Echtzeitleistung können wir die Aufgabenplanung verwenden, um eine regelmäßige Abfrageverarbeitung durchzuführen. Zum Beispiel: xxl-job Heute werden wir auswählen

So lösen Sie das Problem, dass Springboot nach dem Einlesen in ein JAR-Paket nicht auf die Datei zugreifen kann So lösen Sie das Problem, dass Springboot nach dem Einlesen in ein JAR-Paket nicht auf die Datei zugreifen kann Jun 03, 2023 pm 04:38 PM

Springboot liest die Datei, kann aber nach dem Packen in ein JAR-Paket nicht auf die neueste Entwicklung zugreifen. Es gibt eine Situation, in der Springboot die Datei nach dem Packen in ein JAR-Paket nicht lesen kann ist ungültig und kann nur über den Stream gelesen werden. Die Datei befindet sich unter resources publicvoidtest(){Listnames=newArrayList();InputStreamReaderread=null;try{ClassPathResourceresource=newClassPathResource("name.txt");Input

Vergleich und Differenzanalyse zwischen SpringBoot und SpringMVC Vergleich und Differenzanalyse zwischen SpringBoot und SpringMVC Dec 29, 2023 am 11:02 AM

SpringBoot und SpringMVC sind beide häufig verwendete Frameworks in der Java-Entwicklung, es gibt jedoch einige offensichtliche Unterschiede zwischen ihnen. In diesem Artikel werden die Funktionen und Verwendungsmöglichkeiten dieser beiden Frameworks untersucht und ihre Unterschiede verglichen. Lassen Sie uns zunächst etwas über SpringBoot lernen. SpringBoot wurde vom Pivotal-Team entwickelt, um die Erstellung und Bereitstellung von Anwendungen auf Basis des Spring-Frameworks zu vereinfachen. Es bietet eine schnelle und einfache Möglichkeit, eigenständige, ausführbare Dateien zu erstellen

Wie SpringBoot Redis anpasst, um die Cache-Serialisierung zu implementieren Wie SpringBoot Redis anpasst, um die Cache-Serialisierung zu implementieren Jun 03, 2023 am 11:32 AM

1. Passen Sie den RedisTemplate1.1-Standard-Serialisierungsmechanismus an. Die API-basierte Redis-Cache-Implementierung verwendet die RedisTemplate-Vorlage für Daten-Caching-Vorgänge. Öffnen Sie hier die RedisTemplate-Klasse und zeigen Sie die Quellcodeinformationen der Klasse publicclassRedisTemplateextendsRedisAccessorimplementsRedisOperations an. Schlüssel deklarieren, verschiedene Serialisierungsmethoden des Werts, der Anfangswert ist leer @NullableprivateRedisSe

So implementieren Sie Springboot+Mybatis-plus, ohne SQL-Anweisungen zum Hinzufügen mehrerer Tabellen zu verwenden So implementieren Sie Springboot+Mybatis-plus, ohne SQL-Anweisungen zum Hinzufügen mehrerer Tabellen zu verwenden Jun 02, 2023 am 11:07 AM

Wenn Springboot + Mybatis-plus keine SQL-Anweisungen zum Hinzufügen mehrerer Tabellen verwendet, werden die Probleme, auf die ich gestoßen bin, durch die Simulation des Denkens in der Testumgebung zerlegt: Erstellen Sie ein BrandDTO-Objekt mit Parametern, um die Übergabe von Parametern an den Hintergrund zu simulieren dass es äußerst schwierig ist, Multi-Table-Operationen in Mybatis-plus durchzuführen. Wenn Sie keine Tools wie Mybatis-plus-join verwenden, können Sie nur die entsprechende Mapper.xml-Datei konfigurieren und die stinkende und lange ResultMap konfigurieren Schreiben Sie die entsprechende SQL-Anweisung. Obwohl diese Methode umständlich erscheint, ist sie äußerst flexibel und ermöglicht es uns

So erhalten Sie den Wert in application.yml in Springboot So erhalten Sie den Wert in application.yml in Springboot Jun 03, 2023 pm 06:43 PM

In Projekten werden häufig einige Konfigurationsinformationen benötigt. Diese Informationen können in der Testumgebung und in der Produktionsumgebung unterschiedliche Konfigurationen haben und müssen möglicherweise später basierend auf den tatsächlichen Geschäftsbedingungen geändert werden. Wir können diese Konfigurationen nicht fest im Code codieren. Am besten schreiben Sie sie in die Konfigurationsdatei. Sie können diese Informationen beispielsweise in die Datei application.yml schreiben. Wie erhält oder verwendet man diese Adresse im Code? Es gibt 2 Methoden. Methode 1: Wir können den Wert, der dem Schlüssel in der Konfigurationsdatei (application.yml) entspricht, über den mit @Value versehenen Wert erhalten. Diese Methode eignet sich für Situationen, in denen es relativ wenige Mikrodienste gibt: Tatsächlich Projekte, wenn das Geschäft kompliziert ist, Logik

See all articles