作者:Eddy 历史版本:1 最后编辑:龚清 更新时间:2024-09-20 15:09
外部业务框架如何接入IBPS3.x接口权限控制
外部业务框架(非IBPS3.x框架开发)如何接入IBPS-V3接口权限
接入说明
- 本文档适用于IBPS-v3.2.0及以上版本;
- 注册到IBPS-V3服务发现;
- 引入IBPS-V3权限客户端依赖;
- 添加swagger、权限相关配置;
- 在IBPS-V3系统-系统管理-接口授权进行接口授权;
接入步骤
添加依赖
服务发现
<dependency> <groupId>com.lc.ibps.cloud</groupId> <artifactId>ibps-basic-discovery</artifactId> <version>当前版本号</version> </dependency>
公共依赖
<dependency>
<groupId>com.lc.ibps.cloud</groupId>
<artifactId>ibps-basic-response</artifactId>
<version>当前版本号</version>
<exclusions>
<exclusion>
<groupId>*</groupId>
<artifactId>*</artifactId>
</exclusion>
</exclusions>
</dependency>
权限客户端
<dependency> <groupId>com.lc.ibps.cloud</groupId> <artifactId>ibps-oauth-client2</artifactId> <version>当前版本号</version> <exclusions> <exclusion> <groupId>net.oschina.j2cache</groupId> <artifactId>j2cache-mybatis</artifactId> </exclusion> </exclusions> </dependency> <dependency> <groupId>com.lc.ibps.provider.base</groupId> <artifactId>ibps-provider-platform-client</artifactId> <version>当前版本号</version> </dependency> <dependency> <groupId>com.lc.ibps.base</groupId> <artifactId>ibps-base-web</artifactId> <version>当前版本号</version> </dependency>
添加swagger依赖
<dependency> <groupId>com.lc.ibps.cloud</groupId> <artifactId>ibps-basic-swagger</artifactId> <version>当前版本号</version> </dependency>
添加配置
服务发现
- 请参考application-dev-consul.yml或application-dev-eureka.yml或application-dev-zookeeper.yml配置服务发现链接;
接口授权配置
- 添加swagger配置
swagger:
terms-of-service-url : http://www.bpmhome.cn
contact-name: 广州流辰信息技术有限公司
contact-url: http://www.bpmhome.cn
contact-email: <联系邮箱>
version: <当前版本>
base-package: <扫描包名,可配置多个使用英文逗号分割即可>
docs: v2/api-docs
string-extensions:
- name: appId
value: ${spring.application.name}
- IBPS-V3会自动导入接口;
- 在系统界面,系统管理-接口授权,对业务系统的接口进行授权即可;
其他配置
关闭IBPS3框架中Mybatis的bean注入
com: lc: db: mybatis: enabled: false
ID生成策略信息
id: # 工作ID (0~31) workerId: ${ID_WORKER_ID:0} # 数据中心ID (0~31) datacenterId: ${ID_DATACENTER_ID:0}
bean注入配置
- 复制Demo工程中的ibps-context.xml、ibps-resources.xml到项目的conf目录下。
- 在非启动类的Configure类中使用
@ImportResource(locations={"classpath:conf/ibps-context.xml"})
引入bean注入配置。
FeignClient注入配置
- 在启动类的@EnableFeignClients注解添加配置(basePackages = {“com.lc.ibps”, “cn.lc.ibps”})//TODO 配置基础包名!重要步骤!!!。包名按需修改
授权文件配置
- 授权文件引入
将授权文件ibpsPublic.store、ibpsVfy.lic、license.passwdv3.2.0复制到项目的conf目录下。
- 授权密码配置
license: xxxx # 和授权文件同级目录有一个名字随机的文件,文件名即授权密码,v3.1.10及以下版本使用
maven私服请切换至自己的服务;
Demo工程详见源码中的provider-skeleton-other
目录;
FAQ
请求/user/context
地址出现access_token值重复?
解决方案:检查是否引入spring-boot-starter-tomcat
,里面定义了filter导致header重复设置;