SakuraCat(2)Endpoint

Endpoint

功能概述

  • 监听指定端口(默认是 8080)的客户端连接。
  • 接受客户端连接后,为每个连接创建一个新的线程进行处理。
  • 使用 Processor 类来处理客户端的请求和响应。
package com.SakuraCat.connector.protocolHandler;

import com.SakuraCat.servletContainer.ServletContainer;

import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;

public class EndPoint {
    private static final int PORT = 8080; // 服务器监听的端口号

    private ServletContainer servletContainer;

    public EndPoint(ServletContainer servletContainer) {
        this.servletContainer  = servletContainer;
    }

    public void start(){
        ServerSocket serverSocket = null;

        try {
            // 创建一个 ServerSocket,用于监听指定端口
            serverSocket = new ServerSocket(PORT);
            System.out.println("服务器已启动,监听端口:" + PORT);

            // 服务器持续运行,等待客户端连接
            while (true) {
                // 接受客户端的连接请求
                Socket clientSocket = serverSocket.accept();
                System.out.println("客户端已连接:" + clientSocket.getInetAddress().getHostAddress());

                // 为每个客户端创建一个新的线程进行处理
                new Thread(new Processor(clientSocket, servletContainer)).start();
            }
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            // 关闭服务器套接字
            if (serverSocket != null) {
                try {
                    serverSocket.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
    }
}

ServerSocket 的工作原理

  • 创建 ServerSocket 实例:
    服务器程序创建一个 ServerSocket 对象,并绑定到一个指定的端口上。这一步告诉操作系统,服务器希望监听该端口的连接请求。
    例如:ServerSocket serverSocket = new ServerSocket(8080); 表示服务器监听 8080 端口。
  • 等待客户端连接:
    ServerSocket 会一直处于监听状态,等待客户端的连接请求。这通常通过 serverSocket.accept() 方法实现,该方法会阻塞,直到有客户端连接到来。
    例如:Socket clientSocket = serverSocket.accept(); 会阻塞,直到有客户端连接。
  • 接受客户端连接:
    当有客户端连接时,accept() 方法返回一个 Socket 对象,该对象代表与客户端的连接。服务器可以通过这个 Socket 对象与客户端进行通信。

使用多线程进行请求处理

对于每个socket连接,服务器通过一个新的线程来处理请求,让服务器具有并发处理请求的能力。(后续将会优化成线程池)

OAuth 2.0 的 Token Endpoint 是用于获取访问令牌(Access Token)和刷新令牌(Refresh Token)的终结点。下面是一般使用 OAuth 2.0 Token Endpoint 的步骤: 1. 获得授权码(Authorization Code):在用户授权后,通过重定向回调获得授权码。例如,用户在浏览器中登录并授权后,将被重定向到你的应用程序的回调URL,并包含授权码。 2. 通过授权码获取令牌:使用授权码向 Token Endpoint 发起 POST 请求,包含必要的参数,如客户端ID、客户端秘钥、授权码、重定向URI和授权类型。示例请求如下: ``` POST /token HTTP/1.1 Host: token_endpoint Content-Type: application/x-www-form-urlencoded grant_type=authorization_code&code=AUTHORIZATION_CODE&redirect_uri=REDIRECT_URI&client_id=CLIENT_ID&client_secret=CLIENT_SECRET ``` 3. 解析令牌响应:Token Endpoint 应该返回一个 JSON 格式的响应,包含访问令牌和刷新令牌等信息。示例响应如下: ```json { "access_token": "ACCESS_TOKEN", "refresh_token": "REFRESH_TOKEN", "expires_in": 3600, "token_type": "Bearer" } ``` 4. 使用访问令牌:拿到访问令牌后,可以将其发送到受保护资源的服务器上,以获取所需的数据或执行操作。 需要注意的是,Token Endpoint 的具体实现可能会有所不同,可以参考你使用的 OAuth 2.0 提供商的文档来了解其具体用法和参数要求。另外,为了保护令牌的安全性,使用 HTTPS 来进行请求和响应是非常重要的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值