asp.net 使用JS获得串口数据
JavaScript语言通常是一种网页编程语言,比较适合前台的一些应用设计。对于本地设备和数据的操作有比较大的限制。由于项目的需要,我需要获得本机的串口数据并显示在web端。我们有很多中方法实现功能,在实际的操作过程中我测试两种方式获得数据。第一种方法是使用ActiveX控件,JS调用MSCOMM32.dll的串口控件对串口进行控制。第二种方法是使用C#语言的控件对串口进行控制,然后使用JS+AJAX与C#进行交互获得串口数据。
先说说两种方法各自的特点:方法一使用的是微软的ActiveX控件MSCOMM32.dll,该控件可以直接对串口进行操作,而JS也可以通过调用接口进行控制。不过ActiveX控件目前只针对IE浏览器支持较好,我用的是Chrome那就爱莫能助了。方法二目前应该是比较流行的,C#用来做后台控制个人觉得还是很不错的,而AJAX在前后台数据交互方面的作用应该也是有目共睹的。唯一的不足可能就是在数据同步方面可能会稍有延迟,毕竟AJAX是一个异步传输的标准。
首先,我尝试了方法一。实现一个htm文件和一个js文件。关于串口调用的代码很简单,htm文件中的主要工作是添加MSCOMM32.dll控件的调用。
- <object classid="clsid:648A5600-2C6E-101B-82B6-000000000014" id="MSComm1" codebase="MSCOMM32.OCX"
- type="application/x-oleobject" style="left: 54px; top: 14px">
- <param name="CommPort" value="4"><!--设置并返回通讯端口号。-->
- <param name="DTREnable" value="1">
- <param name="Handshaking" value="0">
- <param name="InBufferSize" value="1024">
- <param name="InputLen" value="0">
- <param name="NullDiscard" value="0">
- <param name="OutBufferSize" value="512">
- <param name="ParityReplace" value="?">
- <param name="RThreshold" value="1">
- <param name="RTSEnable" value="1">
- <param name="SThreshold" value="2">
- <param name="EOFEnable" value="0">
- <param name="InputMode" value="0"><!--comInputModeText 0 (缺省) 通过 Input 属性以文本方式取回数据。comInputModeBinary 1 通过 Input 属性以二进制方式检取回数据。-->
- <param name="DataBits" value="8">
- <param name="StopBits" value="1">
- <param name="BaudRate" value="38400">
- <param name="Settings" value="38400,N,8,1">
- </object>
以上代码主要设置了串口号,波特率,收发缓冲等等(具体使用说明网上有很多)。
而在js文件中则主要实现打开关闭串口,以及收发数据的操作。
- function OpenPort()
- {
- var cmd_send = "";
- var result = $('txtReceive').value;
- var results = result.split(',');
- for(var i=0;i<results.length;i++)
- {
- cmd_send += String.fromCharCode(eval(results[i]));
- }
- if(MSComm1.PortOpen==false)
- {
- MSComm1.PortOpen=true;
- MSComm1.Output=cmd_send;//发送命令
- }
- else
- {
- window.alert ("已经开始接收数据!");
- }
- }
- function ClosePort()
- {
- if(MSComm1.PortOpen==true)
- {
- MSComm1.PortOpen=false;
- }
- else
- {
- window.alert ("串口已经关闭!");
- }
- }
- function SendMessage()
- {
- var cmd_send = "";
- var result = $('txtReceive').value;
- var results = result.split(',');
- for(var i=0;i<results.length;i++)
- {
- cmd_send += String.fromCharCode(eval(results[i]));
- }
- if(MSComm1.PortOpen==false)
- {
- window.alert ("串口已经关闭!!");
- }
- else
- {
- MSComm1.Output=cmd_send;//发送命令
- }
- }
实现之后的效果是这样的:
我们看到的上面的文本框使我发送的指令,而下面的文本框就是我收到的数据。
然后,我使用方法二。使用C#打开串口,使用jQuery的函数和C#进行通讯获取当前的数据(包括当前经纬度,时间日期)。C#的代码如下:
- public static void Read()
- {
- sp = new SerialPort("COM4", 38400, Parity.None, 8, StopBits.One);
- sp.Close();
- sp.ReadBufferSize = 512;
- sp.ReceivedBytesThreshold = 1;
- sp.Open();
- while (true)
- {
- try
- {
- Databuffer += sp.ReadExisting();
- }
- catch (TimeoutException) { }
- }
- }
其中sp为串口类SerialPort。打开串口之后调用ReadExisting函数读取串口数据。
JS中获取当前数据的代码如下:
- function GPSGetDataTimer() {
- Referece = "data"; //获得GPS数据
- $.post("GetGPSDataComm.aspx",
- { REF: encodeURI(Referece)
- },
- function (data) {
- alert(data);
- });
- }
我按照一定的频度向GetGPSDataComm.aspx文件发出请求,然后获得当前的数据,并且把字符串显示出来。效果如下图:

