博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
google似乎把ADB输出的回车换行问题改掉了
阅读量:6937 次
发布时间:2019-06-27

本文共 1458 字,大约阅读时间需要 4 分钟。

hot3.png

改动内容在这儿,没有测试过,看起来没问题。

到目前位置,市面上所有的Android设备,都存在这个这个小问题:

在Linux/Mac上执行adb命令输出什么东西时,就算是二进制输出,那么LF(0x0a)字符会被转换成CR(0x0d) + LF。Windows上更可笑,会变成CR+CR+LF。

这个很好验证:

从Android上抓一个文件下来,例如/default.prop, 看看里面应该只有LF(0x0a),而没有CR(0x0d)的。

adb pull /default.prop     local_output_file1

然后在通过adb shell cat命令输出到本地,看看文件里是不是多了好多CR(0x0d)了。

adb shell cat /default.prop > local_output_file2

这个不是简单的因为Windows OS的缘故,Linux也出毛病。

解决方法一大堆,例如上述的pull,或者通过socket输出到PC。

其实还有方法可以完全不需要转换,也不需要pull,socket什么的。首先总结原因是两个:

  1. Android那边首先做了LF->CR+LF的转换。具体的在代码里有,adbd用了pty这东西来做输入输出。很古老的东西,没什么兴趣说,。

  2. Windows OS这边的adb工具更额外做了一层LF->CR+LF的转换。这个到是Windows的默认风格。

解决方法有两个步骤(Linux/Mac只要第一个步骤就行了)

1. 在android那边设定stty -onlcr来禁止发自android那边的转换。

这个也有两个方法,一个是借助于外部工具stty(从busybox里来的),那么

预先把工具放到android里:

adb push busybox /data/local/tmp/adb shell chmod 755 /data/local/tmp/busybox

然后,那就是在执行自己的命令之前执行busybox stt -onlcr。例如

adb shell '/data/local/tmp/busybox stty -onlcr; cat /default.prop' > local_output_file2

还有一种方法就是自己的C代码里,执行这一段:

#include 
if (isatty(STDOUT_FILENO)) {    struct termios term;    tcgetattr(STDOUT_FILENO, &term);    cfmakeraw(&term);    tcsetattr(STDOUT_FILENO, TCSANOW, &term);}

2. Windows这边才需要这个步骤。那就是不直接使用adb工具了,而是直接和adb工具所服务的5037端口打交道,发送命令,取得结果,这个具体的说起来有点啰嗦,如果是nodejs,那么用好了,其他的我没多看,大致就是

1. 向localhost:5037 发送host:transport:设备序列号    得到回答,如果是OKAY四个字那就到step2,否则就错误。 2. 继续向上述port发送shell:命令内容    得到回答,如果是OKAY四个字那就到step2,否则就错误。 然后从这个连接里能够读到原始的输出。

 

转载于:https://my.oschina.net/osexp2003/blog/464971

你可能感兴趣的文章
【翻译】CodeMix使用的语言和框架(二):PHP
查看>>
Java 内部类
查看>>
python项目实战:20行代码画一朵好看又有趣的小花花
查看>>
jsp 页面中El表达式失效处理
查看>>
在django中按照时间范围查询数据库
查看>>
jQuery在绑定事件时如何传入参数
查看>>
struts.xml配置详解
查看>>
OSChina 周一乱弹 —— 还一星期就要和女神约会了
查看>>
srs-2-CentOS6 创建 Simple-Rtmp-Server
查看>>
红芯浏览器下载
查看>>
Ora_Excel 碉堡了
查看>>
MySQL中REGEXP正则查询同一个字段模糊搜索
查看>>
记录日志方法
查看>>
日常接口请求
查看>>
okhttp通过post发送Json数据到php 更新数据库
查看>>
hadoop集群时间同步
查看>>
win7 修改hosts 不起作用
查看>>
Solr debugQuery使用体会
查看>>
100-95
查看>>
“中序表达式”转“后续表达式”
查看>>