收到TGT休息后如何从cas成功注销

时间:2019-08-21 06:37:11

标签: python rest cas

在cas服务器上创建的TGT将卡住。寻找一种使用postman / python请求注销的方法。

我即将向具有SSO和CAS(用于REST查询)的NMS服务器发送身份验证请求。 第一步是将发布请求发送到: https://x.x.x.x:443/cas/v1/tickets 正文中包含用户名和密码以及grant_type = client_credentials。

然后服务器将提供一个TGT网址以继续进行下一步(生成服务票证)

问题是,在接收到TGT之后,服务器的TGT池已用完,并且每当我生成新的TGT到生成3-4个TGT之后,没有用户可以使用的WebUI减少了1个用户登录,我们需要重新启动TomCat才能重置TGT池。

我如何正确发送我为释放池而创建的TGT的注销请求(使用邮递员)? 我的下一步将使用python而不是postman创建请求。 我的请求结果:

<!DOCTYPE HTML PUBLIC \"-//IETF//DTD HTML 2.0//EN\"> <html>
<head>
    <title>201 Created</title>
</head>
<body>
    <h1>TGT Created</h1>
    <form
        action="https://x.x.x.x/cas/v1/tickets/TGT-269-XONFj15axxxxxxxxxxxxxxxI32bYERsZr9hjCIMY2b-nsdnrcp"
        method="POST">Service:<input type="text" name="service" value=""><br><input type="submit" value="Submit"></form>
</body>
</html>    

下面是我用于注销的代码,但它没有释放服务器上的TGT资源:

def deAuth(casIP,appIP):
        deAuthenticate_URL = f'https://{appIP}:8443/data/deauthenticate'
        commonLogout_URL = f'https://{appIP}:8443/data/common/logout'
        sessionLogout_URL = f'https://{casIP}:443/session-manager/logout'
        casLogout_URL = f'https://{casIP}:443/logout'
        param = {'service':'https://{appIP}:8443/pages/main'}
        deAuthenticate_r = requests.post(deAuthenticate_URL,params=param,verify=False)
        if deAuthenticate_r.status_code != 200:
                print('deAuthenticate failed!')
        commonLogout_r = requests.get(commonLogout_URL,params=param,verify=False)
        if commonLogout_r.status_code != 200:
                print('commonLogout failed!')
        sessionLogout_r = requests.get(sessionLogout_URL,params=param,verify=False)
        if sessionLogout_r.status_code != 200:
                print('sessionLogout failed!')
        casLogout_r = requests.get( casLogout_URL,params=param,verify=False)
        if casLogout_r.status_code != 200:
                print('casLogout failed!')
        print('Logout attempt is completed!')    

以上代码中的所有请求将产生200,但是TGT仍然有效。 我还需要在注销请求中包含TGT吗?

预期结果将是使TGT票证无效,以便其他用户登录到服务器的Webui。

1 个答案:

答案 0 :(得分:0)

删除/ cas / v1 / tickets / TGT-fdsjfsdfjkalfewrihfdhfaie HTTP / 1.0

上面的请求是leopal

中提到的解决方案