1.tableau 是一个做数据统计查看的一个应用,分为桌面端和服务端。
关系:类似于数据库(服务端) 和 Navicat Premium数据库操作软件(桌面端)
2:主讲Java如何接入:
1.配置接入端电脑到tableauserver的ip白名单
官网api:
https://onlinehelp.tableau.com/current/server/zh-cn/trusted_auth_webrequ.htm
如果按官网的方式走不通,加入环境变量 键:no_proxy 值:localhost
10.5 之前:
C:\WINDOWS\system32>E:
E:\>cd E:\tableau\Tableau Server\2018.1\bin
停掉服务
E:\tableau\Tableau Server\2018.1\bin>tabadmin stop
===== Stopping service...
-- Service stopped successfully
配置ip
E:\tableau\Tableau Server\2018.1\bin>tabadmin set wgserver.trusted_hosts "60.24.65.44"
-- value for key wgserver.trusted_hosts has been set
保存设置
E:\tableau\Tableau Server\2018.1\bin>tabadmin config
===== Wrote configuration files to E:/tableau/Tableau Server/data/tabsvc/config
-- Web data connectors were distributed to all gateways.
从新启动
E:\tableau\Tableau Server\2018.1\bin>tabadmin start
===== Starting service...
-- Service was started successfully
E:\tableau\Tableau Server\2018.1\bin>
2.设置好白名单进行下一步 post请求 来和tableau官方j交互票证用来拼接网址,进行无登录访问
http://<tableauServer访问Url>/trusted?username=<userName许可用户用户 要有交互者及以上权利>&client_ip=<tableauServer的ipv4的访问地址>
username= (必需):Tableau Server 许可用户的用户名。如果使用的是本地身份验证,则用户名可以是简单字符串(例如,username=jsmith)。如果将 Active Directory 用于多个域,则用户名中必须包含域名(例如,username=MyCo\jsmith)。
target_site= (如果视图不在默认站点上,则为必需):如果 Tableau Server 运行多个站点,并且视图位于默认站点之外的其他站点上(例如,target_site=Sales),则指定包含该视图的站点。用于 的值应为创建该站点时提供的站点 ID。此值区分大小写。如果站点 ID 为 SAles,则 target_site=SAles。
client_ip= (可选):用于指定 Web 浏览器要访问该视图的计算机的 IP 地址(例如,client_ip=123.45.67.891)。该地址不是发出 Tableau Server 的 POST 请求的 Web 服务器 IP 地址。如果您决定使用此参数,请参见可选:配置客户端 IP 匹配以了解更多信息。
3.连接失败返回-1 连接成功返回对应票证。
然后进行拼装url返回给前端:
ticket–>票证
viewUrl–>大都是 views/工作表名称/1
工作表后面只有一个视图,不会出现多个视图的情况
toolbar 控制着显示下面的按钮组。
params–>:embed=yes&:toolbar=yes
返回前端的网址:“http://” + tableAUServer + “/trusted/”+ ticket + “/” + viewUrl + “?” + params;
以下是票证返回的工具类:
private static String getTrustedTicket(String tableauServer, String user, String remoteAddr) {
OutputStreamWriter out = null;
BufferedReader in = null;
try { // Encode the parameters
StringBuffer data = new StringBuffer();
data.append(URLEncoder.encode("username", "UTF-8"));
data.append("=");
data.append(URLEncoder.encode(user, "UTF-8"));
data.append("&");
data.append(URLEncoder.encode("client_ip", "UTF-8"));
data.append("=");
data.append(URLEncoder.encode(remoteAddr, "UTF-8"));
// Send the request
URL url = new URL("http://" + tableauServer+ "/trusted");
URLConnection conn = url.openConnection();
conn.setDoOutput(true);
out = new OutputStreamWriter(conn.getOutputStream());
out.write(data.toString());
out.flush(); // Read the response
StringBuffer rsp = new StringBuffer();
in = new BufferedReader(new InputStreamReader(conn.getInputStream()));
String line;
while ((line = in.readLine()) != null) {
rsp.append(line);
}
return rsp.toString();
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
if (in != null) in.close();
if (out != null) out.close();
} catch (IOException e) {
}
}
return null;
}