您好,登錄后才能下訂單哦!
這期內容當中小編將會給大家帶來有關Springboot2.X如何解決單點登陸,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
<dependency> <groupId>com.majiaxueyuan</groupId> <artifactId>sso-core</artifactId> <version>1.2.2</version> </dependency>
由于使用的是springboot2.2.0版本,所以配置需要實現WebMvcConfigurer
import com.majiaxueyuan.sso.core.filter.MaJiaSSOIntercepter; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.web.servlet.config.annotation.InterceptorRegistry; import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; /** * @Author:MuJiuTian * @Description: 單點登陸配置WebMvcConfigurer * @Date: Created in 下午5:34 2019/10/21 */ @Configuration public class SsoConfig implements WebMvcConfigurer { @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(ssoIntercepter()).addPathPatterns("/**"); } @Bean public MaJiaSSOIntercepter ssoIntercepter() { return new MaJiaSSOIntercepter().setTokenSalt("pwd_salt"); } }
如果是其他版本可以使用集成WebMvcConfigurerAdapter
import com.majiaxueyuan.sso.core.filter.MaJiaSSOIntercepter; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.web.servlet.config.annotation.InterceptorRegistry; import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter; /** * @Author:MuJiuTian * @Description: 單點登陸配置WebMvcConfigurerAdapter * @Date: Created in 下午5:34 2019/10/21 */ @Configuration public class SsoConfig extends WebMvcConfigurerAdapter { @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(ssoIntercepter()).addPathPatterns("/**"); } @Bean public MaJiaSSOIntercepter ssoIntercepter() { return new MaJiaSSOIntercepter().setTokenSalt("pwd_salt"); } }
@Data @AllArgsConstructor @NoArgsConstructor public class User { private int userId; private String slat; private String account; // ....其他的字段就不寫了 }
/** * @Author:MuJiuTian * @Description: 簡單測試,我就不寫接口了,直接以class的形式 * @Date: Created in 下午5:47 2019/10/21 */ @Service public class LoginService { public User checkUser(String account, String pwd){ // 做假數據,加入密碼登陸成功,返回user實體類 return new User(1,account,"ewdsbj"); } }
import com.majiaxueyuan.sso.core.annotation.NoToken; import com.majiaxueyuan.sso.core.constans.Result; import com.majiaxueyuan.sso.core.helper.TokenLoginHelper; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RestController; /** * @Author:MuJiuTian * @Description: 測試單點登錄框架 * @Date: Created in 下午5:25 2019/10/21 */ @RestController public class LoginController { @Autowired LoginService loginService; @GetMapping(value = "/testToken") public String testToken() { return "需要token"; } @GetMapping(value = "/login") @NoToken(notNeedToken = true) public String login(String account, String password) { // 測試用戶輸入的用戶名、密碼是否正確 User user = loginService.checkUser(account, password); if (user == null){ return "密碼錯誤"; } // 如果密碼成功后,獲取用戶主鍵id、以及注冊時的salt Long user_id = Long.valueOf(user.getUserId()); String salt = user.getSlat(); // 然后通過sso-core框架獲取token Result loginSuccess = TokenLoginHelper.loginSuccess(user_id,account,"",salt); // 獲取token String token = ""; if (loginSuccess.getCode() == 200){ token = loginSuccess.getData().toString(); } return token; } }
測試接口1:
測試接口2:
用戶獲取到Token之后,返回給前端,前端攜帶時需要將Token添加到Header中的Authorization字段。當前強制使用此請求頭字段,這些數據存儲headers中帶過來檢測token是否過期或者登陸...情況。
SSOUser user = (SSOUser) request.getAttribute("ssoUser");
當有某個請求不需要認證即可訪問時,在此請求方法上添加注解@NoToken,不加注解需要驗證,只要加上注解就表示不需要認證,不管@NoToken(notNeedToken = true)還是@NoToken(notNeedToken = false),都不需要驗證,至少在目前最新1.2.2版本是這樣。
上述就是小編為大家分享的Springboot2.X如何解決單點登陸了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。