Не удается подключиться к абстрактному сокету Unix в Python

У меня есть сервер, написанный на C ++, который создает и привязывает к абстрактному сокету Unix с адресом пространства имен "\0hidden", У меня также есть клиент, который написан на C ++ также, и этот клиент может успешно подключиться к моему серверу Кстати, у меня нет исходного кода этого клиента. Сейчас я пытаюсь подключиться к своему серверу с помощью клиента, написанного на python, но безуспешно. Я не понимаю, почему мой клиент Python не работает. Я публикую соответствующие части моего сервера и клиентские коды.

сервер

#define UD_SOCKET_PATH          "\0hidden"struct sockaddr_un addr;
int fd,cl;

if ( (fd = socket(AF_UNIX, SOCK_STREAM, 0)) == -1)
{
syslog(LOG_CRIT, "Error creating socket!");
exit(1);
}

memset(&addr, 0, sizeof(addr));
addr.sun_family = AF_UNIX;
strncpy(addr.sun_path, UD_SOCKET_PATH, sizeof(addr.sun_path)-1);
unlink(UD_SOCKET_PATH);if (::bind(fd, (struct sockaddr*)&addr, sizeof(addr)) == -1)
{
syslog(LOG_CRIT, "Bind error");
exit(1);
}

if (listen(fd, MAX_CONN_PENDING) == -1)
{
syslog(LOG_CRIT, "Listen error");
exit(1);
}

syslog(LOG_INFO, "Start listening.");

И мой код клиента

#! /opt/python/bin/python
import os
import socket
import sys
# Create a UDS socket
sock = socket.socket(socket.AF_UNIX, socket.SOCK_STREAM)

server_address = "\0hidden"print >>sys.stderr, 'connecting to %s' % server_address.decode("utf-8")
try:
sock.connect(server_address)
except socket.error, msg:
print >>sys.stderr, msg
sys.exit(1)

После запуска клиента я получаю следующую ошибку:

connecting to hidden
[Errno 111] Connection refused

А для дополнительной информации я публикую соответствующие части результатов работы моего рабочего клиента c ++ и неработающего клиента python:

Рабочий клиент C ++:

socket(PF_FILE, SOCK_STREAM, 0)         = 3
connect(3, {sa_family=AF_FILE, path=@""}, 110) = 0
fstat64(1, {st_mode=S_IFCHR|0620, st_rdev=makedev(136, 0), ...}) = 0
mmap2(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0xb77d7000
write(1, "Sent message is: 00014 www.googl"..., 38) = 38
write(3, "00014 www.google.com", 20)    = 20
recv(3, "014 Search Engines", 99, 0)    = 18
write(1, "014 Search Engines\n", 19)    = 19
close(3)                                = 0
exit_group(0)                           = ?

Ни один рабочий клиент Python:

socket(PF_FILE, SOCK_STREAM, 0)         = 3
connect(3, {sa_family=AF_FILE, path=@"hidden"...}, 9) = -1 ECONNREFUSED (Connection refused)
write(2, "Traceback (most recent call last"..., 35) = 35
write(2, "  File \"./uds.py\", line 13, in <"..., 40) = 40
open("./uds.py", O_RDONLY|O_LARGEFILE)  = 4
fstat64(4, {st_mode=S_IFREG|0755, st_size=839, ...}) = 0
mmap2(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0xb7792000
read(4, "#! /opt/python/bin/python\nimport"..., 4096) = 839
write(2, "    ", 4)                     = 4
write(2, "sock.connect('\\0hidden')\n", 25) = 25
close(4)                                = 0
munmap(0xb7792000, 4096)                = 0
write(2, "  File \"/opt/python/lib/python2."..., 64) = 64
open("/opt/python/lib/python2.7/socket.py", O_RDONLY|O_LARGEFILE) = 4
fstat64(4, {st_mode=S_IFREG|0755, st_size=20234, ...}) = 0
mmap2(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0xb7792000
read(4, "# Wrapper module for _socket, pr"..., 4096) = 4096
read(4, "oo long.\"\n    errorTab[10064] = "..., 4096) = 4096
write(2, "    ", 4)                     = 4
write(2, "return getattr(self._sock,name)("..., 39) = 39
close(4)                                = 0
munmap(0xb7792000, 4096)                = 0
write(2, "socket", 6)                   = 6
write(2, ".", 1)                        = 1
write(2, "error", 5)                    = 5
write(2, ": ", 2)                       = 2
write(2, "[Errno 111] Connection refused", 30) = 30
write(2, "\n", 1)                       = 1
rt_sigaction(SIGINT, {SIG_DFL, [], 0}, {0x810fbe0, [], 0}, 8) = 0
close(3)                                = 0
exit_group(1)                           = ?

А также, когда я запускаю свой клиент на c ++, я получаю следующий вывод с моего сервера:

0, NULL)                      = 12
futex(0x80646a4, FUTEX_CMP_REQUEUE_PRIVATE, 1, 2147483647, 0x8064688, 360) = 10
futex(0x8064688, FUTEX_WAKE_PRIVATE, 1) = 1
accept(5,

Но когда я запускаю свой python-клиент, на strace ничего не отображается. Похоже, я пытаюсь подключиться не к тому адресу, но мой адрес определяется как "\0hidden" и в моем сервере, и в моем клиенте.

5

Решение

Ваш C ++ делает не совсем то, что вы думаете. Эта строка:

strncpy(addr.sun_path, UD_SOCKET_PATH, sizeof(addr.sun_path)-1);

Копирует один нулевой символ '\0' в addr.sun_path, Обратите внимание на эту строку на странице руководства для strncpy():

Если длина src меньше n, strncpy () записывает дополнительный ноль
байтов в dest, чтобы гарантировать, что всего будет записано n байтов.

В результате ваш C ++ фактически подключается к абстрактному доменному сокету в "\0", Python делает все правильно и подключается к абстрактному доменному сокету по адресу "\0hidden",

3

Другие решения


По вопросам рекламы [email protected]