通过基于JDBC的用户存储部署Identity Server

在这篇文章中,我将演示如何使用JDBC用户存储配置WSO2 Identity Server。 为了演示,我使用的是MySQL用户存储,但是相同的过程也适用于任何其他JDBC用户存储。 我的环境是

  • 操作系统– Ubuntu 12.10
  • Java – 1.6
  • WSO2是4.5.0
  1. 设置MySQL数据库
  2. IS中的用户存储配置–主要
  3. IS中的用户存储配置–辅助

(在本文中,我将提取的wso2is文件夹称为CARBON_HOME)

设置MySQL数据库

我们首先需要运行MySQL。 如果尚未建立MySQL资料库 ,这篇文章会很有帮助。 MySQL运行后,我们必须根据Identity Server的要求来建立数据库。 服务器在其内部打包了必要的sql脚本,这些脚本可以位于CARBON_HOME / dbscripts中。

dbscrpts
让我们登录到MySQL服务器并执行以下命令:

创建一个数据库,

mysql> create datbase JDBC_demo_user_store;

看看创作,

mysql> show databases;

显示数据库

然后使用sql脚本并设置数据库,

mysql> use JDBC_demo_user_store;
mysql> source <path_to>/wso2is-4.5.0/dbscripts/mysql.sql;

这将在SQL脚本中运行查询并设置所需的表。

现在,如果我们输入命令,将显示以下输出。

mysql> show tables;

showTables

现在我们完成了数据库的设置。 我们可以继续要求Identiy Server使用它。

注意:在执行以下步骤之前,我们还需要将mysql-jdbc连接器添加到Identity Server。 您可以从此处下载它,并将其放入CARBON_HOME / repository / components / lib中。

IS中的用户存储配置–主要

Identity Server使用嵌入式H2数据库保留权限详细信息等,其数据源详细信息位于CARBON_HOME / repository / conf / datasources / master-datasources.xml中。 我们也可以在此处添加新JDBC用户存储的数据源详细信息。 根据我的设置,这是master-datasources.xml文件。

<datasource><name>JDBC_demo_user_store</name><description>The datasource used for JDBC_demo_user_store</description><jndiConfig><name>jdbc/JDBC_demo_user_store</name></jndiConfig><definition type="RDBMS"><configuration><url>jdbc:mysql://localhost:3306/JDBC_demo_user_store</url><username>root</username><password>pushpalanka2</password><driverClassName>com.mysql.jdbc.Driver</driverClassName><maxActive>50</maxActive><maxWait>60000</maxWait><testOnBorrow>true</testOnBorrow><validationQuery>SELECT 1</validationQuery><validationInterval>30000</validationInterval></configuration></definition>
</datasource>

用户存储的主要配置位于CARBON_HOME / repository / conf / user-mgt.xml文件中。 默认情况下,它指向嵌入式ReadLDAPUserStoreManager。 现在我们将其更改为JDBCUserStoreManager。 因此,让我们注释掉默认值之一,并取消注释JDBCUserStoreManager。 现在,我们将有一个类似于this的user-mgt.xml文件 。 如果需要,我们可以根据上下文修改这些属性。

现在配置已结束。 让我们从bin / wso2server.sh启动服务器。 一旦开始,请继续并将用户添加到“主”域。

添加用户

现在,如果我们检查在数据库中创建的UM_USER表,它也会列出用户。

UM_USER

IS中的用户存储配置–辅助

现在,让我们看看如何在IS中将相同的MySQL用户存储用作辅助用户存储。 这很容易,我们可以通过UI进行全部操作,而无需对master-datasources.xml或user-mgt.xml中的上述默认配置进行任何修改。 我们必须在此处添加驱动程序名称,URL,用户名和密码,作为先前在master-datasources.xml中提供的强制属性。

ui

添加后,它将显示在可用的用户存储列表中。 在UI中定义用户商店经理是很直观的,但是如果您想了解更多详细信息,可以参考这篇文章 。 如果需要,我们也可以编辑可选属性。 高级部分包含JDBC用户存储管理器所需的SQL语句。

Advanced Option:如果要编辑数据库结构(SQL脚本),则需要使用该Advanced选项根据该架构更新这些SQL查询。

