spring cloud單點登錄

来源:https://www.cnblogs.com/demodashi/archive/2018/02/22/8459869.html
-Advertisement-
Play Games

概述 概述 基於springcloud的單點登錄服務及基於zuul的網關服務(解決了通過zuul轉發到認證服務之後session丟失問題) 基於springcloud的單點登錄服務及基於zuul的網關服務(解決了通過zuul轉發到認證服務之後session丟失問題) 詳細 詳細 代碼下載:http: ...


概述

基於springcloud的單點登錄服務及基於zuul的網關服務(解決了通過zuul轉發到認證服務之後session丟失問題)

詳細

代碼下載:http://www.demodashi.com/demo/10313.html

一、準備工作

學習前請先系統的學習一下eureka、zuul、spring security,否則上手可能會比較困難,我當時買的《springcloud微服務實戰》,這本書寫的還不錯。

該項目基於springcloud Dalston.SR1。因公司決定使用spring cloud,前期做認證服務時發現通過zuul網關把請求轉發到認證服務之後session丟失,一直報csrf驗證失敗問題,網上的大部分資料也不靠譜,通過研究解決掉該問題,特做了一個例子,供大家參考

二、項目截圖

blob.png

blob.png

blob.png

三、各個服務說明

① 服務註冊(基於eureka):項目名稱:service-registry-server 埠號:8761

啟動類:cn.com.springcloudtest.cloud.service.registry.ServiceRegistryServerApplication

② 網關服務(基於zuul): 項目名稱:api-gateway-server 埠號:8080

啟動類:cn.com.springcloudtest.cloud.api.gateway.ApiGatewayServerApplication

③ 認證服務(基於oauth2及spring security): 項目名稱:uaa-server 埠號:7769

啟動類:cn.com.springcloudtest.cloud.uaa.UaaServerApplication

認證服務使用redis保存了session,客戶端保存於mysql資料庫

四、配置文件說明

有些配置作者也沒全部搞明白,網上找的設置,但是這麼設置確定是沒問題的

① service-registry-server服務註冊配置信息不再過多描述,標準用法

② api-gateway-server網關服務配置信息

spring:
  aop: #aop代理
    proxyTargetClass: true
  application:
    name: api-gateway-server

server:
  port: 8080
  tomcat:
    uri-encoding: UTF-8

#服務註冊
eureka: 
  client:
    serviceUrl:
      defaultZone: http://127.0.0.1:8761/eureka/
#  server:
#    enable-self-preservation: false  #關閉eureka自我保護,生產環境不建議關閉自我保護

