博主最近在最有作一个嵌入式课程设计,要求是利用基于cortax a8的物联网实验箱作一个简单的嵌入式网页交互系统做为课程设计来验收评分。由于自己本身是学前端的,因此网页部分并非重点,主要是和boa服务器之间的通讯,课程实验给的例子是直接使用printf来打印html标签造成新的页面,有过前端开发经验的人都知道这种作法效率低下并且没有办法实现异步刷新,因此博主采用ajax来进行boa服务器下的异步通讯。html
主要实现及踩过的坑以下:前端
1. get 仍是 post请求:怎么发请求参见W3School上的ajax教程jquery
推荐通常人没有前端基础的人使用get请求,由于只须要在请求的参数作一个字符串拼接就能够完成基本的ajax请求,具体实现能够参照一下这个网址(http://blog.csdn.net/huguohu2006/article/details/7755107),接下来重点讲一下post请求,优点这里我就很少讲了,前面的教程里面都有,主要讲一下实现方式:linux
function sender(url, data) { var xhr = createXHR(); if (xhr) { xhr.onreadystatechange = function() { if (xhr.readyState == 4 && xhr.status == 200) { console.log(xhr.responseText); console.log(xhr.responseText.toString()); var returnValue = xhr.responseText.toString(); console.log(returnValue); return returnValue; // firefox下xhr.responseText做为返回值失效的问题 // ie能够利用return来获得值。但firefox则不能,只能在readyState == 4 && status == 200时处理一个函数 // 这个函数应看成为一个参数传递入函数。有个奇怪现象你若是去除红线部分的注释,firefox又能够取到值。 // 估计是firefox使用ajax取值有个延时形成。 //return xhr.responseText.toString(); } }; xhr.open("post", url, true); // send(string) 仅适用于post请求 xhr.send(data); } else { //XMLHttpRequest对象建立失败 alert("浏览器不支持,请更换浏览器!"); } }
利用调用sender函数来实现ajax,函数的两个参数分别是请求的url和要发送的数据,注意post请求只能发送string类型的数据。若是要发送其余类型的数据建议采用jquery封装的ajax方法,这里之因此采用原生的ajax方法来发送数据主要有如下几个缘由:web
下面再介绍一下cgi文件对http请求的处理,示例函以下:ajax
#include <stdlib.h> #include <stdio.h> #include <string.h> char* get_cgi_data(FILE* fp, char* method) { char* input; int len; int size=1024; int i=0; if (strcmp(method, "GET") == 0) /**< GET method */ { input = getenv("QUERY_STRING"); return input; } else if (strcmp(method, "POST") == 0) /**< POST method */ { len = atoi(getenv("CONTENT_LENGTH")); input = (char*)malloc(sizeof(char) * (size+1)); if (len == 0) { input[0] = '\0'; return input; } while (1) { input[i] = (char)fgetc(fp); if (i == size) { input[i+1] = '\0'; return input; } --len; if (feof(fp) || (!(len))) { i++; input[i] = '\0'; return input; } i++; } } return NULL; } int main(void) { char* input; char* method; char name[64]; char passwd[64]; int i=0; int j=0; printf("Content-type:text/html\n\n"); printf("The following is query result:"); method = getenv("REQUEST_METHOD"); input = get_cgi_data(stdin, method); printf("string is: %s", input); return 0; }
上面包含了c语言处理两种请求的方法,get请求比较简单,直接使用getenv("QUERY_STRING")就能够获取到请求发送的数据,post请求的处理则比较负责,先获取请求内容长度,而后根据长度来动态分配一个等长的字符串空间,将发送的数据传给字符串,而后再根据本身项目的须要进行相应的处理便可。浏览器
PS:发送http请求时对应的成功程序printf以后就是http请求接受到的相应,也就是对应的xhr的responseText属性值,另外.c文件须要理由arn-linux-gcc -o helloworld.cgi helloworld.c命名交叉编译获得对应的.cgi文件。而后博主用的是在每一次请求成功以后继续发送下一次请求,由于若是直接使用setInterval函数进行循环请求传感器数据的话会产生比较大的延时,基本等同于进程,若是直接经过文件存储传感器数据的方式则可使用setInterval函数。服务器