现在,如果我们尝试添加新用户,我们还将看到该辅助域。

2013-09-05 17-01-50的屏幕截图

如果选择此域并添加用户,我们可以看到用户添加到数据库中的方式与主要用户存储中的方式相同。

参考: Pushpalanka博客博客中的JCG合作伙伴 Pushpalanka 通过基于JDBC的用户存储部署Identity Server 。

翻译自: https://www.javacodegeeks.com/2013/09/deploying-identity-server-over-a-jdbc-based-user-store.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/367182.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

前端路由实现原理(history)

前端路由实现&#xff08;history&#xff09; 了解&#xff1a; HTML5 history新增了两个API:history.pushState和history.replaceState 两个api都接受三个参数 状态对象&#xff08;state object&#xff09;&#xff1a;一个JavaScript对象&#xff0c;与用pushState()方法…

mysql中临时表的特点_解析Mysql临时表及特点

临时表是当连接没有断开时存在&#xff0c;一旦断开就不会存在&#xff0c;临时表的数据和结构都在内存中&#xff0c;可以做个测验&#xff0c;你创建一个临时表&#xff0c;但是到响应的数据目录下并不会找到.frm文件mysql> CREATE TEMPORARY TABLE tmp_table (->->…

原生js实现一个连连看小游戏(三)-----------点击列表获取索引

需求&#xff1a;当点击一个列表时&#xff0c;我们要知道它在列表的第几项&#xff0c;即索引&#xff0c;代码实现如下&#xff1a; <!DOCTYPE html> <html> <head><title></title> </head> <body><ul id"myUl">&…

3、数组和集合

