欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

springboot集成CAS實(shí)現(xiàn)單點(diǎn)登錄的示例代碼

 更新時(shí)間:2020年06月22日 10:05:58   作者:Mshu  
這篇文章主要介紹了springboot集成CAS實(shí)現(xiàn)單點(diǎn)登錄的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

最近新參與的項(xiàng)目用到了cas單點(diǎn)登錄,我還不會(huì),這怎么能容忍!空了學(xué)習(xí)并搭建了一個(gè)spring-boot 集成CAS 的demo。實(shí)現(xiàn)了單點(diǎn)登錄與登出。

單點(diǎn)登錄英文全稱是:Single Sign On,簡(jiǎn)稱SSO。
含義:在多個(gè)相互信任的系統(tǒng)中,只要登錄一個(gè)系統(tǒng)其他系統(tǒng)均可訪問(wèn)。

CAS 是一種使用廣泛的單點(diǎn)登錄實(shí)現(xiàn),分為客戶端CAS Client和服務(wù)端 CAS Service,客戶端就是我們的系統(tǒng),服務(wù)端是認(rèn)證中心,由CAS提供,我們需要稍作修改,啟動(dòng)起來(lái)就可以用。~~~~

效果演示

https證書(shū)

CAS Service 需要用https的方式,那么就需要證書(shū),可以買也可以自己生成一個(gè)。
其實(shí)這一步也可以省略,訪問(wèn)的時(shí)候使用http即可,只是cas 會(huì)給警告。

步驟和把大象裝進(jìn)冰箱一樣簡(jiǎn)單,總共三步:

  • 生成密鑰
  • 生成證書(shū)
  • 導(dǎo)入證書(shū)

1. 生成密鑰

keytool -genkey -alias cainiao -keyalg RSA -keystore E:sslcainiao.keystore

參數(shù)說(shuō)明:

  • -genkey 生成密鑰
  • -keyalg 指定密鑰算法,這時(shí)指定RSA
  • -alias 指定別名
  • -keystore 指定密鑰庫(kù)存儲(chǔ)位置,這里存在 E:/ssl/目錄下

在執(zhí)行中會(huì)問(wèn)你很多問(wèn)題,當(dāng)問(wèn)到 :您的名字與姓氏是什么?
此時(shí)需要填寫(xiě)域名,作為之后的訪問(wèn)地址,其他隨意。
執(zhí)行完后生成一個(gè)密鑰文件 cainiao.keystore

2. 生成證書(shū)

keytool -export -alias cainiao -storepass 123456 -file E:/ssl/cainiao.cer -keystore E:/ssl/cainiao.keystore

參數(shù)說(shuō)明:

-storepass 剛剛生成密鑰文件時(shí)候的設(shè)置的密碼
-file指定導(dǎo)出證書(shū)的文件名為cainiao.cer
-keystore指定之前生成的密鑰文件的文件名

執(zhí)行完后目錄下會(huì)生成一個(gè)cainiao.cer證書(shū)

3. 導(dǎo)入證書(shū)

keytool -import -alias cainiao -keystore C:/"Program Files"/Java/jdk1.8.0_181/jre/lib/security/cacerts -file E:/ssl/cainiao.cer -trustcacerts

將證書(shū)導(dǎo)入到JDK信任庫(kù)
把原來(lái)的$JAVA_HOME/jre/lib/security/cacerts文件要先刪掉,否則會(huì)報(bào)出 Keystore was tampered with, or password was incorrect.

下面是整個(gè)過(guò)程:

PS E:\ssl> keytool -genkey -alias cainiao -keyalg RSA -keystore E:\ssl\cainiao.keystore
輸入密鑰庫(kù)口令:
再次輸入新口令:
您的名字與姓氏是什么?
 [Unknown]: www.cainiao.com
您的組織單位名稱是什么?
 [Unknown]: cainian
您的組織名稱是什么?
 [Unknown]: cainiao
您所在的城市或區(qū)域名稱是什么?
 [Unknown]: wx
您所在的省/市/自治區(qū)名稱是什么?
 [Unknown]: js
該單位的雙字母國(guó)家/地區(qū)代碼是什么?
 [Unknown]: CN
CN=www.cainiao.com, OU=cainian, O=cainiao, L=wx, ST=js, C=CN是否正確?
 [否]: y

輸入 <cainiao> 的密鑰口令
  (如果和密鑰庫(kù)口令相同, 按回車):
