Próbuję wysłać dane przez USOCKET. Gdy dane docierają do serwera, serwer powinien odpowiedzieć. Jednak stream-read
(zgodnie z definicją poniżej) zwraca dane tylko wtedy, gdy są one echo z powrotem z oryginalnymi danymi, które wysłał. Na przykład, jeśli wyślę hello
, a serwer odpowie tymi samymi danymi, hello
, wtedy stream-read
zwróci, ale jeśli serwer odpowie hi
, stream-read
nie powróci, dopóki serwer nie wyśle dokładnie tego bufora, który otrzymał.Odbieranie danych za pośrednictwem LISP USOCKET
Oto kod: (Znalazłem większość z nich w Internecie.)
;; Load USocket
(load #P"/usr/share/common-lisp/source/cl-asdf/asdf.lisp")
(asdf:operate 'asdf:load-op :usocket)
(defun stream-read (stream)
(socket-listen (usocket:socket-stream stream)))
(defun stream-print (string stream)
(write-line string (usocket:socket-stream stream))
(force-output (usocket:socket-stream stream)))
;; Define a stream
(defparameter my-stream
(usocket:socket-connect "127.0.0.1" 6003))
;; Use the stream
(stream-print "random" my-stream)
(print (stream-read my-stream))
chodzi o serwer, używam nieco zmodyfikowaną wersję impuls blokujący przykład serwera. (C++) pełny kod można znaleźć tutaj: http://www.boost.org/doc/libs/1_53_0/doc/html/boost_asio/example/echo/blocking_tcp_echo_server.cpp
...
void session(socket_ptr sock)
{
try
{
for (;;)
{
char data[max_length];
boost::system::error_code error;
size_t length = sock->read_some(boost::asio::buffer(data), error);
if (error == boost::asio::error::eof)
break; // Connection closed cleanly by peer.
else if (error)
throw boost::system::system_error(error); // Some other error.
std::vector<char> v(data,data+length);
std::string theStr;
for(unsigned int i=0;i<v.size();i++)
{
if(v[i]<32 || v[i]>=0x7f);//Remove non-ascii char
else theStr.insert(theStr.end(),v[i]);
}
std::cout<<"|"<<theStr<<"|"<<std::endl;
boost::asio::write(*sock, boost::asio::buffer(data, length)); //works
boost::asio::write(*sock, boost::asio::buffer("some", 4)); //doesn't work
}
}
catch (std::exception& e)
{
std::cerr << "Exception in thread: " << e.what() << "\n";
}
}
...
Dzięki, dodałem kod serwera do głównego postu. –
Wygląda na to, że serwer był problemem, zastąpił go praktycznym serwerem echo C++ i wszystko działa! http://cs.ecs.baylor.edu/~donahoo/practical/CSockets/practical/ Ponadto, dzięki za funkcję odczytu gniazda, teraz czyta się poprawnie. –