#認證中心index頁面地址,如果直接登錄認證中心則會跳轉到該地址
uaa.server.index-path: /uaa/index
#認證中心跳轉路徑首碼
uaa.server.service.path: /uaa/**
#不走認證的url集合
http.authorize.matchers: /**/css/**,/**/styles/**,/**/js/**,/**/plugin/**,/**/plugins/**,/**/template/**,/**/img/**,/**/fonts/**,/**/cvr100u/**,/css/**,/js/**,/plugin/**,/template/**,/img/**,/fonts/**,/cvr100u/**

#網關信息
zuul:
  routes:
    uaa-server:
      sensitiveHeaders: "*"  #敏感headers也支持全局設置(必須這樣設置)
      path: ${uaa.server.service.path}
      stripPrefix: false
  add-proxy-headers: true  #X-Forwarder-Host請求頭預設添加到轉發請求中

#安全認證信息
security:
  basic:
    enabled: false 
  oauth2:
    sso:
      loginPath: /login
    client:
      accessTokenUri: http://127.0.0.1:7769/uaa/oauth/token
      userAuthorizationUri: /uaa/oauth/authorize
      clientId: acme
      clientSecret: acmesecret
    resource:
      jwt:
        keyValue: |
          -----BEGIN PUBLIC KEY-----
          MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAnGp/Q5lh0P8nPL21oMMrt2RrkT9AW5jgYwLfSUnJVc9G6uR3cXRRDCjHqWU5WYwivcF180A6CWp/ireQFFBNowgc5XaA0kPpzEtgsA5YsNX7iSnUibB004iBTfU9hZ2Rbsc8cWqynT0RyN4TP1RYVSeVKvMQk4GT1r7JCEC+TNu1ELmbNwMQyzKjsfBXyIOCFU/E94ktvsTZUHF4Oq44DBylCDsS1k7/sfZC2G5EU7Oz0mhG8+Uz6MSEQHtoIi6mc8u64Rwi3Z3tscuWG2ShtsUFuNSAFNkY7LkLn+/hxLCu2bNISMaESa8dG22CIMuIeRLVcAmEWEWH5EEforTg+QIDAQAB
          -----END PUBLIC KEY-----
      id: openid
      serviceId: ${PREFIX:}resource

③ uaa-server配置信息

spring:
  application:
    name: uaa-server
  #資料庫連接信息
  datasource:
    url: jdbc:mysql://localhost:3306/uaa?characterEncoding=UTF-8
    username: root
    password: root
    driver-class-name: com.mysql.jdbc.Driver
    max-idle: 5
    max-wait: 10000
    min-idle: 2
    initial-size: 3
    validation-query: SELECT 1
    time-between-eviction-runs-millis: 18800
    jdbc-interceptors: ConnectionState;SlowQueryReport(threshold=50)
  jpa: 
    database: MYSQL
    show-sql: true
  #使用redis存儲session,redis服務地址
  redis:
    host: 127.0.0.1 
    port: 6379
#不緩存thymeleaf模板,開發環境下配置該屬性,生產環境下請勿配置
thymeleaf: 
    cache: false
    cache-period: 0
template: 
    cache: false

server:
  port: 7769
  context-path: /uaa   #認證服務上下文地址(必須配置)
  use-forward-headers: false
  tomcat:
    uri-encoding: UTF-8

#服務註冊
eureka: 
  instance:
    preferIpAddress: true
  client:
    serviceUrl:
      defaultZone: http://127.0.0.1:8761/eureka/

security:
  basic:
    enabled: false
  user:
    password: password
  ignored: /css/**,/js/**,/favicon.ico,/webjars/**
  sessions: NEVER #永遠不自己創建session

#jwt信息(自定義的屬性,AuthorizationServerConfigurer配置類中用到)
jwt:
  access:
    token:
      converter:
        resource:
          location: classpath:keystore.jks
          password: foobar
          key-pair-alias: test
    
#自定義的屬性,WebSecurityConfigurer配置類中用到 
http:
  authorize:
    #不走認證的url集合
    matchers: /**/css/**,/**/js/**,/**/plugin/**,/**/template/**,/**/img/**,/**/fonts/**,/**/cvr100u/**,/css/**,/js/**,/plugin/**,/template/**,/img/**,/fonts/**,/cvr100u/**
  login:
    path: /login

五、java代碼配置

①、api-gateway-server服務配置都集中在WebSecurityConfigurer類中,配置比較簡單

②、uaa-server服務配置都集中在AuthorizationServerConfigurer和WebSecurityConfigurer中,AuthorizationServerConfigurer是jwt相關的配置,WebSecurityConfigurer是安全相關的配置,重要的部分代碼中已經做了註釋

六、項目運行效果

註:項目運行前請閱讀readme.txt文件

用戶名:[email protected] 密碼:admin

blob.png

blob.png

代碼下載:http://www.demodashi.com/demo/10313.html

註:本文著作權歸作者,由demo大師發表,拒絕轉載,轉載需要作者授權

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 數組函數 java.util包的Arrays類中用來操作數組的方法:使用前需導入類import java.util.Arrays; fill() 填充替換數組元素Arrays.fill(arr,8) //將數組arr中的值都變為8 Arrays.fill(arr,1,2,8) //將數組arr中索引 ...
  • OS:windows 10,x64JDK:9.0.4JRE:Java(TM) SE Runtime Environment (build 9.0.4+11)下載及安裝步驟省略新建系統變數JAVA_HOME=jdk安裝路徑JRE_HOME=jre安裝路徑PATH= .;%JAVA_HOME%\bin;... ...
  • 定位記憶體泄漏是C++的一個棘手問題,可行的方法之一如下: 在debug模式下,在輸出中可以看到如下信息: 請註意大括弧{}中的內容,此處是{156},這就是程式可能記憶體泄露的地方。 將上面註釋的代碼加入,並將大括弧中的數字填入,就可以讓程式停在記憶體泄漏的地方。 如下,這裡我讓程式停在156處: 參考 ...
  • package com.xiwi; import java.io.*; import java.util.*; class file{ public static void main(String args[]){ System.out.println("file Go..."); // 這裡改成你... ...
  • 如果父類和子類中存在static方法或者變數, 那麼父類對象指向子類引用的時候, 調用的靜態方法或變數都是父類的static方法或變數,與子類引用無關。 因為static修飾的方法或變數不需要使用對象,只用類名就可以調用, 非static的方法需要對象名才能調用,所以父類對象指向子類引用的時候,調用 ...
  • 巴什博奕 巴什博奕: 兩個頂尖聰明的人在玩游戲,有$n$個石子,每人可以隨便拿$1 m$個石子,不能拿的人為敗者,問誰會勝利 巴什博奕是博弈論問題中基礎的問題 它是最簡單的一種情形對應一種狀態的博弈 博弈分析 我們從最簡單的情景開始分析 當石子有$1 m$個時,毫無疑問,先手必勝 當石子有$m+1$ ...
  • 前言 前面介紹了maven相關的SSH開發的,但是在團隊開發中一般都是各自負責各自的,最後再歸結在一起。所以接下來筆者要學習的就是maven的分模塊開發的相關內容。 一、案例需求 基於上邊的三個工程分析 繼承:創建一個parent工程將所需的依賴都配置在pom中 聚合:聚合多個模塊運行 1.1需求描 ...
  • 一、Mybatis 是什麼 ![][1] MyBatis 是一個支持普通SQL查詢、存儲過程和高級映射的優秀持久層框架。MyBatis 消除了幾乎所有的 JDBC 代碼和參數的手工設置以及對結果集的檢索封裝。MyBatis可以使用簡單的XML或註解用於配置和原始映射,將介面和Java的POJO(Pl ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...