我正在尝试通过boost的Unix Domain sockets包装器在Android上打开一个本地套接字。
我似乎找不到接受者工作的路径。
using boost::asio::local::stream_protocol;
void test()
{
boost::asio::io_service io;
stream_protocol::endpoint ep("/dev/shm/BlahBLah");
stream_protocol::acceptor(io, ep);
}我从sock bind()得到一个异常,错误代码为:2 (ENOENT)
那么,为什么boost stream_protocol无法通过该目录进行连接呢?(我可以手动打开并将套接字绑定到该路径)
我需要以某种方式设置权限吗?或者是否有不同的路径可以工作(不是通过SD卡,我需要一个虚拟路径)
发布于 2015-12-11 21:24:05
首先,使用共享内存设备似乎很有趣。
UNIX域套接字与其无关。我相信Android内核不支持共享内存。
我认为你应该能够使用程序可访问和可写的任何目录。
“我需要一条虚拟路径”是什么意思?我想你的意思是你希望插座是隐形的?为此,应使用Posix权限或acls。
最后,看看socketpair,它为进程间通信创建了未命名的套接字
²/proc、lsof和类似的应用程序仍然可以看到它。不要暴露套接字名称中的秘密,并使用权限保护它。
https://stackoverflow.com/questions/34181562
复制相似问题