SDK JDBC多种方式接入AZURE SQL DATABASE JAVA版

news2024/11/28 6:52:11

本文阐述使用JDBC接入AZURE SQL 数据库
笔者认为AZURE云上的AZURE SQL和SQL SERVER是很相似的,在普通的账号密码情况下JDBC字符串都是一致的。
下来全部说明官方的多种连接方式,参考官方:
https://learn.microsoft.com/zh-cn/sql/connect/jdbc/connecting-using-azure-active-directory-authentication?view=sql-server-ver16#set-kerberos-ticket-on-windows-linux-and-macos
在这里插入图片描述

在这里插入图片描述

a.SqlPassword

SQL SERVER验证
使用数据库用户名+密码

String sql="jdbc:sqlserver://xx.database.windows.net:1433;database=dbname;user=user;password=pass;authentication=SqlPassword";

b.ActiveDirectoryPassword

采用Azure AD用户名+密码验证
首先设置AD账号为数据库管理员
在这里插入图片描述
然后

String sql="jdbc:sqlserver://xx.database.windows.net:1433;database=db;user=xx@xx.onmicrosoft.com;password=xx;authentication=ActiveDirectoryPassword";

e.ActiveDirectoryMSI
采用AZURE内部得服务器,等验证
先设置服务器为数据库的管理员
在这里插入图片描述

再进行请求,MSIClientId是服务器的id,是不必要的

String sql="jdbc:sqlserver://xx.database.windows.net:1433;database=whalead;MSIClientId=xxx;authentication=ActiveDirectoryMSI";


f.ActiveDirectoryServicePrincipal
采用应用和密钥进行验证
先设置应用为数据库的管理员
在这里插入图片描述
给应用设置密钥
在这里插入图片描述

String sql="jdbc:sqlserver://xx.database.windows.net:1433;database=xxdb;authentication=ActiveDirectoryServicePrincipal;user=cliendid;password=secret;";

g.accessToken
采用使用和密钥去获取token进行验证,步骤和principal一致,代码不一样,不能使用jdbc连接
多了一步要获取
在这里插入图片描述

String spn = "https://database.windows.net/";
		String stsurl = "https://login.microsoftonline.com/xxxx/oauth2/v2.0/token"; // Replace with your STS URL.
		String clientId = "xxx"; // Replace with your client ID.
		String clientSecret = "xxx"; // Replace with your client secret.

		String scope = spn +  "/.default";
		Set<String> scopes = new HashSet<>();
		scopes.add(scope);

		ExecutorService executorService = Executors.newSingleThreadExecutor();
		IClientCredential credential = ClientCredentialFactory.createFromSecret(clientSecret);
		ConfidentialClientApplication clientApplication = ConfidentialClientApplication
				.builder(clientId, credential).executorService(executorService).authority(stsurl).build();
		CompletableFuture<IAuthenticationResult> future = clientApplication
				.acquireToken(ClientCredentialParameters.builder(scopes).build());
		IAuthenticationResult authenticationResult = future.get();
		String accessToken = authenticationResult.accessToken();

		System.out.println("!!!!!!!!!!!!!!!!!!!!!!!!!!!Access Token: " + accessToken);
		String sql="jdbc:sqlserver://xxx.database.windows.net:1433;database=xxx;user=xxx;accessToken="+accessToken;
		System.out.println("!!!!!!!!!!!!!!!!!!!!!!!!!!!Access Token: " + sql);

		// Connect with the access token.
		SQLServerDataSource ds = new SQLServerDataSource();

		ds.setServerName("xxx.database.windows.net"); // Replace with your server name.
		ds.setDatabaseName("xxx"); // Replace with your database name.
		ds.setAccessToken(accessToken);

		try (Connection connection = ds.getConnection();
			 Statement stmt = connection.createStatement();
			 ResultSet rs = stmt.executeQuery("SELECT SUSER_SNAME()")) {
			if (rs.next()) {
				System.out.println("You have successfully logged on as: " + rs.getString(1));
			}
		}

未实践的