再次輸入新口令:

------------------------------------------------------------------------------------

PS E:\ssl> keytool -export -alias cainiao -storepass 123456 -file E:/ssl/cainiao.cer -keystore E:/ssl/cainiao.keystore
存儲(chǔ)在文件 <E:/ssl/cainiao.cer> 中的證書(shū)

------------------------------------------------------------------------------------

PS E:\ssl> keytool -import -alias cainiao -keystore C:/"Program Files"/Java/jdk1.8.0_181/jre/lib/security/cacerts -file E:/ssl/cainiao.cer -trustcacerts
輸入密鑰庫(kù)口令:
所有者: CN=www.cainiao.com, OU=cainian, O=cainiao, L=wx, ST=js, C=CN
發(fā)布者: CN=www.cainiao.com, OU=cainian, O=cainiao, L=wx, ST=js, C=CN
序列號(hào): 509d1aea
有效期為 Wed Jun 17 22:02:55 CST 2020 至 Tue Sep 15 22:02:55 CST 2020
證書(shū)指紋:
   MD5: 5B:B2:7C:D7:B7:31:C5:7C:1C:BC:F7:DA:A8:2D:1C:B2
   SHA1: F6:76:55:55:D7:48:E3:9F:3A:B6:EE:68:1F:BE:DC:DE:51:B1:33:E5
   SHA256: 24:53:18:CD:E8:95:65:D8:6E:6A:7B:8E:79:CB:91:BD:F4:2E:C3:99:59:D1:76:12:A8:95:45:2A:4B:03:E4:AD
簽名算法名稱: SHA256withRSA
主體公共密鑰算法: 2048 位 RSA 密鑰
版本: 3

擴(kuò)展:

#1: ObjectId: 2.5.29.14 Criticality=false
SubjectKeyIdentifier [
KeyIdentifier [
0000: 70 B3 D5 76 36 EA 54 BA 75 C1 A1 5C DA 76 82 0E p..v6.T.u..\.v..
0010: 4D F4 C9 05          M...
]
]

是否信任此證書(shū)? [否]: y
證書(shū)已添加到密鑰庫(kù)中

最后,hosts 配置 127.0.0.1 www.cainiao.com

搭建CAS service

需要從github上拉取模板 https://github.com/apereo/cas-overlay-template
5.3之后的都是gradle項(xiàng)目,5.3以之前都是maven 項(xiàng)目,我下載5.3版本的。

1.> 把pom 里面的<repositories>倉(cāng)庫(kù)地址去掉,國(guó)外的倉(cāng)庫(kù)地址比較慢。你懂得。
2.> 在根目錄下建/src/main/resources目錄
3.> 將生成的密鑰文件復(fù)制到/src/main/resources目錄下
4.> 將overlays/org.apereo.cas.cas-server-webapp-tomcat-5.3.14/WEB-INF/classes/application.properties文件復(fù)制到第二步建的目錄下。
5.> 修改復(fù)制過(guò)來(lái)的/src/main/resources/application.properties文件,根據(jù)上面的證書(shū)信息如實(shí)填寫(xiě)。

server.ssl.key-store=classpath:cainiao.keystore
server.ssl.key-store-password=123456
server.ssl.key-password=123456

6.> 連接mysql數(shù)據(jù)庫(kù),在pom 中添加依賴

<dependency>
  <groupId>org.apereo.cas</groupId>
  <artifactId>cas-server-support-jdbc</artifactId>
  <version>${cas.version}</version>
</dependency>
<dependency>
  <groupId>mysql</groupId>
  <artifactId>mysql-connector-java</artifactId>
  <version>5.1.21</version>
</dependency>

或許你會(huì)發(fā)現(xiàn)有個(gè)xmlsectool-2.0.0.jar包下不下來(lái),這是阿里云的倉(cāng)庫(kù)沒(méi)有,需要到maven中央倉(cāng)庫(kù)下載,后安裝到本地倉(cāng)庫(kù),可不是直接放到本地倉(cāng)庫(kù),jar包都是必須使用命令安裝到本地倉(cāng)庫(kù)。

mvn install:install-file -Dfile="E:下載xmlsectool-2.0.0.jar" "-DgroupId=net.shibboleth.tool" "-DartifactId=xmlsectool" "-Dversion=2.0.0" "-Dpackaging=jar"

安裝jar包到本地倉(cāng)庫(kù)筆記

