- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我尝试使用从 NDEF 格式的 MIFARE NFC 标签读取的数据发出 HTTP GET 请求。我无法将标签中的字节数组数据转换为适用于以太网客户端 print()
函数的格式。
硬件设置是带有 seeedstudio NFC Shield 和 Arduino 以太网扩展板的 Arduino Uno。我使用以太网、PN532 和 NfcAdapter 库。
我尝试了几种类型的转换,使用 char *
和 char[]
而不是 String 对象,但没有成功。
为了查明问题,我选择了一个案例,其中 Serial.print()
给出了预期的结果,但 client.print()
没有。
代码基于PN532 NDEF library example 'ReadTagExtended' .
void loop(void)
{
if (nfc.tagPresent()) // Do an NFC scan to see if an NFC tag is present
{
NfcTag tag = nfc.read(); // read the NFC tag
if (tag.hasNdefMessage())
{
NdefMessage message = tag.getNdefMessage();
for (int i = 0; i < message.getRecordCount(); i++)
{
NdefRecord record = message.getRecord(i);
int payloadLength = record.getPayloadLength();
byte payload[payloadLength];
record.getPayload(payload);
String tag_content = "";
for(int i = 0; i<payloadLength; i++) {
tag_content += (char)payload[i];
}
Serial.println(tag_content); // prints the correct string
request(tag_content);
}
}
}
}
void request(String data) {
EthernetClient client;
// if you get a connection, report back via serial:
if (client.connect(remote, 8080)) {
client.print("GET /subaddress");
client.print("?data=");
client.print(data); // unfortunately empty
client.println();
client.println();
while (client.connected()) {
if (client.available()) {
char c = client.read();
Serial.print(c);
}
}
client.stop();
Serial.println(" OK");
delay(100);
} else {
Serial.println("ERR");
delay(100);
}
}
通过上述设置,我使用 Serial.println()
获得了预期的输出。然而,在(成功)请求中,data
是空的。
来自评论(总结):
打印记录类型 (record.getType()
) 给出字母“U”。对于包含字符串“def”的标记,payloadLength
为 4。
最佳答案
根据您在评论中提供的信息,该标签包含一个 URI 记录(该记录又包含您的数据)。您的代码中的问题是您直接将 URI 记录的完整有效负载用作字符串。但是,URI 记录包含的不仅仅是一个字符串。特别是,有效载荷的第一个字节是前缀字节(通常是不可打印的字符)。所以看起来 Serial.println()
(或者更确切地说是你的串行接收器)只是跳过了那个字符。 client.print()
会将那个字符包含到 HTTP 请求中,并因此创建一个无效的 HTTP 请求(看起来好像剩余的字节被省略了)。
因此,在使用它之前,您必须遵循 URI 记录类型定义将有效负载解码为正确的 URI:
NdefMessage message = tag.getNdefMessage();
for (int i = 0; i < message.getRecordCount(); ++i) {
NdefRecord record = message.getRecord(i);
if (record.getType() == "U") {
String uri = "";
int payloadLength = record.getPayloadLength();
if (payloadLength > 0) {
byte payload[payloadLength];
record.getPayload(payload);
switch (payload[0]) {
case 0x000: break;
case 0x001: uri += "http://www."; break;
case 0x002: uri += "https://www."; break;
case 0x003: uri += "http://"; break;
case 0x004: uri += "https://"; break;
case 0x005: uri += "tel:"; break;
case 0x006: uri += "mailto:"; break;
case 0x007: uri += "ftp://anonymous:anonymous@"; break;
case 0x008: uri += "ftp://ftp."; break;
case 0x009: uri += "ftps://"; break;
case 0x00A: uri += "sftp://"; break;
case 0x00B: uri += "smb://"; break;
case 0x00C: uri += "nfs://"; break;
case 0x00D: uri += "ftp://"; break;
case 0x00E: uri += "dav://"; break;
case 0x00F: uri += "news:"; break;
case 0x010: uri += "telnet://"; break;
case 0x011: uri += "imap:"; break;
case 0x012: uri += "rtsp://"; break;
case 0x013: uri += "urn:"; break;
case 0x014: uri += "pop:"; break;
case 0x015: uri += "sip:"; break;
case 0x016: uri += "sips:"; break;
case 0x017: uri += "tftp:"; break;
case 0x018: uri += "btspp://"; break;
case 0x019: uri += "btl2cap://"; break;
case 0x01A: uri += "btgoep://"; break;
case 0x01B: uri += "tcpobex://"; break;
case 0x01C: uri += "irdaobex://"; break;
case 0x01D: uri += "file://"; break;
case 0x01E: uri += "urn:epc:id:"; break;
case 0x01F: uri += "urn:epc:tag:"; break;
case 0x020: uri += "urn:epc:pat:"; break;
case 0x021: uri += "urn:epc:raw:"; break;
case 0x022: uri += "urn:epc:"; break;
case 0x023: uri += "urn:nfc:"; break;
default: break;
}
for (int j = 1; j < payloadLength; ++j) {
uri += (char)payload[j]; // NOTE: this is wrong since the string is UTF-8 encoded (but we translate it byte-by-byte)
}
}
Serial.println(uri);
request(uri);
}
}
请注意,上述解决方案仍然存在一些问题:
String
在内存效率方面当然不是最佳选择。关于c++ - 将 NDEF 记录有效负载转换为 EthernetClient print() 的字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54446038/
我已经和 Lua 搞了几天,我想出了一些让我三思而后行的事情。 Lua 5.3 的引用手册我还没有看,因为它似乎很复杂,我会尽快查看。 好的,在 lua 5.3 中,我们知道 print() 返回 n
计算时IO (IO ()) , 两个 (IO ())和 ()是计算出来的,所以为什么 main :: IO (IO ()) main = print (print "Hello, World!")
我不太理解从以下位置收到的输出: print(print(print('aaa'))) aaa None None 先aaa清楚了。但我认为第二个 print(aaa) 会抛出一个错误,因为变量 aa
当我运行下面的 Perl one-liner 时,它会打印 1在每一行的前面,我不想要它。它应该做的只是注释匹配 root 的行. $ cat /etc/passwd | perl -ne 'prin
我发现由于 Xcode 将不再消化 println() 我是 留下 Swift.print() 或 print() 。我的问题是, 两者有什么区别?我没能 在网上或在 swift 前卫郎。 (Swif
我正在开发一个内部 Google Chrome 扩展,它需要一种方法来启动将当前页面打印到打印机。我不希望出现默认的打印对话框(因此,javascript:window.print() 是不可能的)。
我正在将 Perl6 Terminal::Print 模块用于基于控制台的应用程序。 它运行良好 - 但是,现在我需要提示用户输入一串文本。 有什么好的方法可以做到这一点? 最佳答案 这是使用 Ter
在学习第三方的Lua代码时,我发现在主脚本文件的顶部 local insert = table.insert local match = string.match local gsub = strin
在学习第三方的Lua代码时,我发现在主脚本文件的顶部 local insert = table.insert local match = string.match local gsub = strin
我目前正在学习 Python,并开始了一个项目,为 2000-2005 年 MLB 摊牌纸牌游戏创建棒球模拟游戏。这些程序包含棒球比赛的事件,作为单独代码段中间的打印语句(“Jeff 击中单打”,“B
我的问题:在没有多余括号的情况下漂亮地打印表达式的最干净的方法是什么? 我有以下 lambda 表达式的表示: Term ::= Fun(String x, Term t) | App(
为了在 Julia 中创建可打印的新类型,应该定义哪些方法?我认为应该只定义 show,然后它将引发其他函数的行为,例如: 打印 字符串 repl_show 显示紧凑 展示 需要为新类型定义以下哪些方
我有一个页面,用户可以在其中打印一些带有图像和数据的 pdf。我希望他们能够打印他们想要的文件数量,并且能够暂停它们——这意味着他们可以停止打印并防止打印尚未发送到打印机的文件;当然,已经发送到打印机
CLHS 说 An attempt to print a circular structure with *print-circle* set to nil may lead to looping
正如标题所示,在 Pycharm 中使用自动完成功能时,显示的唯一自动完成选项是:print(args,kwargs) 内置 我希望自动完成功能以“print”完成,因为这是我通常使用的。我正在使用
是否有可能使用 fmt.Println("...") 打印一个 shell 居中对齐的字符串? 最佳答案 作为对这个长期回答问题的更新,可以通过使用 fmt 包中的 * 符号来改进@miltonb 发
我想在控制台屏幕上显示使用 DO 循环完成的计算进度。我可以像这样将进度变量打印到终端: PROGRAM TextOverWrite_WithLoop IMPLICIT NONE INTEGER ::
我正在尝试为我的新对象定义打印方法,并使用传递给 print 的对象名称。使用 deparse(substitute(y)) .这可以完美地使用 print功能明确: obj function (x
我需要安装 dompdf 方面的帮助。我应该将解压的 zip 文件放在目录中的哪个位置?我按照 INSTALL.txt 进行操作,它显示“将下载的包的内容提取到支持的路径之一”。这是否意味着放入“Mo
我的应用程序中有一个 webkit 小部件,您可以打印它。打印效果很好,除了打印时没有图像,即使屏幕上有图像。 打印代码如下: void MainWindow::printPage() { Q
我是一名优秀的程序员,十分优秀!