c.ActiveDirectoryIntegrated
WINDOWS下是使用mssql-jdbc_auth--.dll 进行验证

Linux下采用
在 Windows、Linux 和 macOS 上设置 Kerberos 票证

d.ActiveDirectoryInteractive
使用时,弹出网页让用户自行三方验证

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

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

相关文章

Post-GWAS: single-cell disease relevance score (scDRS) 分析

1、scDRS的计算原理如下所示&#xff1a; 图片来源&#xff1a;Zhang M J, Hou K, Dey K K, et al. Polygenic enrichment distinguishes disease associations of individual cells in single-cell RNA-seq data[R]. Nature Publishing Group, 2022. 2、通过scDRS分析可以得到…

XDisplay 安装教程

Splashtop Wired XDisplay 安装教程1. 概述2. Splashtop XDisplay 详细安装教程2.1 下载 Splashtop XDisplay2.2 电脑上安装 Splashtop XDisplay2.3 iPad安装 Splashtop XDisplay3. 遇到的问题3.1 下载 iTunes3.2 安装 iTunes3.3 打开 iTunes3.4 同意许可协议4. iPad连接Window…

学会用这个键,Word做得比领导还整齐, 早早下班不是梦

大家比较常用到哪些快捷键呢&#xff1f;快捷键用得熟练&#xff0c;工作效率可是会大大提高的。下面介绍4类常用的Word快捷键&#xff0c;希望能够帮到你&#xff0c;大家一起提高效率&#xff0c;早早下班&#xff01;一、字体样式&#xff1a;平常更改字体样式&#xff0c;总…

【openEuler系列】部署文件共享服务Samba

个人名片&#xff1a; 对人间的热爱与歌颂&#xff0c;可抵岁月冗长&#x1f31e; Github&#x1f468;&#x1f3fb;‍&#x1f4bb;&#xff1a;念舒_C.ying CSDN主页✏️&#xff1a;念舒_C.ying 个人博客&#x1f30f; &#xff1a;念舒_C.ying 1 配置环境 挂载系统ISO&am…

李沐精读论文:GAN

论文&#xff1a;https://papers.nips.cc/paper/2014/file/5ca3e9b122f61f8f06494c97b1afccf3-Paper.pdf 视频&#xff1a;GAN论文逐段精读【论文精读】_哔哩哔哩_bilibili 课程&#xff1a;CS231n 2022PPT笔记- 生成模型Generative Modeling ​李宏毅机器学习——对抗生成网络…

基本算法学习记录---Day2