7.> 在復(fù)制過(guò)來(lái)的/src/main/resources/application.properties文件中在添加如下信息

#查詢賬號(hào)密碼sql,必須包含密碼字段
cas.authn.jdbc.query[0].sql=select * from sys_user where username=?
#指定上面的sql查詢字段名(必須)
cas.authn.jdbc.query[0].fieldPassword=password
#指定過(guò)期字段,1為過(guò)期,若過(guò)期需要修改密碼
cas.authn.jdbc.query[0].fieldExpired=expired
#為不可用字段段,1為不可用,
cas.authn.jdbc.query[0].fieldDisabled=disabled
#數(shù)據(jù)庫(kù)方言hibernate的知識(shí)
cas.authn.jdbc.query[0].dialect=org.hibernate.dialect.MySQLDialect
#數(shù)據(jù)庫(kù)驅(qū)動(dòng)
cas.authn.jdbc.query[0].driverClass=com.mysql.jdbc.Driver
#數(shù)據(jù)庫(kù)連接 
cas.authn.jdbc.query[0].url=jdbc:mysql://localhost:3306/cas?useUnicode=true&characterEncoding=UTF-8
#數(shù)據(jù)庫(kù)用戶名
cas.authn.jdbc.query[0].user=root
#數(shù)據(jù)庫(kù)密碼
cas.authn.jdbc.query[0].password=123456
#默認(rèn)加密策略,通過(guò)encodingAlgorithm來(lái)指定算法,默認(rèn)NONE不加密
cas.authn.jdbc.query[0].passwordEncoder.type=DEFAULT
cas.authn.jdbc.query[0].passwordEncoder.characterEncoding=UTF-8
cas.authn.jdbc.query[0].passwordEncoder.encodingAlgorithm=MD5

附上數(shù)據(jù)庫(kù)sql,用戶信息表

-- ----------------------------
-- Table structure for sys_user
-- ----------------------------
DROP TABLE IF EXISTS `sys_user`;
CREATE TABLE `sys_user` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `username` varchar(255) DEFAULT NULL,
 `password` varchar(255) DEFAULT NULL,
 `expired` int(11) DEFAULT NULL,
 `disabled` int(11) DEFAULT NULL,
 PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;

-- ----------------------------
-- Records of sys_user
-- ----------------------------
INSERT INTO `sys_user` VALUES ('1', 'admin', '21232f297a57a5a743894a0e4a801fc3', '0', '1');
INSERT INTO `sys_user` VALUES ('2', 'cainiao', '6b757206058785025cd90c8d865c8e43', '1', '0');
INSERT INTO `sys_user` VALUES ('3', 'mashu', 'd1f21ceb3f710ebbd9f408274aee1193', '0', '0');

用戶名和密碼一樣,密碼在數(shù)據(jù)庫(kù)中是MD5加密的。
這樣就完成了CAS service 的搭建,在根目錄使用 build.cmd run 命令啟動(dòng)
出現(xiàn) READY 的branner就啟動(dòng)好了 訪問(wèn)地址 https://www.cainiao.com:8443/cas/login

mashu正常登錄,cainiao需要修改密碼,admin被禁用,符合預(yù)期。

搭建CAS client

創(chuàng)建一個(gè)spring boot 項(xiàng)目.
1.加入cas 客戶端 的依賴, 我選擇目前最新的 2.3.0-GA 版本

<dependency>
 <groupId>net.unicon.cas</groupId>
 <artifactId>cas-client-autoconfig-support</artifactId>
 <version>2.3.0-GA</version>  
</dependency>

2.在啟動(dòng)類上加上注解 @EnableCasClient
3.在application.properties中添加配置

#cas服務(wù)端的地址
cas.server-url-prefix=https://www.cainiao.com:8443/cas
#cas服務(wù)端的登錄地址
cas.server-login-url=https://www.cainiao.com:8443/cas/login
#客戶端訪問(wèn)地址
cas.client-host-url=http://www.mashu.com:8080
cas.validation-type=CAS3

4.添加hosts 配置,把客戶端的訪問(wèn)地址配置到hosts

127.0.0.1 www.mashu.com

這樣就客戶端就配置好了。

單點(diǎn)登錄

我寫(xiě)一個(gè)controller,訪問(wèn)一下。

@RestController
public class TestController {

 @RequestMapping("/hello")
 public String hello() {
  return "word";
 }
}

訪問(wèn) http://www.mashu.com:8080/hello

