修改提交
This commit is contained in:
233
Packages/cn.tuanjie.codely.bridge/README.md
Normal file
233
Packages/cn.tuanjie.codely.bridge/README.md
Normal file
@@ -0,0 +1,233 @@
|
||||
# Codely Bridge
|
||||
|
||||
Codely Bridge is a lightweight TCP socket server implementation for Unity Editor that provides networking capabilities with port management and client handling.
|
||||
|
||||
## Features
|
||||
|
||||
### 🚀 TCP Socket Server
|
||||
|
||||
- **Modern Architecture**: Built with async/await patterns for Unity Editor
|
||||
- **Automatic Port Management**: Smart port allocation with project-specific persistence
|
||||
- **Client Connection Handling**: Multi-client support with proper connection management
|
||||
- **Socket Configuration**: Optimized socket options for reliable connections
|
||||
|
||||
### ⚙️ Port Management
|
||||
|
||||
- **Dynamic Port Allocation**: Automatically finds available ports starting from default (25916)
|
||||
- **Project-Specific Storage**: Remembers port settings per Unity project
|
||||
- **Port Conflict Resolution**: Handles port conflicts gracefully with fallback options
|
||||
- **Cross-Platform Support**: Works on Windows, macOS, and Linux
|
||||
|
||||
### 🔧 TCP Features
|
||||
|
||||
- **Keep-Alive Support**: Configurable socket keep-alive for stable connections
|
||||
- **Connection Timeout**: Prevents hanging connections with configurable timeouts
|
||||
- **Multi-Client Support**: Handles multiple simultaneous client connections
|
||||
- **Graceful Shutdown**: Proper cleanup on Unity Editor shutdown or assembly reload
|
||||
|
||||
### 🎛️ Unity Editor Integration
|
||||
|
||||
- **Control Window**: Full-featured TCP bridge management interface (`Tools > Codely Bridge > Control Window`)
|
||||
- **Status Window**: Compact dockable status monitor (`Tools > Codely Bridge > Status Window`)
|
||||
- **Menu Items**: Quick actions via Unity menu (`Tools > Codely Bridge`)
|
||||
- **Real-time Status**: Live server status updates and port information
|
||||
- **Debug Controls**: Toggle debug logging and port management tools
|
||||
|
||||
## Installation
|
||||
|
||||
### Requirements
|
||||
|
||||
- Unity 2021.3 or later
|
||||
|
||||
### Setup
|
||||
|
||||
1. Add this package to your Unity project
|
||||
2. The TCP server will start automatically when Unity loads
|
||||
3. Check Unity Console for server startup confirmation and port information
|
||||
|
||||
## Usage
|
||||
|
||||
### Basic TCP Server
|
||||
|
||||
The TCP server starts automatically when Unity loads and listens for client connections. By default:
|
||||
|
||||
- **Default Port**: 25916 (automatically managed)
|
||||
- **Protocol**: Basic TCP with welcome message
|
||||
- **Echo Server**: Currently configured as an echo server (sends received data back to client)
|
||||
|
||||
### Using the Unity Editor UI
|
||||
|
||||
Access the TCP Bridge controls through Unity's menu system:
|
||||
|
||||
1. **Control Window**: `Tools > Codely Bridge > Control Window`
|
||||
- Complete server management interface
|
||||
- Real-time status monitoring
|
||||
- Server start/stop/restart controls
|
||||
- Port management and configuration
|
||||
- Debug logging controls
|
||||
|
||||
2. **Status Window**: `Tools > Codely Bridge > Status Window`
|
||||
- Compact status display (can be docked)
|
||||
- Quick start/stop buttons
|
||||
- Shows current port and connection status
|
||||
|
||||
3. **Menu Actions**: `Tools > Codely Bridge > [Action]`
|
||||
- Quick server operations
|
||||
- Port discovery and management
|
||||
- Debug logging toggle
|
||||
|
||||
### Connecting to the Server
|
||||
|
||||
```bash
|
||||
# Example using telnet (replace 25916 with actual port shown in Unity Console or UI)
|
||||
telnet localhost 25916
|
||||
```
|
||||
|
||||
### Customizing the Protocol
|
||||
|
||||
The current implementation includes a basic echo server. To customize for your needs:
|
||||
|
||||
1. Modify the `HandleClientAsync` method in `UnityTcpBridge.cs`
|
||||
2. Replace the echo logic with your custom protocol handling
|
||||
3. Update the welcome message format if needed
|
||||
|
||||
### Port Management
|
||||
|
||||
```csharp
|
||||
// Get the current port
|
||||
int port = UnityTcpBridge.GetCurrentPort();
|
||||
|
||||
// Check if server is running
|
||||
bool isRunning = UnityTcpBridge.IsRunning;
|
||||
|
||||
// Manually start/stop (usually automatic)
|
||||
UnityTcpBridge.Start();
|
||||
UnityTcpBridge.Stop();
|
||||
```
|
||||
|
||||
## Architecture
|
||||
|
||||
### TCP Server Implementation
|
||||
|
||||
```
|
||||
External TCP Client → Codely Bridge Server → Custom Protocol Handler
|
||||
```
|
||||
|
||||
### Key Components
|
||||
|
||||
- **UnityTcpBridge**: Main TCP server with lifecycle management
|
||||
- **PortManager**: Dynamic port allocation and persistence
|
||||
- **TcpLog**: Logging utility for TCP operations
|
||||
|
||||
### Performance Features
|
||||
|
||||
- **Async Operations**: Non-blocking I/O operations
|
||||
- **Connection Pooling**: Efficient client connection management
|
||||
- **Resource Cleanup**: Automatic cleanup on Unity lifecycle events
|
||||
|
||||
## Configuration
|
||||
|
||||
### Debug Logging
|
||||
|
||||
Enable detailed logging for troubleshooting:
|
||||
|
||||
```csharp
|
||||
// In Unity Editor, set this EditorPref:
|
||||
EditorPrefs.SetBool("UnityTcp.DebugLogs", true);
|
||||
```
|
||||
|
||||
### Port Configuration
|
||||
|
||||
The server automatically manages ports, but you can access port management:
|
||||
|
||||
```csharp
|
||||
// Check if a port is available
|
||||
bool available = PortManager.IsPortAvailable(25916);
|
||||
|
||||
// Get port with fallback
|
||||
int port = PortManager.GetPortWithFallback();
|
||||
|
||||
// Discover a new port
|
||||
int newPort = PortManager.DiscoverNewPort();
|
||||
```
|
||||
|
||||
## Development
|
||||
|
||||
### Building from Source
|
||||
|
||||
1. Clone this repository
|
||||
2. Open in Unity 2021.3 or later
|
||||
3. The TCP server will start automatically
|
||||
4. Check Unity Console for server status
|
||||
|
||||
### Customizing the Protocol
|
||||
|
||||
To implement your custom TCP protocol:
|
||||
|
||||
1. **Modify HandleClientAsync**: Replace the echo server logic
|
||||
2. **Update Welcome Message**: Change the initial handshake
|
||||
3. **Add Message Parsing**: Implement your message format
|
||||
4. **Error Handling**: Add appropriate error handling for your protocol
|
||||
|
||||
Example customization:
|
||||
|
||||
```csharp
|
||||
// In HandleClientAsync method, replace echo logic with:
|
||||
while (!token.IsCancellationRequested && client.Connected)
|
||||
{
|
||||
// Read client message
|
||||
int bytesRead = await stream.ReadAsync(buffer, 0, buffer.Length, token);
|
||||
if (bytesRead == 0) break;
|
||||
|
||||
// Parse your custom message format
|
||||
string message = Encoding.UTF8.GetString(buffer, 0, bytesRead);
|
||||
|
||||
// Process the message according to your protocol
|
||||
string response = ProcessCustomMessage(message);
|
||||
|
||||
// Send response
|
||||
byte[] responseBytes = Encoding.UTF8.GetBytes(response);
|
||||
await stream.WriteAsync(responseBytes, 0, responseBytes.Length, token);
|
||||
}
|
||||
```
|
||||
|
||||
## Troubleshooting
|
||||
|
||||
### Common Issues
|
||||
|
||||
**Port Already in Use**
|
||||
|
||||
- The server will automatically find an alternative port
|
||||
- Check Unity Console for the actual port being used
|
||||
- Use `PortManager.DiscoverNewPort()` to force a new port
|
||||
|
||||
**Server Won't Start**
|
||||
|
||||
- Verify Unity project is loaded properly
|
||||
- Check Unity Console for error messages
|
||||
- Ensure no firewall is blocking the port
|
||||
|
||||
**Client Can't Connect**
|
||||
|
||||
- Verify the server is running (check Unity Console)
|
||||
- Use the correct port number shown in Unity Console
|
||||
- Ensure localhost connectivity
|
||||
|
||||
**Connection Drops**
|
||||
|
||||
- Check if client is sending data within timeout period (60 seconds default)
|
||||
- Enable debug logging to see connection details
|
||||
- Verify client is properly handling the welcome message
|
||||
|
||||
### Debug Logging
|
||||
|
||||
Enable detailed logging to get comprehensive information about:
|
||||
|
||||
- Server startup and port allocation
|
||||
- Client connections and disconnections
|
||||
- Data transmission and errors
|
||||
- Port management decisions
|
||||
|
||||
## License
|
||||
|
||||
This project is licensed under the MIT License.
|
||||
Reference in New Issue
Block a user