A flutter plugin for aspx.net SignalR client for Android, iOS, macOS and Web
Note: This library is NOT compatible with ASP.NET Core SignalR
Android | iOS | macOS | Web | Windows | Linux |
---|---|---|---|---|---|
✔️ | ✔️ | ✔️ | ✔️ |
dependencies:
signalr_socket: ^1.1.6 #latest version
Initialize SignalR Socket & connect to server.
SignalrSocket signalrSocket = SignalrSocket(
url: 'https://signalr.socket.com',
hubName: 'hubName',
eventName: 'eventName',
queryString: {'key': 'value'},
updateConnectionStatus: (status) {
debugPrint("signalr socket update connection status ${status.name}");
},
newMessage: (message) {
debugPrint("signalr socket new message $message");
},
);
signalrSocket.connect();
- Add proguard rules for release mode in android
- Create a new file in your android project: android/app/proguard-rules.pro
- Add the following lines to the proguard-rules.pro
-keep class com.github.signalr4j.client.hubs.HubResult { *; }
-keep class com.github.signalr4j.client.hubs.HubInvocation { *; }
-keep class com.github.signalr4j.client.hubs.HubProxy$* { *; }
-keep class com.github.signalr4j.client.hubs.HubConnection {*;}
If you want a HTTP url, then you need to add the following lines to the manifest of your android project.
<application
android:usesCleartextTraffic="true">
</application>
- Add some js files to your web project in 'web/signalR_js'
- Download javascript files here https://github.com/ARASHz4/flutter_signalR_js/archive/refs/tags/2.4.3.zip
- Add 3 files 'jquery.min.js', 'jquery.signalR-2.4.3.min.js' and 'socketConnection.js' in 'web/signalR_js' folder
- Go to 'web/index.html' and add the following lines in head
<head>
<!--other lines-->
<script defer type="application/javascript" src="signalR_js/jquery.min.js"></script>
<script defer type="application/javascript" src="signalR_js/jquery.signalR-2.4.3.min.js"></script>
<script defer type="application/javascript" src="signalR_js/socketConnection.js"></script>
</head>