未認(rèn)證授權(quán)的服務(wù)

喜提報(bào)錯(cuò):

原因是服務(wù)端不允許客戶端的http協(xié)議的請(qǐng)求。需要對(duì)服務(wù)端做以下修改,讓他妥協(xié)。
1.>修改overlays/org.apereo.cas.cas-server-webapp-tomcat-5.3.14/WEB-INF/classes/services/HTTPSandIMAPS-10000001.json文件

"serviceId" 由原來(lái)的"^(https|imaps)://.*"改成 "^(https|imaps|http)://.*"

2.>在application.properties文件中添加:

#允許http
cas.tgc.secure=false
cas.serviceRegistry.initFromJson=true

再次訪問(wèn) http://www.mashu.com:8080/hello,可以看到已經(jīng)帶著地址轉(zhuǎn)發(fā)到服務(wù)端的登錄頁(yè)。

輸入賬號(hào)密碼mashu/mashu,登錄成功后又回來(lái)了!哈哈哈哈嗝,并攜帶了登錄憑證。

多系統(tǒng)登錄

再啟動(dòng)一個(gè)客戶端,打開(kāi)idea 的edit configurations設(shè)置。勾選 Allow parallel run

修改application.properties,服務(wù)的端口等信息,再點(diǎn)擊啟動(dòng),就可以同時(shí)啟動(dòng)了(8081/8080)兩個(gè)客戶端

server.port=8081
#cas服務(wù)端的地址
cas.server-url-prefix=https://www.cainiao.com:8443/cas
#cas服務(wù)端的登錄地址
cas.server-login-url=https://www.cainiao.com:8443/cas/login
#客戶端訪問(wèn)地址
cas.client-host-url=http://www.mshu.com:8081
cas.validation-type=CAS3

訪問(wèn)第二個(gè)客戶端 http://www.mshu.com:8081/hello,(需要先配置host),就直接登錄了,到此完成了單點(diǎn)登錄。

點(diǎn)單登出

添加兩個(gè)配置文件;

1. CasProperties.java

import org.springframework.boot.context.properties.ConfigurationProperties;
import javax.validation.constraints.NotNull;

@ConfigurationProperties(prefix = "cas",ignoreUnknownFields = true)
public class CasProperties {

 /**
  * CAS server URL E.g. https://example.com/cas or https://cas.example. Required.
  * CAS 服務(wù)端 url 不能為空
  */
 @NotNull
 private String serverUrlPrefix;

 /**
  * CAS server login URL E.g. https://example.com/cas/login or https://cas.example/login. Required.
  * CAS 服務(wù)端登錄地址 上面的連接 加上/login 該參數(shù)不能為空
  */
 @NotNull
 private String serverLoginUrl;

 /**
  * CAS-protected client application host URL E.g. https://myclient.example.com Required.
  * 當(dāng)前客戶端的地址
  */
 @NotNull
 private String clientHostUrl;

 /**
  * 忽略規(guī)則,訪問(wèn)那些地址 不需要登錄
  */
 private String ignorePattern;

 /**
  * 自定義UrlPatternMatcherStrategy驗(yàn)證
  */
 private String ignoreUrlPatternType;

 public String getServerUrlPrefix() {
  return serverUrlPrefix;
 }

 public void setServerUrlPrefix(String serverUrlPrefix) {
  this.serverUrlPrefix = serverUrlPrefix;
 }

 public String getServerLoginUrl() {
  return serverLoginUrl;
 }

 public void setServerLoginUrl(String serverLoginUrl) {
  this.serverLoginUrl = serverLoginUrl;
 }

 public String getClientHostUrl() {
  return clientHostUrl;
 }

 public void setClientHostUrl(String clientHostUrl) {
  this.clientHostUrl = clientHostUrl;
 }

 public String getIgnorePattern() {
  return ignorePattern;
 }

 public void setIgnorePattern(String ignorePattern) {
  this.ignorePattern = ignorePattern;
 }

 public String getIgnoreUrlPatternType() {
  return ignoreUrlPatternType;
 }

 public void setIgnoreUrlPatternType(String ignoreUrlPatternType) {
  this.ignoreUrlPatternType = ignoreUrlPatternType;
 }
}

2. Configs.java

