The OpenNET Project / Index page

[ новости /+++ | форум | теги | ]




Версия для распечатки Пред. тема | След. тема
Новые ответы [ Отслеживать ]
Странная ситуация - из за чего такое может быть?, !*! Towellie, 24-Янв-09, 11:00  [смотреть все]
Это по сути та же проблема - которую я описывал на этом форуме не так давно собственно большая ее часть была результатом моего невежества(Прошу меня простить) - и я решил создать новую тему, чтобы не пудрить людям мозги, которые читают темы с самого начала(Дай господь здоровья этим людям).
Краткая аннотация - создается BIO соединение с шифрованием. Если отослать привет с одной стороны то привет - поймается с другой, и наоборот.(То есть с только запись с одной стороны и только чтение с другой и соответственно наоборот) - это я к тому что в этот дескриптор можно писать, и с него читать - проверено.


//_________________________Server__________________________________________
strcpy(tmpbuf,"Hello client");
len=BIO_write(sbio,tmpbuf,sizeof(tmpbuf));
printf("[%d] bytes was writed\n", len); // Write прорабатывает
/*<----------Когда этот код не заремарен - на другом конце дело не доходит до printf
for(;;)
{
    len=BIO_read(sbio,tmpbuf,sizeof(tmpbuf));
    printf("Cycle is rock! --- [%d]", len);
    if(len > 0)break;
}
printf("[%s]----[%d]\n",tmpbuf,strlen(tmpbuf));

if(strcmp(tmpbuf,"Hello server")==0)
{
    printf("Hello server is recived - let's rock!!!!! \n");
}
*/ <----------Когда этот код не заремарен - на другом конце дело не доходит до printf


//___________________________________________________________________

//________________________Client___________________________________________

for(;;)
{
    len=BIO_read(sbio,tmpbuf,sizeof(tmpbuf));
    printf("Cycle is rock! --- [%d]", len);
    if(len > 0)break;
}
printf("[%s]----[%d]\n",tmpbuf,strlen(tmpbuf)); <---- Этот printf
fflush(stdout);
sleep(5); <-- Когда код заремарен строка появляется до sleep
if(strcmp(tmpbuf,"Hello client")==0)
{
    printf("Hello client is recived - sending hello server\n");
    strcpy(tmpbuf,"Hello server");
    len=BIO_write(sbio,tmpbuf,sizeof(tmpbuf));
    printf("[%d] bytes was writed\n", len);
}

//___________________________________________________________________
Подробно --- >
Если код чтения заремарен результат работы программ
$ ./recv
[1024] bytes was writed
$
$ ./send
Cycle is rock! --- [1024][Hello client]----[12]
Hello client is recived - sending hello server
// Прорабатывает sleep
[1024] bytes was writed
$
// - Если не заремарен
$ ./recv
[1024] bytes was writed
$
$ ./send
<--- Ждет BIO_read чего она ждет?  В дескриптор записывается уже к этому времени именно столько сколько она должна считать.

  • Странная ситуация - из за чего такое может быть?, !*! Michelnok, 13:33 , 24-Янв-09 (1)
    >и я решил создать новую тему, чтобы не пудрить людям мозги

    А не мог бы ты еще и упростить свой код, поубирав все ненужное, и разделив по вариантам? Очень трудно анализировать такое сумбурное изложение. То закомментировано, то нет, то один printf, то какой-то другой, и все это в одной куче.

    • Странная ситуация - из за чего такое может быть?, !*! Towellie, 14:14 , 24-Янв-09 (2)
      В общем если так
      //_________________________Server__________________________________________
      strcpy(tmpbuf,"Hello");
      len=BIO_write(sbio,tmpbuf,sizeof(tmpbuf));
      //_________________________Server__________________________________________
      А на клиенте
      //__________________________Client_________________________________________
      for(;;)
      {
          len=BIO_read(sbio,tmpbuf,sizeof(tmpbuf));
      }
      printf("[%s]----[%d]\n",tmpbuf,strlen(tmpbuf));
      fflush(stdout);
      sleep(5);
      len=BIO_write(sbio,tmpbuf,sizeof(tmpbuf));
      //___________________________________________________________________
      Слип для того, чтобы увидеть не затупляет ли read и не отсылает данные по окончанию соединения(Сразу все отправляется)
      а так
      //_________________________Server__________________________________________
      strcpy(tmpbuf,"Hello");
      len=BIO_write(sbio,tmpbuf,sizeof(tmpbuf));
      for(;;)
      {
          len=BIO_read(sbio,tmpbuf,sizeof(tmpbuf));
      }
      //_________________________Server__________________________________________
      А на клиенте
      //__________________________Client_________________________________________
      for(;;)
      {
          len=BIO_read(sbio,tmpbuf,sizeof(tmpbuf));
      }
      printf("[%s]----[%d]\n",tmpbuf,strlen(tmpbuf));
      fflush(stdout);
      sleep(5);
      len=BIO_write(sbio,tmpbuf,sizeof(tmpbuf));
      //___________________________________________________________________
      Затупляет read который в первом случае работал.
      fflush чтобы printf полюбому показался
  • Странная ситуация - из за чего такое может быть?, !*! Towellie, 16:22 , 24-Янв-09 (3)
    Все - оказалось на стороне сервера подрубался в цепочку sbio буферный bbio который там не нужен

    Все))) Делаю дальше - бодрячком пацанчики)))




Партнёры:
PostgresPro
Inferno Solutions
Hosting by Hoster.ru
Хостинг:

Закладки на сайте
Проследить за страницей
Created 1996-2025 by Maxim Chirkov
Добавить, Поддержать, Вебмастеру