Класс WinSock

Программирование на Visual Basic, главный форум. Обсуждение тем программирования на VB 1—6.
Даже если вы плохо разбираетесь в VB и программировании вообще — тут вам помогут. В разумных пределах, конечно.
Правила форума
Темы, в которых будет сначала написано «что нужно сделать», а затем просьба «помогите», будут закрыты.
Читайте требования к создаваемым темам.
Mleha
Продвинутый пользователь
Продвинутый пользователь
Аватара пользователя
 
Сообщения: 146
Зарегистрирован: 06.10.2004 (Ср) 7:49
Откуда: Ангарск

Класс WinSock

Сообщение Mleha » 11.01.2005 (Вт) 11:09

Пишу сетевую прогу для пересылки файлов...и хочу использовать класс WinSock'а так как в технаре доступ обрублен ко всем компонентам!

с этим классом есть Event'ы но немогу использовать функции WinSock'а
(senddata;close...)
Вложения
CSocket-1.0.12.rar
(20.02 Кб) Скачиваний: 77

alibek
Большой Человек
Большой Человек
 
Сообщения: 14205
Зарегистрирован: 19.04.2002 (Пт) 11:40
Откуда: Russia

Сообщение alibek » 11.01.2005 (Вт) 12:13

А как объявляешь инстанс сокета?
Lasciate ogni speranza, voi ch'entrate.

Mleha
Продвинутый пользователь
Продвинутый пользователь
Аватара пользователя
 
Сообщения: 146
Зарегистрирован: 06.10.2004 (Ср) 7:49
Откуда: Ангарск

Сообщение Mleha » 11.01.2005 (Вт) 12:21

1) Dim WithEvents w As CSocket
2) Set W = New CSocket

Первое с евентами, но без функций
Второе - наоборот

Надо бы все сразу с одной переменной
Может Получится у кого это в ActiveX переработать?

tyomitch
Пользователь #1352
Пользователь #1352
Аватара пользователя
 
Сообщения: 12822
Зарегистрирован: 20.10.2002 (Вс) 17:02
Откуда: חיפה

Сообщение tyomitch » 11.01.2005 (Вт) 17:10

Mleha, а оба сразу не пробовал?
Код: Выделить всё
Dim WithEvents W As CSocket

Private Sub Form_Load
   Set W = New CSocket

End Sub
Изображение

Mleha
Продвинутый пользователь
Продвинутый пользователь
Аватара пользователя
 
Сообщения: 146
Зарегистрирован: 06.10.2004 (Ср) 7:49
Откуда: Ангарск

Сообщение Mleha » 12.01.2005 (Ср) 8:00

Уже пробовал и вот что получилось:
Вложения
Sender.rar
(54.51 Кб) Скачиваний: 64

Mleha
Продвинутый пользователь
Продвинутый пользователь
Аватара пользователя
 
Сообщения: 146
Зарегистрирован: 06.10.2004 (Ср) 7:49
Откуда: Ангарск

Сообщение Mleha » 17.01.2005 (Пн) 6:53

Признаю первая версия жутко глючная и очень криво работает :) .
Но вот новая и снова проблема:
Если запустить сервера и клиента на одном компе и подключиться через 127.0.0.1 то все работает безотказно, а если через модемное соединение 33.6 Kb/sec то файлы доходят "жеваные".
Может проблема в том что передаются блоки по 4096 байт, а не 255?
Вложения
Sender2.rar
Проект прилагается
(121.86 Кб) Скачиваний: 98

Mleha
Продвинутый пользователь
Продвинутый пользователь
Аватара пользователя
 
Сообщения: 146
Зарегистрирован: 06.10.2004 (Ср) 7:49
Откуда: Ангарск

Сообщение Mleha » 18.01.2005 (Вт) 14:14

Да надо было посылать блоки по 255 байт! :D
но снова проблема: допустим дана папка, надо узнать адреса всех вложенных файлов и папок в отдельности. как это реализовать? помогите :oops:

tyomitch
Пользователь #1352
Пользователь #1352
Аватара пользователя
 
Сообщения: 12822
Зарегистрирован: 20.10.2002 (Вс) 17:02
Откуда: חיפה

Сообщение tyomitch » 18.01.2005 (Вт) 17:38

Где? на локальной машине? или может, на FTP-сервере, раз в теме про сокеты? :-)
Изображение

Mleha
Продвинутый пользователь
Продвинутый пользователь
Аватара пользователя
 
Сообщения: 146
Зарегистрирован: 06.10.2004 (Ср) 7:49
Откуда: Ангарск

Сообщение Mleha » 19.01.2005 (Ср) 6:19

Искать нужно отправителю у себя на компе! :cry:

Mleha
Продвинутый пользователь
Продвинутый пользователь
Аватара пользователя
 
Сообщения: 146
Зарегистрирован: 06.10.2004 (Ср) 7:49
Откуда: Ангарск

Сообщение Mleha » 19.01.2005 (Ср) 7:50

Помогите доработать или переработоать этот код:

Код: Выделить всё
Dim count As Integer, cnt As Integer, Olditem As Integer, k As Integer, lcl As Integer
Dim Path as String
d.Path = Path
d.Refresh
count = d.ListCount
Caption = count
Olditem = 0

For i = 0 To count - 1
lf.AddItem d.List(i)
k = d.ListCount
Next i

Caption = lf.ListCount
SS:

Olditem = lf.ListCount

If k = 0 Or aa = True Then Exit Function

For i = lcl To lf.ListCount
d.Path = lf.List(i - 1)
d.Refresh

cnt = d.ListCount

For j = 1 To cnt
DoEvents
lf.AddItem d.List(j - 1)
lNext j
Next i


k = lf.ListCount - k
lcl = k + 1

GoTo SS


, где
Код: Выделить всё
d - DriveListBox
lf - ListBox

Решение чуствую где то близко :D[/code]

Mleha
Продвинутый пользователь
Продвинутый пользователь
Аватара пользователя
 
Сообщения: 146
Зарегистрирован: 06.10.2004 (Ср) 7:49
Откуда: Ангарск

Сообщение Mleha » 20.01.2005 (Чт) 7:24

Сам тему затеял - самому пришлоь думать :wink:

Еще как искать скрытые/системные ПАПКИ :?:
Вложения
Find.rar
(1.6 Кб) Скачиваний: 65


Вернуться в Visual Basic 1–6

Кто сейчас на конференции

Сейчас этот форум просматривают: Yandex-бот и гости: 174

    TopList