feiyu02
2025-03-28 7d74f3fd087d4a8192ed556a6c2e3a2ea3c81cff
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
package cn.flightfeather.supervision.socket.config
 
import org.apache.logging.log4j.util.Strings
import org.springframework.http.server.ServerHttpRequest
import org.springframework.http.server.ServerHttpResponse
import org.springframework.stereotype.Component
import org.springframework.web.socket.WebSocketHandler
import org.springframework.web.socket.server.HandshakeInterceptor
 
/**
 *
 * @date 2024/7/19
 * @author feiyu02
 */
@Component
class WsHandshakeInterceptor : HandshakeInterceptor {
    /**
     * 握手前
     */
    @Throws(Exception::class)
    override fun beforeHandshake(
        request: ServerHttpRequest,
        response: ServerHttpResponse,
        wsHandler: WebSocketHandler,
        attributes: MutableMap<String, Any>,
    ): Boolean {
        println("握手开始")
        val hostName = request.remoteAddress.hostName
        // TODO: 2024/7/19 后续可添加用户身份验证机制,sessionId可替换为实际的用户id
        val sessionId = hostName + (Math.random() * 1000).toInt().toString()
        if (Strings.isNotBlank(sessionId)) {
            // 放入属性域
            attributes["session_id"] = sessionId
            println("用户 session_id $sessionId 握手成功!")
            return true
        }
        println("用户登录已失效")
        return false
    }
 
    /**
     * 握手后
     */
    override fun afterHandshake(
        request: ServerHttpRequest,
        response: ServerHttpResponse,
        wsHandler: WebSocketHandler,
        exception: Exception?,
    ) {
        println("握手完成")
    }
}