С наступающим Новым годом! Форум программистов, компьютерный форум, киберфорум
Наши страницы
Visual Basic
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.61/23: Рейтинг темы: голосов - 23, средняя оценка - 4.61
Dragokas
Эксперт WindowsАвтор FAQ
17031 / 7089 / 857
Регистрация: 25.12.2011
Сообщений: 10,914
Записей в блоге: 16
1

Скрипт отправки на FTP и копирования ссылки в буфер обмена

10.10.2012, 22:20. Просмотров 4303. Ответов 4

Решил поделиться полезняшкой:

1) Внести в код имя своего FTP-сервера, имя пользователя и пароль, корневую директорию.
1) Сохранить код в файл "FTP and ClipBoard.VBS"
2) Перетащить на него любой файл.

Получаем отправку на FTP и в буфере обмена уже готовую ссылочку.
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
Rem Отправка на FTP и копирование ссылки в буфер (Visual Basic Script)
Dim objArgs, Server, DomainName, Port, User, Pass, Folder, rootFolder, CloseDOS, DosStr
 
'=== Данные учетной записи FTP ===
 
Server = "31.170.123.45"
DomainName = "http://NickName.16mb.com"
Port = "21"
User = "***"
Pass = "***"
 
'Папка на FTP, куда будут складываться файлы
rootFolder = "public_html" 'корневая
Folder = "Folder/SubFolder" 'подкаталог
 
'Флаг - закрывать консольное окно после передачи данных
CloseDOS = True
if not CloseDOS then DosStr = "&pause"
 