数组 ------------------------------------------------------------------ 一维数组 object Demo2 {def main(args: Array[String]): Unit {//定义数组&#xff0c;并指定长度val arr1 new Array[Int](5)arr1(0) 1arr1(2) 4printarr(arr1)//初始化并赋值val arr2 Array[…

unity 删除服务器项目,在吗?有个支持批量构建项目的好东西推荐给你

Unity Build Server是一种全新的项目构建辅助工具&#xff0c;它可以指定硬件设备&#xff0c;专门用于构建项目版本&#xff0c;帮助工作室大规模构建项目&#xff0c;提高团队生产力。很多人在选择Unity时并不会首先考虑到项目构建问题&#xff0c;而随着项目变得更大、更复杂…

使用WSO2 ESB构建制造服务总线(MSB)

在开始讨论本主题之前&#xff0c;我想介绍一些制造业中常用的术语。 术语制造执行系统&#xff08;MES&#xff09;由AMR Research于1990年提出&#xff0c;从先进的制造计算机信息系统的发展&#xff0c;MES概念已经发展了近三十年。 以下是制造执行系统协会&#xff08;MES…

mysql jion 实现原理_MySQL-join的实现原理、优化及NLJ算法

案例分析&#xff1a;selectc.*fromhotel_info_original cleft joinhotel_info_collection honc.hotel_typeh.hotel_typeandc.hotel_idh.hotel_idwhereh.hotel_idis null这个sql是用来查询出 c 表中有 h 表中无的记录&#xff0c;所以想到了用 left join 的特性(返回左边全部记…

手把手教你写一份优质的前端技术简历

不知不觉一年一度的秋招又来了&#xff0c;你收获了哪些大厂的面试邀约&#xff0c;又拿了多少offer呢&#xff1f;你身边是不是有挺多人技术比你差&#xff0c;但是却拿到了很多大厂的offer呢&#xff1f;其实&#xff0c;要想面试拿offer&#xff0c;首先要过得了简历那一关。…

地兵布阵 -----------HDU-1166

C国的死对头A国这段时间正在进行军事演习&#xff0c;所以C国间谍头子Derek和他手下Tidy又开始忙乎了。A国在海岸线沿直线布置了N个工兵营地,Derek和Tidy的任务就是要监视这些工兵营地的活动情况。由于采取了某种先进的监测手段&#xff0c;所以每个工兵营地的人数C国都掌握的一…

python笔记30-docstring注释添加变量

前言 python里面添加字符串注释非常简单&#xff0c;如何将变量放入 python 的函数注释里面呢&#xff1f; docstring也就是给代码加注释的内容了&#xff0c;python可以给函数&#xff0c;类、方法&#xff0c;模块添加注释内容&#xff0c;注释标准格式一般是三个双引号&…

无线路由器在手机上如何连接服务器,192.168.10.1路由器手机怎么设置? | 192路由网...

问&#xff1a;192.168.10.1路由器手机怎么设置&#xff1f;答&#xff1a;192.168.10.1是一个C类的私有IP地址&#xff0c;目前国产的路由器中&#xff0c;睿因路由器使用192.168.10.1作为默认登录地址。鉴于此&#xff0c;下面鸿哥使用睿因路由器来进行演示介绍。温馨提示&am…

Java Mission Control 5.2终于来了! 欢迎7u40!

自从我们上次听说这个叫做任务控制的小东西已经有一段时间了。 它从JRockit一直到现在都被重命名为Java Mission Control。 这是从HotSpot和JRockit融合战略中幸存下来的部分之一。 使用今天的Java SE 7 Update 40&#xff0c;您实际上可以再次使用它。 Java Mission Control …

webview布局适配实践

一、相关概念 1、viewport&#xff1a;移动设备&#xff08;包括webview&#xff09;用来显示网页的那一块区域&#xff1b; 2、devicePixelRatio属性(别名像素比&#xff0c;简称dpr)&#xff1a;window.devicePixelRatio 物理像素 / 独立像素(css中的px)&#xff1b; 3、rem…

mysql count 不等于_Mysql 不同的 count 区别

不同 count 的区别&#xff1a;count(*)、count(主键 id)和 count(1) 都表示返回满足条件的结果集的总行数&#xff1b;而 count(字 段)&#xff0c; 则表示返回满足条件的数据行里面&#xff0c;参数“字段”不为 NULL 的总个数。性能&#xff1a;count(主键 id)&#xff1a;I…

Python3爬虫(四)请求库的使用requests

Infi-chu: http://www.cnblogs.com/Infi-chu/ 一、基本用法&#xff1a; 1. 安装&#xff1a; pip install requests 2. 例子&#xff1a; import requests url http://www.baidu.com r requests.get(url) print(type(r)) # 类型是str&#xff08;JSON格式&#xff09; pr…

后台通过request.setAttribute向前台传值,前台如何去获取其中的对象或属性值

讲这些&#xff0c;我们先来了解一下request.setAttribute和request.setAttribute()这两种方法的作用。 request.getAttribute("nameOfObj"); 可得到jsp页面表单中输入框内的value。&#xff08;其实表单控件中的Object的name与value是存放在一个哈希表中的&#xff…

两个用于Eclipse的TCK –开源到底有什么?

早在5月&#xff0c;Oracle就向Eclipse Foundation 授予了兼容性测试奖学金 。 在过去的几天里&#xff0c;这引起了媒体的关注&#xff0c;我只是想确保我对整个过程和详细动作有所了解。 看起来像是一见钟情的简单诚实的礼物实际上具有更多的方面。 但让我们从头开始&#xf…

尝试连接到服务器时出错请检查虚拟机管理器,Hyper-V尝试连接到服务器出错无效类的解决方法...

Hyper-V尝试连接到服务器出错无效类的解决方法Windows10安装Hyper-V后没有自动连接到本地计算机&#xff0c;手工连接失败&#xff0c;提示&#xff1a;引用内容尝试连接到服务器"DESKTOP-6P9L2HB"时出错。请检查虚拟机管理服务是否正在运行以及是否授权你连接到此服…

Flask和mysql多线程_Flask解析(二):Flask-Sqlalchemy与多线程、多进程

Sqlalchemyflask-sqlalchemy的session是线程安全的&#xff0c;但在多进程环境下&#xff0c;要确保派生子进程时&#xff0c;父进程不存在任何的数据库连接&#xff0c;可以通过调用db.get_engine(appapp).dispose()来手动销毁已经创建的engine&#xff0c;然后再派生子进程。…

深入理解redis数据类型

转载请注明出处&#xff1a;https://www.cnblogs.com/wenjunwei/p/9720033.html redis的存储模型 redis不是普通的键值对存储&#xff0c;它实际上是一个数据结构存储服务器&#xff0c;可以支持不同类型的值。这意味着redis相比传统键值对字符串key和字符串value存储来说&…