import org.jasig.cas.client.authentication.AuthenticationFilter;
import org.jasig.cas.client.session.SingleSignOutFilter;
import org.jasig.cas.client.session.SingleSignOutHttpSessionListener;
import org.jasig.cas.client.util.HttpServletRequestWrapperFilter;
import org.jasig.cas.client.validation.Cas30ProxyReceivingTicketValidationFilter;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.context.properties.EnableConfigurationProperties;
import org.springframework.boot.web.servlet.FilterRegistrationBean;
import org.springframework.boot.web.servlet.ServletListenerRegistrationBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import java.util.EventListener;
import java.util.HashMap;
import java.util.Map;

@Configuration
@EnableConfigurationProperties(CasProperties.class)
public class Configs {

 @Autowired
 private CasProperties configProps;

 /**
  * 配置登出過(guò)濾器
  * @return
  */
 @Bean
 public FilterRegistrationBean filterSingleRegistration() {
  final FilterRegistrationBean registration = new FilterRegistrationBean();
  registration.setFilter(new SingleSignOutFilter());
  // 設(shè)定匹配的路徑
  registration.addUrlPatterns("/*");
  Map<String,String> initParameters = new HashMap<String, String>();
  initParameters.put("casServerUrlPrefix", configProps.getServerUrlPrefix());
  registration.setInitParameters(initParameters);
  // 設(shè)定加載的順序
  registration.setOrder(1);
  return registration;
 }

 /**
  * 配置過(guò)濾驗(yàn)證器 這里用的是Cas30ProxyReceivingTicketValidationFilter
  * @return
  */
 @Bean
 public FilterRegistrationBean filterValidationRegistration() {
  final FilterRegistrationBean registration = new FilterRegistrationBean();
  registration.setFilter(new Cas30ProxyReceivingTicketValidationFilter());
  // 設(shè)定匹配的路徑
  registration.addUrlPatterns("/*");
  Map<String,String> initParameters = new HashMap<String, String>();
  initParameters.put("casServerUrlPrefix", configProps.getServerUrlPrefix());
  initParameters.put("serverName", configProps.getClientHostUrl());
  initParameters.put("useSession", "true");
  registration.setInitParameters(initParameters);
  // 設(shè)定加載的順序
  registration.setOrder(2);
  return registration;
 }

 /**
  * 配置授權(quán)過(guò)濾器
  * @return
  */
 @Bean
 public FilterRegistrationBean filterAuthenticationRegistration() {
  final FilterRegistrationBean registration = new FilterRegistrationBean();
  registration.setFilter(new AuthenticationFilter());
  // 設(shè)定匹配的路徑
  registration.addUrlPatterns("/*");
  Map<String,String> initParameters = new HashMap<String, String>();
  initParameters.put("casServerLoginUrl", configProps.getServerLoginUrl());
  initParameters.put("serverName", configProps.getClientHostUrl());

  if(configProps.getIgnorePattern() != null && !"".equals(configProps.getIgnorePattern())){
   initParameters.put("ignorePattern", configProps.getIgnorePattern());
  }

  //自定義UrlPatternMatcherStrategy 驗(yàn)證規(guī)則
  if(configProps.getIgnoreUrlPatternType() != null && !"".equals(configProps.getIgnoreUrlPatternType())){
   initParameters.put("ignoreUrlPatternType", configProps.getIgnoreUrlPatternType());
  }

  registration.setInitParameters(initParameters);
  // 設(shè)定加載的順序
  registration.setOrder(3);
  return registration;
 }

 /**
  * request wraper過(guò)濾器
  * @return
  */
 @Bean
 public FilterRegistrationBean filterWrapperRegistration() {
  final FilterRegistrationBean registration = new FilterRegistrationBean();
  registration.setFilter(new HttpServletRequestWrapperFilter());
  // 設(shè)定匹配的路徑
  registration.addUrlPatterns("/*");
  // 設(shè)定加載的順序
  registration.setOrder(4);
  return registration;
 }

 /**
  * 添加監(jiān)聽(tīng)器
  * @return
  */
 @Bean
 public ServletListenerRegistrationBean<EventListener> singleSignOutListenerRegistration(){
  ServletListenerRegistrationBean<EventListener> registrationBean = new ServletListenerRegistrationBean<EventListener>();
  registrationBean.setListener(new SingleSignOutHttpSessionListener());
  registrationBean.setOrder(1);
  return registrationBean;
 }
}

登出地址: https://www.cainiao.com:8443/cas/logout,退出服務(wù)端。
再次訪問(wèn)客戶端發(fā)現(xiàn)自動(dòng)跳到了登錄頁(yè)面,即客戶端也自動(dòng)退出成功。