下一步我计划在前台将字符串以图形化的方式显示,这样便会更加直观的观测到串口的数据。
asp.net 使用JS获得串口数据的更多相关文章
- [转]WEB页获取串口数据
本文转自:https://www.cnblogs.com/rockyhm/p/3434200.html 最近做一个B/S的项目,需要读取电子秤的值,之前一直没做过,也没有经验,于是在网上找到很多 大 ...
- WEB页获取串口数据
最近做一个B/S的项目,需要读取电子秤的值,之前一直没做过,也没有经验,于是在网上找到很多 大致分两种 使用ActiveX控件,JS调用MSCOMM32.dll的串口控件对串口进行控制 使用C#语言 ...
- 通过js获取前台数据向一般处理程序传递Json数据,并解析Json数据,将前台传来的Json数据写入数据库表中
摘自:http://blog.csdn.net/mazhaojuan/article/details/8592015 通过js获取前台数据向一般处理程序传递Json数据,并解析Json数据,将前台传来 ...
- Jquery zTree结合Asp.net实现异步加载数据
zTree结合Asp.net实现异步加载数据 实现简单操作 zTree 下载 api 访问 :http://www.ztree.me/v3/main.php 例子中用到json数据转化 newtons ...
- 初探原生js根据json数据动态创建table
初探原生js根据json数据动态创建table 小生以实习生的职位进入了一家非纯软件的公司做asp.net开发,大半个月下来发现公司里居然没有前端工程师,这令我很诧异,跟着公司做项目,发现前端后台没有 ...
- ASP.NET+d3.js实现Sqlserver数据库的可视化展示
效果: 数据库端: 前端展示: 实现原理: 1.在数据段建立两个存储过程 queryUserAnsawer(id) 根据用户ID返回每一题的得分,主要是bcp exe时不能直接在sqlserver中执 ...
- 基于MQTT的串口数据转发器
问: ComHub能做什么?ComHub使用MQTT协议,将串口数据经TCP分发出去.这种结构可以实现很多功能:1.COM-Over-TCP: 将COM数据使用TCP远程传送;2.COM多播:一个CO ...
- ASP模拟POST请求异步提交数据的方法
这篇文章主要介绍了ASP模拟POST请求异步提交数据的方法,本文使用MSXML2.SERVERXMLHTTP.3.0实现POST请求,需要的朋友可以参考下 有时需要获取远程网站的某些信息,而服务器又限 ...
- C#SerialPort如何读取串口数据并显示在TextBox上
SerialPort中串口数据的读取与写入有较大的不同.由于串口不知道数据何时到达,因此有两种方法可以实现串口数据的读取.一.线程实时读串口:二.事件触发方式实现. 由于线程实时读串口的效率不是十分高 ...
随机推荐
- java编译优化
#java编译器对`String常量表达式`的优化: - 1.String+String 可以被编译器识别为常量表达 String a="ab" ; String b=" ...
- Node.js学习笔记(1) - Node.js简介
近期在看一些Node.js的知识,看完后觉得,一些前面的东西忘记了,于是整理一下,方便自己查阅,也希望对学习Node.js的朋友有些帮助: 当然以下只是我个人的观点和理解,不喜勿喷,也望大神指教. 一 ...
- Cocos2d—X游戏开发之CCToggle(菜单标签切换)CCControlSwitch(开关切换)
Cocos2d—X游戏开发之CCToggle(菜单标签切换) 首先继承子CCMenu,是菜单标签中的一种.‘ class CC_DLL CCMenuItemToggle : public CCMenu ...
- PHPExcel 导出2003和2007的excel文档实例
require_once 'common/excel/PHPExcel.php'; require_once 'common/excel/phpExcel/Writer/Excel2007.php'; ...
- Material Design(原质化设计)视觉设计语言规范 踏得网镜像
Android 5.0 Lollipop(棒棒糖,也就是之前的代称Android L)全面实践了谷歌最新研发的 Material Design 设计语言规范,只是该设计规范并不是仅针对移动平台. 我们 ...
- ExtJs Ext.data.Store 处理
var storeCpye = new Ext.data.GroupingStore({ proxy : new Ext.data.HttpProxy({ url : 'cxgl_cpye.app?d ...
- Oracle 快速插入1000万条数据的实现方式
1.使用dual配合connect by level create table BigTable as select rownum as id from dual connect by level & ...
- 使用依赖关系注入在 ASP.NET Core 中编写干净代码
ASP.NET Core 1.0 是 ASP.NET 的完全重新编写,这个新框架的主要目标之一就是更多的模块化设计.即,应用应该能够仅利用其所需的框架部分,方法是框架在它们请求时提供依赖关系.此外,使 ...
- Selenium2+python自动化29-js处理多窗口
前言 在打开页面上链接的时候,经常会弹出另外一个窗口(多窗口情况前面这篇有讲解:Selenium2+python自动化13-多窗口.句柄(handle)),这样在多个窗口之间来回切换比较复杂,那么有没 ...
- Mac 在启动eclipse时 Failed to load JavaHL Library解决方法
在Mac 10.9.1系统里, 在Eclipse中安装svn的插件,出现如下提示 方法一: 1.根据提示进入链接 http://subclipse.tigris.org/wiki/JavaHL 2. ...