登录

整合spring cloud云架构 - commonservice-sso服务搭建(一)

皮皮万 Java技术

前面几篇我们已经介绍了Spring Cloud和oauth2的知识点,今天我们要利用Spring Cloud和oauth2进行commonservice-sso服务搭建,本节我们只是搭建commonservice-sso的基础平台,闲话少说,直接将步骤记录下来:

1. 创建maven项目commonservice-sso,其中pom.xml文件配置如下:

Xml代码  

  

  

    4.0.0  

      

      

        com.ml.honghu  

        commonservice  

        0.0.1-SNAPSHOT  

      

  

    commonservice-sso  

    jar  

  

      

          

            org.springframework.cloud  

            spring-cloud-starter-eureka  

          

          

            org.springframework.cloud  

            spring-cloud-starter-config  

          

          

            org.springframework.boot  

            spring-boot-starter-actuator  

          

          

            org.springframework.boot  

            spring-boot-starter-data-rest  

          

          

            org.springframework.boot  

            spring-boot-starter-web  

          

          

            org.springframework.boot  

            spring-boot-starter-security  

          

  

          

            org.springframework.security.oauth  

            spring-security-oauth2  

          

  

          

            org.springframework.boot  

            spring-boot-starter-test  

          

          

            org.springframework.hateoas  

            spring-hateoas  

          

          

            org.springframework.boot  

            spring-boot-starter-data-rest  

          

          

            com.ml.honghu.common.framework  

            common-framework-dao  

            1.0.0-SNAPSHOT  

          

          

            org.springframework.boot  

            spring-boot-starter-web  

          

          

            org.springframework.boot  

            spring-boot-starter-freemarker  

          

          

            com.ml.honghu  

            component-bbse  

          

          

      

  

      

      

          

              

                org.springframework.boot  

                spring-boot-maven-plugin  

                  

                      

                        1  

                          

                            repackage  

                          

                      

                      

                        2  

                          

                            build-info  

                          

                      

                  

              

          

      

  

 2. 配置bootstrap.yml文件

Xml代码  

spring:  

  application:  

    name: commonservice-sso  

  profiles:   

    active: dev,discoveryClient  

  cloud:  

    config:  

      discovery:   

        enabled: true  

        service-id: commonservice-config-server  

eureka:   

  client:  

    service-url:  

      defaultZone: http://honghu:123456@localhost:8761/eureka  

  instance:  

    prefer-ip-address: true  

 3. 配置项目启动文件

Java代码  

package com.ml.honghu;  

  

import org.springframework.boot.SpringApplication;  

import org.springframework.boot.autoconfigure.SpringBootApplication;  

import org.springframework.cloud.netflix.eureka.EnableEurekaClient;  

  

@SpringBootApplication  

@EnableEurekaClient  

public class SSOApplication {  

    public static void main(String[] args) {  

        SpringApplication.run(SSOApplication.class, args);  

    }  

}  

 4. 创建sso相关表:

oauth_access_token、oauth_approvals、

oauth_client_details、oauth_client_token、

oauth_code、oauth_refresh_token

 

脚本如下:

Java代码  

/* 

Navicat MySQL Data Transfer 

 

Source Server         : localhost 

Source Server Version : 50621 

Source Host           : localhost:3306 

Source Databbse       : honghu 

 

Target Server Type    : MYSQL 

Target Server Version : 50621 

File Encoding         : 65001 

 

Date: 2017-10-26 20:12:56 

*/  

  

SET FOREIGN_KEY_CHECKS=0;  

  

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

-- Table structure for `oauth_access_token`  

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

DROP TABLE IF EXISTS `oauth_access_token`;  

CREATE TABLE `oauth_access_token` (  

  `token_id` varchar(256) DEFAULT NULL,  

  `token` blob,  

  `authentication_id` varchar(128) NOT NULL,  

  `user_name` varchar(256) DEFAULT NULL,  

  `client_id` varchar(256) DEFAULT NULL,  

  `authentication` blob,  

  `refresh_token` varchar(256) DEFAULT NULL,  

  PRIMARY KEY (`authentication_id`)  

) ENGINE=InnoDB DEFAULT CHARSET=utf8;  

  

  

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

-- Table structure for `oauth_approvals`  

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

DROP TABLE IF EXISTS `oauth_approvals`;  

CREATE TABLE `oauth_approvals` (  

  `userId` varchar(256) DEFAULT NULL,  

  `clientId` varchar(256) DEFAULT NULL,  

  `scope` varchar(256) DEFAULT NULL,  

  `status` varchar(10) DEFAULT NULL,  

  `expiresAt` datetime DEFAULT NULL,  

  `lastModifiedAt` datetime DEFAULT NULL  

) ENGINE=InnoDB DEFAULT CHARSET=utf8;  

  

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

-- Records of oauth_approvals  

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

  

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

-- Table structure for `oauth_client_details`  

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

DROP TABLE IF EXISTS `oauth_client_details`;  

CREATE TABLE `oauth_client_details` (  

  `client_id` varchar(128) NOT NULL,  

  `resource_ids` varchar(256) DEFAULT NULL,  

  `client_secret` varchar(256) DEFAULT NULL,  

  `scope` varchar(256) DEFAULT NULL,  

  `authorized_grant_types` varchar(256) DEFAULT NULL,  

  `web_server_redirect_uri` varchar(256) DEFAULT NULL,  

  `authorities` varchar(256) DEFAULT NULL,  

  `access_token_validity` int(11) DEFAULT NULL,  

  `refresh_token_validity` int(11) DEFAULT NULL,  

  `additional_information` varchar(4096) DEFAULT NULL,  

  `autoapprove` varchar(256) DEFAULT NULL,  

  PRIMARY KEY (`client_id`)  

) ENGINE=InnoDB DEFAULT CHARSET=utf8;  

  

  

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

-- Table structure for `oauth_client_token`  

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

DROP TABLE IF EXISTS `oauth_client_token`;  

CREATE TABLE `oauth_client_token` (  

  `token_id` varchar(256) DEFAULT NULL,  

  `token` blob,  

  `authentication_id` varchar(128) NOT NULL,  

  `user_name` varchar(256) DEFAULT NULL,  

  `client_id` varchar(256) DEFAULT NULL,  

  PRIMARY KEY (`authentication_id`)  

) ENGINE=InnoDB DEFAULT CHARSET=utf8;  

  

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

-- Records of oauth_client_token  

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

  

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

-- Table structure for `oauth_code`  

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

DROP TABLE IF EXISTS `oauth_code`;  

CREATE TABLE `oauth_code` (  

  `code` varchar(256) DEFAULT NULL,  

  `authentication` blob  

) ENGINE=InnoDB DEFAULT CHARSET=utf8;  

  

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

-- Records of oauth_code  

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

  

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

-- Table structure for `oauth_refresh_token`  

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

DROP TABLE IF EXISTS `oauth_refresh_token`;  

CREATE TABLE `oauth_refresh_token` (  

  `token_id` varchar(256) DEFAULT NULL,  

  `token` blob,  

  `authentication` blob  

) ENGINE=InnoDB DEFAULT CHARSET=utf8;  

 备注: oauth的相关表是用来存储用户的token信息和认证信息的。

 

本节搭建先搭建那么多,后面的业务代码太多,我们会在后面的章节中放出来。

展开全文
打开APP,一键看同内容文章>

相关推荐

最新问答

查看更多问答
反馈