Write data to USB HID using Javascript, HTML5, or any cross platform language (supports Android)

旧巷老猫 提交于 2019-12-02 23:22:35

I've actually thought about how to do things similar to this....

Here's is one way sure way to do it if you have control over the computer which has the usb device attached:

Have the computer with the USB device run a web server such as apache/php. Have it only listen to localhost.

Then in the html page being viewed, execute an ajax post to localhost/somescript.php (or cgi or cfm or whatever).

In php/cgi script communicate to the USB device and then return a json string to the browser saying something happened.


UPDATE:


Another approach is to use Custom URL Protocols. You create an executable and "install" it on the client computer along with your custom url protocol.

Then you can invoke the executable from the browser using your custom url protocol.

If the usb device you want to control is a barcode printer, you can use jZebra

https://code.google.com/p/jzebra/

This is an applet which directly communicates to locally connected printers.

There is one more alternative Web Socket.Create a web socket server which will access the usb device in local system.

Connect your web server using Web Socket from Web Application.Web Socket has standard Api

You can do something like this

  var host = "wss://localhost:25000/test";

  Websokcet ws = new WebSocket(host);

You can create your web sokcet Server using RFC 6455

for older browser you can think of http server as well.

Please have a look at JSFS. It works similar to Chris_vr's approach and is already a working solution.

https://github.com/jsfsproject/jsfs. It's free and licensed under GPL.

How about this?

Writing to a serial port:

var writeSerial=function(str) {
  chrome.serial.write(connectionId, str2ab(str), onWrite);
}
// Convert string to ArrayBuffer
var str2ab=function(str) {
  var buf=new ArrayBuffer(str.length);
  var bufView=new Uint8Array(buf);
  for (var i=0; i<str.length; i++) {
    bufView[i]=str.charCodeAt(i);
  }
  return buf;
}

more at http://developer.chrome.com/apps/app_hardware.html

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!