收集整理了一份《2024年最新物联网嵌入式全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升的朋友。
需要这些体系化资料的朋友,可以加我V获取:vip1024c (备注嵌入式)
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人
都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
文章目录
修改记录
- 2021.5.19 修改文章格式,在第三节添加了服务器的压缩文件 myweb.war. 添加项目仓库。
- 2022.3.1 myweb.war. 百度网盘失效,请到项目仓库 https://gitee.com/killerp/emqx-web下载
一,前言
之前写过一篇关于EMQX数据持久化到MySQL数据库,但由于这个功能需要EMQX企业版才能实现,而企业版的费用对于我这种学生党而言实在难以负担。于是,我在EMQX官方发现另一种方法也可以实现保存数据。官网对于webhook的示例
预备知识:
http协议与格式
web服务器:web项目基本结构
java语言
tomcat的安装:window系统安装tomcat,linux系统安装tomcat
开发环境:eclipse官网下载
思路:设备的数据上传到emqx服务器,我们需要一个web服务器来接收EMQX服务器post过来数据,然后再将数据保存到数据库。
项目仓库地址:https://gitee.com/killerp/emqx-web
二,搭建基于tomcat的web服务器
首先在主机安装tomcat和java jdk,这是搭建web服务器必须的环境。
具体的安装方法网上很多,找到适合自己的。这里只介绍搭建web服务器。
已经搭建好环境的同学请跳过此步骤
假设你已经完成以上的环境部署,还需要安装开发环境eclipse
,再安装程序中选择安装eclipse ee,这是专门为web开发而设计的开发软件。
打开eclipse,新建工程,选择Dynamic Web Project
给项目取个名称,target runtime选择你主机安装的tomcat的版本,如果你是在云主机安装tomcat,建议在本地电脑也安装同一版本的tomcat,方便调试
接下来就一路next,最后这个页面记得勾选generate
web.xml是配置web服务器的文件,java resources是放java文件的
在下图lib文件夹下添加需要用到的库文件,然后把库文件真正导入项目
库文件请到项目仓库中下载:https://gitee.com/killerp/emqx-web
在webcontent/web-inf/lib
右击项目,选择properties,选择java build path ,点击add jars 找到你的项目lib里的库文件,全部添加进去,最后apply and close,导入库文件完成!
接下来编写一个Java 类,myhttpservlet,它继承自HttpServlet ,用来接收EMQX post过来的数据;
HttpServlet 是一个实现http协议的最重要的java类可以参考这篇博客 httpservlet详解
package myweb;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.io.Reader;
import java.io.StringWriter;
import java.io.Writer;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.tomcat.util.http.fileupload.IOUtils;
import com.mysql.jdbc.StringUtils;
import com.oracle.webservices.internal.api.message.ContentType;
import com.sun.xml.internal.bind.CycleRecoverable.Context;
import com.sun.xml.internal.ws.wsdl.writer.document.Service;
import net.sf.json.JSONArray;
import net.sf.json.JSONObject;
public class FirstServlet extends HttpServlet {
//用来读取post过来的json的缓存区的数据长度
private static final int BUFFER_SIZE = 1024 \* 8;
//一些emqx post过来的数据
private String app_id,device_id,remark,time,state,type;
/\*\*
\* 不知道是什么,反正是必须的
\*/
private static final long serialVersionUID = 1L;
//用来处理get消息
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//doPost(request,response);
//get请求用来获取数据库的数据
}
//用来处理post消息
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//获取post过来的输入流
InputStream in=request.getInputStream();
//创建一个缓存读取器来暂时存贮输入流里的数据
BufferedReader reader = new BufferedReader(new InputStreamReader(in));
//body是json字符串,要解析字符串,拿到对应的值插入数据库
//读取缓存读取器里的body数据并转为字符串格式,这里的body数据为json字符串格式
String body = read(reader);
//从json字符串里获取json对象
JSONObject J=JSONObject.fromObject(body);
//通过键值对的形式,获取json里的值并赋值给变量
app_id= J.getString("app\_id");
device_id=J.getString("device\_id");
time=J.getString("mytime");
state=J.getString("state");
type=J.getString("device\_type");
remark=J.getString("remark");
//把变量的值保存到数据库
DBUutil.update(app_id,device_id,remark,time,state,type);
}
public static String read(Reader reader) throws IOException
{
StringWriter writer = new StringWriter();
try
{
write(reader, writer);
return writer.getBuffer().toString();
}
finally{ writer.close(); }
}
public static long write(Reader reader, Writer writer) throws IOException
{
return write(reader, writer, BUFFER_SIZE);
}
//把缓存器的json数据写入缓存区
public static long write(Reader reader, Writer writer, int bufferSize) throws IOException
{
int read;
long total = 0;
char[] buf = new char[BUFFER_SIZE];
while( ( read = reader.read(buf) ) != -1 )
{
writer.write(buf, 0, read);
total += read;
}
return total;
}
}
再新建一个java 类,dbutil,这个类的作用是对数据库进行操作,这里只写了对数据库进行插入数据的操作,其他操作如更新,删除,查询都可实现
package myweb;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import com.mysql.jdbc.Connection;
import com.mysql.jdbc.log.Log;
public class DBUutil {
static List<ESP8266> ESPlist=new ArrayList<>();//����豸������
private static ESP8266 Device=new ESP8266();//��ʼ������
private static String driver = "com.mysql.jdbc.Driver";// MySql驱动
private static String user = "app";// MySQL的用户名和密码
private static String password = "123456";
//连接数据库的方法
private static Connection getConn(String dbName){
Connection connection;
connection = null;
try{
Class.forName(driver);//加载驱动,需要驱动才能对数据库进行操作
String ip = "118.31.20.121";//数据库的ip地址ַ
//连接数据库,驱动+ip地址+端口号+用户名+密码,端口号默认是3306
connection = (Connection) DriverManager.getConnection("jdbc:mysql://" + ip + ":3306/" + dbName,
user, password);
}catch (Exception e){
e.printStackTrace();
}
//返回一个connection对象
return connection;
}
//这个是添加设备到数据库,不用看
public static void bind\_id(String app_id,String device_id){
Connection connection=getConn("MQTTDATA");
String sql="INSERT INTO user\_bind\_devices (app\_id,device\_id) VALUES (?,?)";
if (connection!=null){
try {
**收集整理了一份《2024年最新物联网嵌入式全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升的朋友。**
![img](https://img-blog.csdnimg.cn/img_convert/3dd25cd9649f104118ee7bacb9d0d085.png)
![img](https://img-blog.csdnimg.cn/img_convert/f8dc54f07febbb789675cc79958e2291.png)
**[如果你需要这些资料,可以戳这里获取](https://bbs.csdn.net/topics/618679757)**
**需要这些体系化资料的朋友,可以加我V获取:vip1024c (备注嵌入式)**
**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人**
**都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**
很简单,就是希望能够帮助到想自学提升的朋友。**
[外链图片转存中...(img-qMlVKGr6-1715869994043)]
[外链图片转存中...(img-U7fr55Hd-1715869994044)]
**[如果你需要这些资料,可以戳这里获取](https://bbs.csdn.net/topics/618679757)**
**需要这些体系化资料的朋友,可以加我V获取:vip1024c (备注嵌入式)**
**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人**
**都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**