anysocket
v0.4.29
طبقة شبكية مجردة عبر وسائل نقل متعددة، لا تعتمد على العميل/الخادم مع دعم E2EE
هذا عمل قيد التقدم وواجهة برمجة التطبيقات (API) عرضة للتغيير.
AnySocket.Packer
)/dist/anysocket.browser.js
)** نقل http تجريبي
معلومات: يتم تعبئة/تفكيك وسيطات واستجابات RPC الثنائية تلقائيًا ( AnySocket.Packer.pack
/ AnySocket.Packer.unpack
).
انظر المعايير
npm install -- save anysocket
أو
< script src =" /dist/anysocket.browser.js " > </ script >
أو (في حالة استخدام AnySocketHTTP)
< script src =" @anysocket " > </ script >
يقوم المثال التالي بتشغيل خادم websocket على المنفذ 3000.
const AnySocket = require ( "anysocket" ) ;
const server = new AnySocket ( ) ;
const PORT = 3000 ;
server . listen ( "ws" , PORT )
. then ( ( ) => {
console . log ( "Listening on port:" , PORT ) ;
} )
. catch ( ( err ) => {
console . error ( "Failed to start server:" , err ) ;
} ) ;
server . on ( "connected" , async ( peer ) => {
console . log ( "Connected" , peer . id ) ;
console . log ( await peer . getSyncedTime ( ) ) // { time: 1674671482107, rtt: 2, offset: 0 }
peer . send ( {
hello : "world"
} ) ;
} ) ;
server . on ( "message" , ( packet ) => {
console . log ( "From:" , packet . peer . id , "Message:" , packet . msg ) ;
} ) ;
server . on ( "disconnected" , ( peer , reason ) => {
console . log ( "Disconnected" , peer . id , "Reason:" , reason ) ;
} ) ;
يتصل المثال التالي بمقبس ويب على المنفذ 3000
const AnySocket = require ( "anysocket" ) ;
const client = new AnySocket ( ) ;
const PORT = 3000 ;
client . connect ( "ws" , "127.0.0.1" , PORT )
. then ( ( ) => {
console . log ( "Connected to server" ) ;
} )
. catch ( ( err ) => {
console . error ( "Failed to connect to server:" , err ) ;
} ) ;
// after negotiating the AUTH packet, it will trigger the connect event
client . on ( "connected" , async ( peer ) => {
console . log ( "Connected" , peer . id ) ;
console . log ( await peer . getSyncedTime ( ) ) // { time: 1674671482107, rtt: 2, offset: 0 }
peer . send ( {
hello : "world"
} ) ;
} ) ;
client . on ( "message" , ( packet ) => {
console . log ( "From:" , packet . peer . id , "Message:" , packet . msg ) ;
} ) ;
client . on ( "disconnected" , ( peer , reason ) => {
console . log ( "Disconnected" , peer . id , "Reason:" , reason ) ;
} ) ;
المزيد في مجلد examples
.
انظر مجلد الوثائق والأمثلة
* سيتطلب هذا تغييرًا في البروتوكول، حيث يفترض البروتوكول أن الحزم يتم إرسالها باستخدام اتصال منظم وموثوق
معهد ماساتشوستس للتكنولوجيا