Skip to content

Latest commit

 

History

History
41 lines (29 loc) · 2.26 KB

README.md

File metadata and controls

41 lines (29 loc) · 2.26 KB

da Websocket Client

I googled to find WS Client that support both WS/WSS with specified certificate file but not found anyone.
I don't want wasting time for finding it anymore. So, I decided to make this tool for work and those who needed.

Features

  • Support both Websocket (WS) & Websocket Secure (WSS) protocol
  • Support to use a specified certification file manually
  • Support to use self-signed & publicly-trusted-signed certification automatically
  • Support send/receive/display Text & Binary data type
  • Support custom websocket header
  • Support save/load preferences from JSON file
  • Support cross-platform like Windows, Linux, macOS, etc
  • Others

Instructions

Note: This project required Python 3.6 or newer

  1. Run the command git clone https://github.com/vic4key/da-Websocket-Client.git then cd da-Websocket-Client to get this repository
  2. Run the command pip install -r requirements.txt to install required packages
  3. Run the command python app.py to run app from the source code
  4. (Optional) To build executable file, run the command pyinstaller --clean --distpath=bin da-Websocket-Client.spec
  5. (Optional) To create a package, run the command file create-package.cmd (for Windows) or ./create-package.sh (for Linux or macOS) or directly download packages here

Note: (Optional) The sample SSL file for local machine (localhost & 127.0.0.1) can be found in the preferences folder or you can generate your own SSL file by run the following command

openssl req -x509 -newkey rsa:4096 -sha256 -days 3650 -nodes -keyout local.pem -out local.pem -subj "/CN=localhost" -addext "subjectAltName=IP:127.0.0.1"

Screenshots

To-Do

  • Consider to support sending file
  • Consider to support more like Socket IO, MQTT, etc
  • Support debug logging to allow user knowing what is backend working like packet header, raw data, etc
  • Support python plugin system to allow user easy to custom, hijack, mitm, handle, etc without any complex installation DOING

Contact

Feel free to contact via Twitter / Gmail / Blog / Website