并查集模板1 class Solution {int[] root new int[200000];public int Que() {//初始化for(int i 1;i<n;i){root[i] i;}//TODO}//找根(将节点连接)public int find(int x){if(root[x] ! x){root[x] find(root[x]);}return root[x];}//合并public void heb(int i,int j)…

快速突出重点数据,条件样式来帮你

使用条件样式可以实现使用样式标注符合规则的数据&#xff0c;可以帮助直观查看数据、发现关键数据问题和数据的变化趋势。例如&#xff1a; 使用红色文字标注同比增幅小于10%的省份 使用红色文字标注同比增幅小于10%的省份使用不同的图标标注计划完成情况&#xff0c;绿色图…

PS CS6视频剪辑基本技巧(一)CS6可以实现的视频剪辑功能

前几天儿子要做一个居家生活的视频在班会上分享&#xff0c;想把视频做得漂亮一些&#xff0c;不想应付了事&#xff0c;本人略懂PS&#xff0c;所以就地取材学了一下用PS CS6制作视频&#xff0c;现在把学习到的基本技巧给大家分享一下。本人非专业人士&#xff0c;所用软件也…

Arthas入门和安装使用

闲聊 我前几天也阳了&#xff0c;难受的要死&#xff0c; 不过今天明显好转&#xff0c;抓紧来一篇博文助助兴。如果对你有一点收获&#xff0c;辛苦点个赞。 简介 Arthas 是 Alibaba 在 2018 年 9 月开源的 Java 诊断工具。支持JDK6以上。主要用于定位和诊断线上程序运行问…

Solidity之abi.encode各编码方法使用

什么是智能合约 ABI ABI Specification for encoding and decoding 非常精炼的一句话&#xff1a;一套用来编码和解码的规范。 注意与合约字节码&#xff08;bytecode&#xff09;要区分开&#xff0c;字节码只是一串用十六进制数表示的 EVM 操作码。 在 Solidity 文档中描…

文件内容的读写 (IO) —— 数据流

文件内容的读写 IO —— 数据流一、什么是数据流二、字节流输入InputStream2.1 InputStream 概述2.2 FileInputStream 的使用三、字节流输出OutputStream3.1 OutputStream 概述3.2 FileOutputStream 的使用四、字符流输入 Reader4.1 Reader 与 FileReader4.2 利用 Scanner 进行…

[Java]图论进阶--最小生成树算法

专栏简介 :MySql数据库从入门到进阶. 题目来源:leetcode,牛客,剑指offer. 创作目标:记录学习MySql学习历程 希望在提升自己的同时,帮助他人,,与大家一起共同进步,互相成长. 学历代表过去,能力代表现在,学习能力代表未来! 目录 1. 最小生成树 1.1 Kruskal(克鲁斯卡尔) 算法 …

计算机毕设Python+Vue校园社团信息管理系统(程序+LW+部署)

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

Teams app LukcyDraw 的升级之路

我已经有很长一段时间没有更新我的 Teams App&#xff1a;LuckyDraw 了&#xff0c;有很多用户反馈给我&#xff0c;因为快到圣诞&#xff0c;新年和春节了&#xff0c;很多公司都开始要使用LuckyDraw来搞抽奖活动&#xff0c;希望LuckyDraw能支持大用户量的抽奖&#xff0c;所…

当打造一款极速湖分析产品时,我们在想些什么

作者&#xff1a;王有卓&#xff0c;StarRocks Contributor 随着开源数据湖技术的快速发展以及湖仓一体全新架构的提出&#xff0c;传统数据湖在事务处理、流式计算以及数据科学场景的限制逐渐得以优化解决。 为了满足用户对数据湖探索分析的需求&#xff0c;StarRocks 在 2.…

jsp+ssm计算机毕业设计ssm实验教学资源管理系统【附源码】

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; JSPSSM mybatis Maven等等组成&#xff0c;B/S模式 Mave…

【linux】linux实操篇之进程管理

目录前言进程介绍和查询进程基本介绍显示系统执行的进程终止进程服务管理监控服务动态监控进程监控网络状态结语前言 本篇博客总结linux中的进程管理相关知识&#xff0c;主要有进程介绍&#xff0c;终止进程&#xff0c;服务管理以及监控服务&#xff0c;一起来看看吧&#x…

模拟电路设计(40)---你真的懂“接地”吗?

概念 接地是指将一个电路、设备乃至分系统与一个基准“地”电位连接的电气要求&#xff0c;目的在于提供一个等电位点或等电位面。接地可以接真正的大地&#xff0c;也可以不接&#xff0c;例如飞机上的电子电气设备接飞机机壳就是接地。 接地必须有接地导体和接地平面才能够…

ChatGPT和InstructGPT 对比,ChatGPT将改变世界,影响力不亚于2007年新一代iPhone智能手机的发布

ChatGPT ChatGPT 的模型&#xff0c;它以对话方式进行交互。对话格式使 ChatGPT 可以回答后续问题、承认错误、挑战不正确的前提并拒绝不适当的请求。ChatGPT 是InstructGPT的兄弟模型&#xff0c;它经过训练可以按照提示中的说明进行操作并提供详细的响应。 ChatGPT 网址&am…

vue打包优化一

webpack.dll.config.js配置 相关文章 https://www.cnblogs.com/echoyya/p/16413591.html 步骤一&#xff1a;创建webpack.dll.config.js&#xff08;不一定要是这个名字&#xff0c;只要执行指令的时候路径正确就行&#xff09; // webpack.dll.config.js const path requi…