首先通过nodejs和mongodb建立后端服务器

一、在windows平台下启动mongodb服务器

1、进入mongodb的安装目录,并进去bin目录启动mongod

2、在d盘建立mongodb\data文件夹作为数据存储目录

mongod.exe --dbpath d:\mongodb\data

二、建立js文件,并通过nodejs启动

1、当向服务器发送01指令时,服务器将从mongodb 读取数据,并返回

var HOST = "localhost";
var PORT = 6969;
var dgram = require('dgram');
var server_udp = dgram.createSocket('udp4');
var mongo=require("mongodb");
var DB_PORT=27017;
var server_database=new mongo.Server(HOST,DB_PORT,{auto_reconnect:true});
var db=new mongo.Db("test",server_database,{safe:true}); db.open(function (err,db) {//连接数据库
if(err)
{
console.log("error");
throw err;
}
else{
db.collection("student", function (err,collection) {
collection.insert({ name:"jinjian",score:"100"}, function (err,docs) {
console.log(docs);
db.close(false);
});
});
}
}); server_udp.on('listening',function(){
var address = server_udp.address();
console.log("server listening " + address.address + " : "+ address.port);
console.log("\n");
}); server_udp.on('message',function(message,remote){ console.log(""+message);
switch( ""+message)
{
case ("01"):
{
console.log("receive 01");
db.open(function (err,db) {
db.collection("student", function (err,collection) {
if(err) throw err;
else{
collection.find({}).toArray(function(err,docs){
if(err) throw err;
else{
var str = JSON.stringify(docs);
server_udp.send(str,0,str.length,6967,remote.address);
console.log(str);
db.close(false);
}
});
}
});
});
break;
} case ("02"):
{
console.log("receive 02");
break;
} case ("03"):
{
console.log("receive 03");
break;
} }
console.log(remote.address +":" + message );
console.log("\n"); });
server_udp.bind(PORT,HOST);

三、编写MFC界面

1、MFC接受到数据后解析代码如下(程序使用了jsoncpp-json数据解析库)

	Json::Reader reader;
Json::Value json_object;
int len = strlen((char *)lParam);
char* temp = new char [len];
memcpy(temp,(char *)lParam,len); if (!reader.parse(temp, json_object))
return 0;
int size = json_object.size(); const Json::Value arrayObj = json_object;
for (int i=0; i<arrayObj.size(); i++){
string id = arrayObj[arrayObj.size()-1-i]["number"].asString();
string name= arrayObj[arrayObj.size()-1-i]["name"].asString();
string score = arrayObj[arrayObj.size()-1-i]["score"].asString(); int n = m_list.InsertItem(0,id.c_str());
m_list.SetItemText(n,1,name.c_str());
m_list.SetItemText(n,2,score.c_str()); //fprintf(pfOutput, "%s\n",id.c_str());
//fprintf(pfOutput, "%s\n",firstname.c_str());
//fprintf(pfOutput, "%s\n",username.c_str());
}

四、测试读取数据库,MFC向数据库发送“01”指令,并将返回的数据显示在列表中

1、向mongodb插入数据。进入mongodb程序的bin目录

D:\Mongodb\bin>mongo

>use test

db.student.insert({"01":"x1","02","x2",.....});

2 MFC读取效果如下

