I am new to websocket and I have been assigned an existing working chat module which, for now, just sends messages to other users. I have been asked to integrate feature where a user can send "attachments" to each other. FYI, I came across this link which says few point but I need more clarity.
My questions:
- What is the server-side requirement there for its implementation?
- Can someone provide a little elaborated answer? More codes rather than words are highly appreciated.
- Do I need to use use ng-file-upload for the same, DEMO
- Any relevant link for this question
UPDATE 1:
I tried implementing below code:
var input = document.querySelector('input[type=file]');
function readFile(event) {
var ws_msg = {content: event.target.result };
// Here I call the ws.send method
send_chat_message($scope.sender, $scope.receiver , ws_msg );
}
function changeFile() {
var file = input.files[0];
var reader = new FileReader();
reader.addEventListener('load', readFile);
reader.readAsText(file);
}
input.addEventListener('change', changeFile);
Selecting a file automatically tries to send it over ws but for some weird reason, the WS connection is getting closed immediately.
I have tried below sample code. I have used https://github.com/websockets/ws for web-socket server. and in HTML/jS I have modified code like below works fine. Steps are below. (Hope you have node installed).
Create a server.js file and add below code.
run node server using node server.js, your websocket server is up on localhost:8080
In your browser js change code as below (you are using angular do the change accordingly later as per your requirement)
load your JS/HTML and upload a file you should see to console logs in your node server console.
you can update your node js server code:
Reference: Create image from ArrayBuffer in Nodejs
And client(browser side js) code as: