From 0663bbfe6e88ae32aa184cb534b3a8c747e83a54 Mon Sep 17 00:00:00 2001 From: serega6531 Date: Tue, 30 Apr 2019 00:00:36 +0300 Subject: [PATCH] =?UTF-8?q?=D0=94=D0=BE=D0=B1=D0=B0=D0=B2=D0=BB=D0=B5?= =?UTF-8?q?=D0=BD=D0=B0=20http=20=D0=B0=D0=B2=D1=82=D0=BE=D1=80=D0=B8?= =?UTF-8?q?=D0=B7=D0=B0=D1=86=D0=B8=D1=8F?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- build.gradle | 1 + .../packmate/SecurityConfiguration.java | 44 +++++++++++++++++++ src/main/resources/application.yml | 4 +- 3 files changed, 48 insertions(+), 1 deletion(-) create mode 100644 src/main/java/ru/serega6531/packmate/SecurityConfiguration.java diff --git a/build.gradle b/build.gradle index 5f2abf5..cb03dec 100644 --- a/build.gradle +++ b/build.gradle @@ -22,6 +22,7 @@ repositories { dependencies { implementation 'org.springframework.boot:spring-boot-starter-data-jpa' implementation 'org.springframework.boot:spring-boot-starter-web' + implementation "org.springframework.boot:spring-boot-starter-security" implementation 'org.springframework.session:spring-session-core' compile group: 'org.apache.commons', name: 'commons-lang3', version: '3.7' compile 'org.pcap4j:pcap4j-core:1.+' diff --git a/src/main/java/ru/serega6531/packmate/SecurityConfiguration.java b/src/main/java/ru/serega6531/packmate/SecurityConfiguration.java new file mode 100644 index 0000000..f94c8b7 --- /dev/null +++ b/src/main/java/ru/serega6531/packmate/SecurityConfiguration.java @@ -0,0 +1,44 @@ +package ru.serega6531.packmate; + +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.beans.factory.annotation.Value; +import org.springframework.context.annotation.Bean; +import org.springframework.context.annotation.Configuration; +import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder; +import org.springframework.security.config.annotation.web.builders.HttpSecurity; +import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity; +import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter; +import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder; +import org.springframework.security.crypto.password.PasswordEncoder; + +@Configuration +@EnableWebSecurity +public class SecurityConfiguration extends WebSecurityConfigurerAdapter { + + @Value("${account-login}") + private String login; + + @Value("${account-password}") + private String password; + + @Autowired + public void configureGlobal(AuthenticationManagerBuilder auth) throws Exception { + auth.inMemoryAuthentication() + .withUser(login).password(passwordEncoder().encode(password)) + .authorities("ROLE_USER"); + } + + @Override + protected void configure(HttpSecurity http) throws Exception { + http.authorizeRequests() + .anyRequest().authenticated() + .and() + .httpBasic(); + } + + @Bean + public PasswordEncoder passwordEncoder() { + return new BCryptPasswordEncoder(); + } + +} diff --git a/src/main/resources/application.yml b/src/main/resources/application.yml index 1562cc2..60afac1 100644 --- a/src/main/resources/application.yml +++ b/src/main/resources/application.yml @@ -12,4 +12,6 @@ spring: temp: use_jdbc_metadata_defaults: false interface-name: enp0s31f6 -local-ip: "192.168.0.125" \ No newline at end of file +local-ip: "192.168.0.125" +account-login: BinaryBears +account-password: 123456 \ No newline at end of file