MFC+mongodb+nodejs 数据库的读取与写入操作的更多相关文章

  1. 数据库并行读取和写入(Python实现)

    这篇主要记录一下如何实现对数据库的并行运算来节省代码运行时间.语言是Python,其他语言思路一样. 前言 一共23w条数据,是之前通过自然语言分析处理过的数据,附一张截图: 要实现对news主体的读 ...

  2. java文件创建、删除、读取、写入操作大全

    一.获得控制台用户输入的信息 public String getInputMessage() throws IOException...{ System.out.println("请输入您的 ...

  3. php以数组做为配置文件的读取和写入操作

    最近想用php开发个简单的文章管理系统,主要是做一批垃圾采集站,目前网上的cms都太多功能了,导致修改个模板要很多文件,花费很多功夫.开始用thinkphp框架做,感觉还是麻烦,后来改用ci,做好了后 ...

  4. java===java基础学习(5)---文件读取,写入操作

    文件的写入读取有很多方法,今天学到的是Scanner和PrintWriter 文件读取 Scanner in = new Scanner(Paths.get("file.txt") ...

  5. 记-Golang日志文件读取及写入操作

    Golang语言的 os 包中OpenFile 函数,如下所示: func OpenFile(name string, flag int, perm FileMode) (*File, error) ...

  6. testbench的设计 文件读取和写入操作 源代码

    十大基本功之 testbench 1. 激励的产生 对于 testbench 而言,端口应当和被测试的 module 一一对应.端口分为 input,output 和 inout 类型产生激励信号的时 ...

  7. 用Java实现对英文版《飘》的文件读取与写入操作

    从文件读入<飘>的英文版,并将结果输出到文件中 要求一: 实现对英文版<飘>的字母出现次数统计 package File; import java.io.FileInputSt ...

  8. 表数据文件DBF的读取和写入操作

    import sys import csv import struct import datetime import decimal import itertools from cStringIO i ...

  9. C#读取和写入XML文件

    关于xml是属于一个比较重要的东西,在平时开发的过程中,这块内容最主要的是要掌握XML内容的读取和写入操作. 一.什么是XML? XML 指可扩展标记语言(EXtensible Markup Lang ...

随机推荐

  1. YUM安装调试以及命令具体解释

    背景,须要安装cacti,google了非常多安装资料.须要先yum安装一些准备lib包,比方snmp以及openssl等等. [root@mysqlvm2 ~]# yum install net-s ...

  2. C# to IL 10 Exception Handling(异常处理)

    Exception handling in IL is a big let down. We expected a significant amount of complexity,but were ...

  3. node api 之:util

    util 库的使用: const util = require('util'); util 的方法: 方法 含义 util.inherits(constructor, superConstructor ...

  4. Zookeeper常用操作命令create,set,delete

    一.zk特性的session的基本原理 1.客户端与服务端之间的连接存在会话 2.每个会话都可以设置一个超时时间 3.心跳结束,session则过期 4.session过期,则临时节点znode会被抛 ...

  5. 使用vivado将bit文件转化为mcs文件

    使用vivado将bit文件转化为mcs文件 1.在Tcl Console中运行脚本: write_cfgmem -force -format MCS -size 64 -interface spix ...

  6. CentOS 7 firewalld vsftpd开放端口

    开放FTP端口的方法: 暂时开放 ftp 服务 firewall-cmd --add-service=ftp 1 永久开放 ftp 服务 firewall-cmd --add-service=ftp ...

  7. Delphi实现菜单项上出现提示

    type TMenuHintWindow = class(THintWindow) private FTimerShow: TTimer; FTimerHide: TTimer; procedure ...

  8. %cd% 与 %~dp0% 区别

    @echo off echo path:%~dpnx0% ipconfig /all|findstr "\<IPv4 适配器\>" %cd%  在批处理和命令窗口都能使 ...

  9. 53题看透java线程

    1) 什么是线程? 线程是操作系统能够进行运算调度的最小单位,它被包含在进程之中,是进程中的实际运作单位.程序员可以通过它进行多处理器编程,你可以使用多线程对运算密集型任务提速.比如,如果一个线程完成 ...

  10. 黄聪:Pjax无刷新跳转页面实现,支持超链接与表单提交

    什么是pjax? 当你点击一个站内的链接的时候,不是做页面跳转,而是只是站内页面刷新.这样的用户体验,比起整个页面都闪一下来说, 好很多. 其中有一个很重要的组成部分, 这些网站的ajax刷新是支持浏 ...