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

Узнай цену своей работы

Формулировка задачи:

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

Но скачать не получается. Помогите, плиз.

Решение задачи: «Скрипт отправки на FTP и копирования ссылки в буфер обмена»

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

ИИ поможет Вам:


  • решить любую задачу по программированию
  • объяснить код
  • расставить комментарии в коде
  • и т.д
Попробуйте бесплатно

Оцени полезность:

5   голосов , оценка 3.4 из 5

Нужна аналогичная работа?

Оформи быстрый заказ и узнай стоимость

Бесплатно
Оформите заказ и авторы начнут откликаться уже через 10 минут
Похожие ответы