Set objArgs = wscript.Arguments
If objArgs.Count <> 0 Then 'Проверяем аргументы (Drag & Drop "путь к файлу")
    Dim FName, WSHShell, Link, FF, TmpFile, objFile
    
    'Получаем имя файла
    FName = Mid(objArgs(0), InStrRev(objArgs(0), "\") + 1)
    'Интернет-адрес
    Link = DomainName & "/" & Folder & "/" & FName
 
    Set WSHShell = CreateObject("WScript.Shell")
    Set objFSO = CreateObject("Scripting.FileSystemObject")
    
    'Копируем в буфер обмена Windows
    WSHShell.Run "cmd.exe /C <nul set /p ""=" & Link & """ | CLIP", 0, False
 
    'Формируем строку коннекта для утилиты FTP
    TmpFile = WSHShell.ExpandEnvironmentStrings("%temp%") & "\temp_" & CInt(Rnd() * 1000)   
    'ForAppending = 8, ForReading = 1, ForWriting = 2
    Set objFile = objFSO.OpenTextFile (TmpFile, 2, True, 0) 'True - создать файл
        objFile.WriteLine "open " & Server & " " & Port
        objFile.WriteLine User
        objFile.WriteLine Pass
        objFile.WriteLine "cd " & rootFolder & "/" & Folder
        objFile.WriteLine "binary"
        objFile.WriteLine "put """ & objArgs(0) & """"
        objFile.WriteLine "disconnect"
        objFile.WriteLine "bye"
    objFile.Close
    
    'Добавляем утилиту FTP в исключения файрвола и запускаем
    WSHShell.Run "cmd.exe /c ""(netsh firewall add allowedprogram """ & WSHShell.ExpandEnvironmentStrings("%windir%") & _
      "\system32\ftp.exe"" ENABLE& ftp -s:""" & TmpFile & """" & DosStr & ")""", 1, True
 
    objFSO.DeleteFile TmpFile, True
 
    Set WSHShell = Nothing: Set objFile = Nothing: Set objFSO = Nothing
    
    wscript.echo "Путь к файлу на FTP: " & vbLf & Link & String(2, vbLf) & _
    "Путь к файлу скопирован в буфер обмена Windows."
  Else
    wscript.echo "Перетащите файл на VBS-сценарий"
End If
Set objArgs = Nothing
Единственное, я не понял как получить ссылку на файл с русскими буквами.
Визуально ссылочка выглядит так: http://Dragokas.16mb.com/Forum/Dl/Тест.txt
(сейчас такой файл у меня реально существует в указанной папке).
P.S. Переадресация на ссылку не будет работать (баг форума).
Но скачать не получается. Помогите, плиз.
3
Вложения
Тип файла: zip FTP and ClipBoard.zip (1.3 Кб, 73 просмотров)
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
10.10.2012, 22:20
Ответы с готовыми решениями:

Буфер обмена Windows в VB
Здравствуйте уважаемые участники форума! Решил освоить работу с Буфером обмена...

Копирование из ListBox в буфер обмена
Доброго всем времени суток!Пожалуйста подскажите или ткните носом.Не могу...

Как скопировать текст в буфер обмена
Подскажите, пожалуйста, как решить проблему: если на Windows 7 из текстового...

Как скопировать в буфер обмена указанный файл из VBA?
Подскажите как скопировать в буфер обмена указанный файл (как в проводнике) из...

Как запретить копирование текста из RichtextBox в буфер обмена?
Задача такая: выводить текст на форму так, чтобы его можно было только читать....

4
Dragokas
Эксперт WindowsАвтор FAQ
17031 / 7089 / 857
Регистрация: 25.12.2011
Сообщений: 10,914
Записей в блоге: 16
21.01.2013, 23:05  [ТС] 2
Лучший ответ Сообщение было отмечено The trick как решение

Решение

Чуть изменил код.
Развернуть код...

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
Rem Отправка на FTP и копирование ссылки в буфер (Visual Basic Script)
Dim objArgs, Server, DomainName, Port, User, Pass, Folder, SystemFolder, CloseDOS, DosStr
 
'=== Данные учетной записи FTP ===
 
Server = "IP-адрес FTP"
DomainName = "http://Домен.16mb.com"
Port = "21"
User = ""
Pass = ""
 
'Папка на FTP, куда будут складываться файлы
SystemFolder = "public_html" 'Системная папка
Folder = "Forum/Dl" 'подкаталог
 
'Флаг - закрывать консольное окно после передачи данных
CloseDOS = True
if not CloseDOS then DosStr = "&pause"
 
Set objArgs = wscript.Arguments
If objArgs.Count <> 0 Then 'Проверяем аргументы (Drag & Drop "путь к файлу")
    Dim FName, WSHShell, Link, FF, TmpFile, objFile
    
    'Получаем имя файла
    FName = Mid(objArgs(0), InStrRev(objArgs(0), "\") + 1)
    'Интернет-адрес
    Link = DomainName & "/" & Folder & "/" & FName
 
    Set WSHShell = CreateObject("WScript.Shell")
    Set objFSO = CreateObject("Scripting.FileSystemObject")
    
    'Копируем в буфер обмена Windows
    WSHShell.Run "cmd.exe /C <nul set /p ""=" & Link & """ | CLIP", 0, False
 
    'Формируем строку коннекта для утилиты FTP
    TmpFile = WSHShell.ExpandEnvironmentStrings("%temp%") & "\temp_" & CInt(Rnd() * 1000)   
    'ForAppending = 8, ForReading = 1, ForWriting = 2
    Set objFile = objFSO.OpenTextFile (TmpFile, 2, True, 0) 'True - создать файл
        objFile.WriteLine "open " & Server & " " & Port
        objFile.WriteLine User
        objFile.WriteLine Pass
        objFile.WriteLine "cd " & SystemFolder & "/" & Folder
        objFile.WriteLine "binary"
        objFile.WriteLine "hash"
        objFile.WriteLine "put """ & objArgs(0) & """"
        objFile.WriteLine "disconnect"
        objFile.WriteLine "bye"
    objFile.Close
    
    'Добавляем утилиту FTP в исключения файрвола и запускаем
    WSHShell.Run "cmd.exe /c ""(netsh firewall add allowedprogram """ & WSHShell.ExpandEnvironmentStrings("%windir%") & _
      "\system32\ftp.exe"" ENABLE& ftp -s:""" & TmpFile & """" & DosStr & ")""", 1, True
 
    objFSO.DeleteFile TmpFile, True
 
    Set WSHShell = Nothing: Set objFile = Nothing: Set objFSO = Nothing
    
    n = inputbox("Путь к файлу на FTP",,Link)
    'wscript.echo "Путь к файлу на FTP: " & vbLf & Link & String(2, vbLf) & _
    '"Путь к файлу скопирован в буфер обмена Windows."
  Else
    wscript.echo "Перетащите файл на VBS-сценарий"
End If
Set objArgs = Nothing


Теперь ссылку на наш файл в буфере обмена мы получаем сразу.
Когда файл будет докачан на сервер - появляется текстовое окно, откуда легко скопировать ссылку
на случай, если Вы случайно очистили буфер обмена.
Файлы с русскими буквами действительно не открываются в браузере, но такую ссылку спокойно качает
спец. менеджер, например бесплатный Download Master.

В скрипте использована утилита Clip, которой нет в составе Windows XP.
Можете взять альтернативу у Carl Peterson ConClip

Как этим добром проще пользоваться:
1. Сохранить с расширением VBS.
2. Зарегистрировать любой*, можно бесплатный хостинг с FTP.
3. Внести учетные данные в скрипт:
Server = "31.170.164.47"
DomainName = "http://Dragokas.16mb.com"
Port = "21"
User = ""
Pass = ""
Задать корневую системную папку (если такая используется сервером - это папка,
которая видна в FTP-менеджере, но она не входит в состав ссылки при скачивании файла).
Задать папку, куда по-умолчанию отправлять файлы.
SystemFolder = "public_html" 'Системная папка
Folder = "Forum/Dl" 'подкаталог
2. Поместить скрипт в системную папку SendTo
Как найти SendTo:
XP: Пуск -> Выполнить Sendto
или читаем MSKB 310270
Vista, Win 7...: Пуск, пишем в строке поиска Shell:Sendto и нажимаем {ENTER}.

*Где взять сервер FTP?
Например, здесь, которым я пользуюсь;
или вот целая тема рекомендаций: Хостинг с MySQL и возможностью доступа к БД удалённо
3
Миниатюры
Скрипт отправки на FTP и копирования ссылки в буфер обмена  
Вложения
Тип файла: rar FTP_and_ClipBoard.rar (1.3 Кб, 55 просмотров)
sotik
1 / 1 / 0
Регистрация: 20.01.2014
Сообщений: 87
18.03.2014, 12:57 3
Скрипт работает не корректно.
Вобщем у меня окошко со ссылкой не появляется и висит консольное окно,а появляется только когда уберешь процесс ftp.
Все данные к ftp прописаны верно,файл закачивается,но пустой.
0
Dragokas
Эксперт WindowsАвтор FAQ
17031 / 7089 / 857
Регистрация: 25.12.2011
Сообщений: 10,914
Записей в блоге: 16
19.03.2014, 02:00  [ТС] 4
sotik, сделайте скриншот момента на котором останавливается консольное окно.
Какой сервер используете?
0
sotik
1 / 1 / 0
Регистрация: 20.01.2014
Сообщений: 87
19.03.2014, 03:07 5
он вас испугался.
Все заработало.
Наверно не хватало путей path к дополнительным утилитам,которые поместил в system32.
После перезагрузки компа все работает.
Спасибо.
0
19.03.2014, 03:07
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
19.03.2014, 03:07

Копирование русских букв в Буфер обмена из текстового поля
Clipboard.SetText Text1.Text Если в текстовом поле есть русские буквы, то они...

Как запихнуть смайлик в буфер обмена и загрузить его в RichTextBox
Подскажите как запихнуть смайлик в буфер обмена и загрузить его в RichTextBox

Можно ли в Turbo Basic скопировать текст программы в буфер обмена?
Можно ли в Turbo Basic скопировать текст программы в буфер обмена? А потом уже...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru