RFCOMM bez parowania za pomocą PyBluez na Debianie?
Próbuję utworzyć proces serwera RFCOMM za pomocą Pythona, którego można używać bez konieczności parowania. Początkowo pobrałem dwa przykładowe skrypty z dokumentacji PyBluez:
Serwer:
# file: rfcomm-server.py
# auth: Albert Huang <[email protected]>
# desc: simple demonstration of a server application that uses RFCOMM sockets
#
# $Id: rfcomm-server.py 518 2007-08-10 07:20:07Z albert $
from bluetooth import *
server_sock=BluetoothSocket( RFCOMM )
server_sock.bind(("",PORT_ANY))
server_sock.listen(1)
port = server_sock.getsockname()[1]
uuid = "94f39d29-7d6d-437d-973b-fba39e49d4ee"
advertise_service( server_sock, "SampleServer",
service_id = uuid,
service_classes = [ uuid, SERIAL_PORT_CLASS ],
profiles = [ SERIAL_PORT_PROFILE ],
# protocols = [ OBEX_UUID ]
)
print "Waiting for connection on RFCOMM channel %d" % port
client_sock, client_info = server_sock.accept()
print "Accepted connection from ", client_info
try:
while True:
data = client_sock.recv(1024)
if len(data) == 0: break
print "received [%s]" % data
except IOError:
pass
print "disconnected"
client_sock.close()
server_sock.close()
print "all done"
Klient:
# file: rfcomm-client.py
# auth: Albert Huang <[email protected]>
# desc: simple demonstration of a client application that uses RFCOMM sockets
# intended for use with rfcomm-server
#
# $Id: rfcomm-client.py 424 2006-08-24 03:35:54Z albert $
from bluetooth import *
import sys
addr = None
if len(sys.argv) < 2:
print "no device specified. Searching all nearby bluetooth devices for"
print "the SampleServer service"
else:
addr = sys.argv[1]
print "Searching for SampleServer on %s" % addr
# search for the SampleServer service
uuid = "94f39d29-7d6d-437d-973b-fba39e49d4ee"
service_matches = find_service( uuid = uuid, address = addr )
if len(service_matches) == 0:
print "couldn't find the SampleServer service =("
sys.exit(0)
first_match = service_matches[0]
port = first_match["port"]
name = first_match["name"]
host = first_match["host"]
print "connecting to \"%s\" on %s" % (name, host)
# Create the client socket
sock=BluetoothSocket( RFCOMM )
sock.connect((host, port))
print "connected. type stuff"
while True:
data = raw_input()
if len(data) == 0: break
sock.send(data)
sock.close()
Kiedy uruchomiłem skrypt serwera w systemie Windows, wszystko działało tak, jak się spodziewałem - nie było potrzeby parowania. Na tym etapie wszystko wyglądało bardzo obiecująco.
Potrzebuję jednak procesu serwera do uruchomienia w Debian Squeeze. Kiedy testuję na Debianie, połączenie klienta zostaje odrzucone. W dzienniku syslog znajdują się wiadomości z bluetoothd o nieudanym żądaniu klucza łącza i żądaniu PIN.
Informacje o wersji:
PyBluez 0.18Python 2.6Bluez 4.66Sprzęt Bluetooth v2.0 na obu końcach połączeniaTa dyskusja wydaje się sugerować, że jeśli mogę dostosować poziom zabezpieczeń w gnieździe serwera, parowanie zostanie wyłączone i wszystko będzie działać zgodnie z oczekiwaniami. Nie jest jednak dla mnie oczywiste, jak to zrobić z PyBluezem, a nawet jeśli jest to możliwe.
Eksperymentowałem z wywołaniami setsockopt () przy użyciu różnych stałych BT_SECURITY *, jak również chwytałem ostatni PyBluez i wywoływałem setl2capsecurity (), ale nie byłem w stanie zrobić żadnego postępu.
Czy to będzie możliwe dzięki PyBluez?