Android串口通信可以实现设备与设备之间通过设备线连接进行数据(消息)传递
(一)导入so库
(二)在moudle的build中添加jniLibs
buildTypes { sourceSets { main { jni.srcDirs = [] } } } 12345
(三)添加Google的SerialPort
添加的是Google的所以必须创建android_serialport_api包
如需要更改SerialPort、SerialPortFinder位置需要重新生成so库
(四)创建串口通信工具类SerialPortUtils
package com.demo.serialport; import android.util.Log; import java.io.File; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import android_serialport_api.SerialPort; /** * @author *** */ public class SerialPortUtils { private final String TAG = "SerialPortUtils"; // private String path = "/dev/ttyS1"; // private int baudrate = 9600; public boolean serialPortStatus = false; //是否打开串口标志 public String data_; public boolean threadStatus; //线程状态,为了安全终止线程 public SerialPort serialPort = null; public InputStream inputStream = null; public OutputStream outputStream = null; public ChangeTool changeTool = new ChangeTool; /** * 打开串口 * @return serialPort串口对象 */ public SerialPort openSerialPort(String path%2cint baudrate){ try { serialPort = new SerialPort(new File(path)%2cbaudrate%2c0); this.serialPortStatus = true; threadStatus = false; //线程状态 //获取打开的串口中的输入输出流,以便于串口数据的收发 inputStream = serialPort.getInputStream; outputStream = serialPort.getOutputStream; new ReadThread.start; //开始线程监控是否有数据要接收 } catch (IOException e) { Log.e(TAG%2c "openSerialPort: 打开串口异常:" + e.toString); return serialPort; } Log.d(TAG%2c "openSerialPort: 打开串口"); return serialPort; } /** * 关闭串口 */ public void closeSerialPort{ try { inputStream.close; outputStream.close; this.serialPortStatus = false; this.threadStatus = true; //线程状态 serialPort.close; } catch (IOException e) { Log.e(TAG%2c "closeSerialPort: 关闭串口异常:"+e.toString); return; } Log.d(TAG%2c "closeSerialPort: 关闭串口成功"); } /** * 发送串口指令(字符串) * @param data String数据指令 */ public void sendSerialPort(String data){ Log.d(TAG%2c "sendSerialPort: 发送数据"); try { byte[] sendData = data.getBytes; //string转byte[] this.data_ = new String(sendData); //byte[]转string if (sendData.length > 0) { outputStream.write(sendData); outputStream.write('n'); //outputStream.write('r'+'n'); outputStream.flush; Log.d(TAG%2c "sendSerialPort: 串口数据发送成功"); } } catch (IOException e) { Log.e(TAG%2c "sendSerialPort: 串口数据发送失败:"+e.toString); } } /** * 单开一线程,来读数据 */ private class ReadThread extends Thread{ @Override public void run { super.run; //判断进程是否在运行,更安全的结束进程 while (!threadStatus){ Log.d(TAG%2c "进入线程run"); //64 1024 byte[] buffer = new byte[64]; int size; //读取数据的大小 try { size = inputStream.read(buffer); if (size > 0){ Log.d(TAG%2c "run: 接收到了数据:" + changeTool.ByteArrToHex(buffer)); Log.d(TAG%2c "run: 接收到了数据大小:" + String.valueOf(size)); onDataReceiveListener.onDataReceive(buffer%2csize); } } catch (IOException e) { Log.e(TAG%2c "run: 数据读取异常:" +e.toString); } } } } //数据回调 public OnDataReceiveListener onDataReceiveListener = null; public static interface OnDataReceiveListener { public void onDataReceive(byte[] buffer%2c int size); } public void setOnDataReceiveListener(OnDataReceiveListener dataReceiveListener) { onDataReceiveListener = dataReceiveListener; } } 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
package com.demo.serialport; /** * @author *** */ public class ChangeTool { /** * byte数组转16进制字符串 * * @param bytes byte数组 * @return 16进制字符串 */ public String ByteArrToHex(byte[] bytes) { String strHex; StringBuilder *** = new StringBuilder; for (byte aByte : bytes) { strHex = Integer.toHexString(aByte & 0xFF); *** .append(" ").append((strHex.length == 1) ? "0" : "").append(strHex); // 每个字节由两个字符表示,位数不够,高位补0 } return *** .toString.trim; } /** * byte字节转int * * @param b byte字节 * @return int */ public static int byteToInt(byte b) { int x = b & 0xff; if (x == 127) { return 0; } return x; } } 123456789101112131415161718192021222324252627282930313233343536373839
package com.demo.serialport; import android.os.Bundle; import android.util.Log; import android.view.View; import android.widget.Button; import android.widget.EditText; import androidx.appcompat.app.AppCompatActivity; /** * @author *** */ public class MainActivity extends AppCompatActivity implements View.OnClickListener { private EditText mMessage; private Button mOpen; private Button mSend; private Button mClose; private SerialPortUtils serialPortUtils; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); init; //串口数据监听事件 serialPortUtils.setOnDataReceiveListener(new SerialPortUtils.OnDataReceiveListener { @Override public void onDataReceive(byte[] buffer%2c int size) { Log.d("TAG"%2c "进入数据监听事件中。。。" + new String(buffer)); } }); } private void init { initView; serialPortUtils = new SerialPortUtils; } private void initView { mMessage = (EditText) findViewById(R.id.message); mOpen = (Button) findViewById(R.id.open); mOpen.setOnClickListener(this); mSend = (Button) findViewById(R.id.send); mSend.setOnClickListener(this); mClose = (Button) findViewById(R.id.close); mClose.setOnClickListener(this); } @Override public void onClick(View v) { switch (v.getId) { case R.id.open: // TODO 20/12/28 serialPortUtils.openSerialPort("/dev/ttyS9"%2c9600); break; case R.id.send: // TODO 20/12/28 serialPortUtils.sendSerialPort(mSend.getText.toString); break; case R.id.close: serialPortUtils.closeSerialPort; // TODO 20/12/28 break; default: break; } } } 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
Demo——github地址
Facebook动态消息(News Feed)因为存在重大排序错误,过去6个月一直推送“糟糕”内容。由于排序算法存在漏洞,动态消息抬高了虚假、暴力信息的权重。去年10月,工程师发现推送有问题,当时动态消息中的虚假信息明显增多。 虚假信息本来是经过事实核查员审查过的,应该早早得到抑制,但这些信息却四处...
据知情人士透露,苹果和Meta在2021年年中回应了伪造的“紧急数据请求”,向黑客提供了用户的基本信息,如客户的地址、电话号码和IP地址。伪造的“紧急数据请求”是由多个国家/地区的执法人员的被黑电子邮件域发送的,并且经过精心设计,带有真实或虚构执法人员的伪造签名,看起来合法。 据彭博社报道,一个名...
在俄乌冲突于 2 月下旬爆发后,许多西方国家都颁布了针对俄罗斯的制裁令。然而漏洞赏金平台 HackerOne 的做法,却让不少乌克兰安全研究人员也感到寒心。多位乌克兰黑客与研究人员在 Twitter 上控诉,HackerOne 正在阻止他们提取漏洞赏金,甚至有人被截留了数千美元。 由 Hacker...
近日 Android 设备被爆存在安全漏洞,但根源来自于苹果的无损音频编解码器(ALAC)。目前,美国市场 95% 的 Android 设备来自于高通和联发科,安全公司 Check Point 指出尚未安装 2021 年 12 月 Android Security Patch 的设备都存在“Out-...
利用新冠疫情,网络犯罪分子发起各种攻击而尽可能地牟利。欧盟网络安全机构 Enisa 强调,这类活动导致雇佣黑客在过去 15 个月中成为网络安全的最大威胁。 2020 年 4 月至 2021 年 7 月进行的研究的年度报告中,Enisa 表示 COVID-19 疫情期间观察到网络犯罪分子加大了针对潜在...
美国联邦调查局(FBI)警告个人和公司当心商业电子邮件泄露(BEC)攻击。据估计,2016年6月至2021年12月期间,国内和国际因此的损失已达430亿美元,2019年7月至2021年12月期间此类攻击增加了65%。 BEC攻击通常针对执行合法资金转移请求的企业或个人。它们涉及通过社会工程、网络钓鱼...