一些問(wèn)題

最開(kāi)始我想把客戶端也加一個(gè)證書(shū),用https訪問(wèn)。免得在服務(wù)端做修改去支持http,
當(dāng)我添加證書(shū)后,單點(diǎn)登錄正常,但是登出功能總是失敗,表現(xiàn)為服務(wù)端退出,客戶端沒(méi)有退出。
我一直以為客戶端配置的登出有問(wèn)題,搞了半天都沒(méi)成功,后來(lái)我把客戶端的證書(shū)去掉,就成功了。想了想大概是因?yàn)槲覀冏约荷傻淖C書(shū)不能被服務(wù)端認(rèn)可,因?yàn)榈浅龅臅r(shí)候需要服務(wù)端向客戶端發(fā)起廣播,而我們之前修改的HTTPSandIMAPS-10000001.json文件只是作用于客戶端向服務(wù)端的請(qǐng)求。和登出相反。

在我使用springboot配置證書(shū)的時(shí)候,2.1.0.RELEASE以上版本的spring-boot-starter-parent都不行。會(huì)報(bào)錯(cuò)。

到此這篇關(guān)于springboot集成CAS實(shí)現(xiàn)單點(diǎn)登錄的示例代碼的文章就介紹到這了,更多相關(guān)springboot集成CAS單點(diǎn)登錄內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解springboot整合ueditor踩過(guò)的坑

    詳解springboot整合ueditor踩過(guò)的坑

    這篇文章主要介紹了詳解springboot整合ueditor踩過(guò)的坑,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • java 中List刪除實(shí)例詳解

    java 中List刪除實(shí)例詳解

    這篇文章主要介紹了java 中List刪除實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • Java JSch遠(yuǎn)程執(zhí)行Shell命令的方法

    Java JSch遠(yuǎn)程執(zhí)行Shell命令的方法

    本文主要介紹了Java JSch遠(yuǎn)程執(zhí)行Shell命令,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • IDEA插件之mybatisx插件使用教程(超詳細(xì)!)

    IDEA插件之mybatisx插件使用教程(超詳細(xì)!)

    MybatisX 是一款基于IDEA的快速開(kāi)發(fā)插件,為效率而生,下面這篇文章主要給大家介紹了關(guān)于IDEA插件之mybatisx插件使用的相關(guān)資料,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-06-06
  • SpringCloud中的Eureka注冊(cè)中心詳細(xì)解讀

    SpringCloud中的Eureka注冊(cè)中心詳細(xì)解讀

    這篇文章主要介紹了SpringCloud中的Eureka注冊(cè)中心詳細(xì)解讀,想要參與服務(wù)注冊(cè)發(fā)現(xiàn)的實(shí)例首先需要向Eureka服務(wù)器注冊(cè)信息,注冊(cè)在第一次心跳發(fā)生時(shí)提交,需要的朋友可以參考下
    2023-11-11
  • Java以編程方式實(shí)現(xiàn)JAR文件的創(chuàng)建

    Java以編程方式實(shí)現(xiàn)JAR文件的創(chuàng)建

    在這篇文章中,我們將為大家詳細(xì)介紹一下利用Java語(yǔ)言以編程方式創(chuàng)建jar文件的過(guò)程。文中的示例代碼講解詳細(xì),感興趣的可以了解一下
    2022-07-07
  • java 非常好用的反射框架Reflections介紹

    java 非常好用的反射框架Reflections介紹

    這篇文章主要介紹了java 反射框架Reflections的使用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-04-04
  • SpringBoot開(kāi)發(fā)中使用DTO層的方法示例

    SpringBoot開(kāi)發(fā)中使用DTO層的方法示例

    DTO層是在應(yīng)用程序的業(yè)務(wù)邏輯層和數(shù)據(jù)訪問(wèn)層之間引入的一個(gè)中間層,用于在不同層之間傳輸數(shù)據(jù),本文主要介紹了SpringBoot開(kāi)發(fā)中使用DTO層,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-06-06
  • Mybatis @SelectKey用法解讀

    Mybatis @SelectKey用法解讀

    這篇文章主要介紹了Mybatis @SelectKey用法解讀,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • JAVA多線程知識(shí)匯總

    JAVA多線程知識(shí)匯總

    這篇文章主要介紹了JAVA多線程的相關(guān)資料,文中講解非常細(xì)致,代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07

最新評(píng)論