Форум программистов, компьютерный форум, киберфорум
VBScript/JScript/WSH/WMI
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.77/13: Рейтинг темы: голосов - 13, средняя оценка - 4.77
0 / 0 / 0
Регистрация: 29.03.2013
Сообщений: 8
VBS

Получение внешнего IP

13.08.2013, 23:55. Показов 2470. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Необходимо получить внениий IP - с этом собственно проблем нет, а вот отправить коректный https запроос не получается.
собственно как пытаюсь:
Visual Basic
1
2
3
4
5
Dim objHTTP 
Set objHTTP = CreateObject("Microsoft.XMLHTTP")
Call objHTTP.Open("GET", "https://xxxx.ru/api/user/getAccountInfo?login=dxxxxx&passwd=xxxxxx", False)
Call objHTTP.Send
MsgBox(objHTTP.ResponseText)
все ок....
собственно вопрос - как в запрос вставить IP и закодировать его в urlencode
Помогите чайнику)
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
13.08.2013, 23:55
Ответы с готовыми решениями:

Получение внешнего IP в переменную
Добрый день, есть этот код: Option Explicit 'On Error Resume Next Dim sIP Sub XMLRequest(sQuery, objRemXML) Set...

Получение внешнего IP-адреса
zyxel keentric giga 2 ТП Zyxel говрит что можно общаться с роутером только или чрез web-интерфейс или по telnet как то вот так: ...

Получение внешнего IP
Добрый вечер! Необходимо получить внешний IP адрес и записать в *.txt. Нарыл код, ну та как в C# только первые дни... Прошу помощи...

4
Эксперт WindowsАвтор FAQ
 Аватар для Dragokas
18031 / 7734 / 892
Регистрация: 25.12.2011
Сообщений: 11,502
Записей в блоге: 16
14.08.2013, 01:30
В смысле getAccountInfo - здесь хранится информация об IP ?

Вот функция:

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
function RusToURL(txt)
  For i = 1 To Len(txt)
    l = Mid(txt, i, 1)
    a = AscW(l)
    Select Case True
        Case a > 256: t = "%" & Hex(AscW(l) \ 64 + 192) & "%" & Hex(8 * 16 + AscW(l) Mod 64)
        Case a = 32: t = "+"
        Case Else: t = l
    End Select
  RusToURL = RusToURL & t
  Next
end function
Использование:

Visual Basic
1
encoded_account = RusToURL("Алекс")
А Вы пытались вручную ввести этот запрос в адресную строку браузера, чтобы добиться адекватного ответа от xxxx.ru?
1
Модератор
Эксперт JS
 Аватар для Eva Rosalene
5241 / 2115 / 416
Регистрация: 06.01.2013
Сообщений: 4,846
14.08.2013, 16:50
Чтобы не засорять форум новыми темами спрошу здесь.
Visual Basic
1
2
3
4
5
6
7
8
9
10
set objHttp = CreateObject("Microsoft.XMLHTTP")
call objHttp.Open("GET", "http://real-play.ru/", False)
call objHttp.Send
Responded = objHttp.ResponseText
MsgBox TypeName(Responded)
set FSO=CreateObject("Scripting.FileSystemObject")
With FSO.OpenTextFile("real-play.txt", 2, True)
 .Write Responded
 .Close
End With
По идее, все должно прекрасно работать, но 8 строка возвращает ошибку. Сначала думал, что ResponseText не совсем является типом String, но строка №6 меня в этом разубедила. Тогда в чем проблема?
0
0 / 0 / 0
Регистрация: 29.03.2013
Сообщений: 8
14.08.2013, 18:10  [ТС]
Цитата Сообщение от Dragokas
А Вы пытались вручную ввести этот запрос в адресную строку браузера, чтобы добиться адекватного ответа от xxxx.ru?
Да конечно... вроде разобрался, у меня все правильно, ошибка была у партнера, ее устранили...
Теперь вопрос другой немного, мне мой закодированный параметр необходимо еще в json формате отправлять...
Подскажете?
0
Эксперт WindowsАвтор FAQ
 Аватар для Dragokas
18031 / 7734 / 892
Регистрация: 25.12.2011
Сообщений: 11,502
Записей в блоге: 16
14.08.2013, 21:17
FraidZZ, FSO не предназначался для записи бинарной информации.
Почему-то по его мнению обычные знаки (?) (ASC 63) со средины записи считаются таковыми.

См. в режиме отладки на перем. a:

Кликните здесь для просмотра всего текста
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
Const ForAppending As Long = 8, ForReading As Long = 1, ForWriting As Long = 2
 
Sub aa()
With CreateObject("Microsoft.XMLHTTP")
    .Open "GET", "http://real-play.ru/", False
    .Send
    responded = .ResponseText
End With
 
Set FSO = CreateObject("Scripting.FileSystemObject")
 
Stop
With FSO.OpenTextFile("h:\real-play.txt", ForWriting, True)
    On Error Resume Next
    For n = 1 To Len(responded)
        '.Write Chr(Asc(Mid(responded, n, 1)))
        ch = Mid(responded, n, 1)
        a = Asc(ch)
        .Write ch
        If Err Then Stop: Err.Clear
    Next
    .Close
End With
End Sub


Хотя тест показывает, что записываются спокойно все Chars:

Кликните здесь для просмотра всего текста
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
Sub test()
Set FSO = CreateObject("Scripting.FileSystemObject")
 
'Формируем строку с Char от 0 до 255
For n = 0 To 255
    chars = chars & Chr(n)
Next
Stop
With FSO.OpenTextFile("h:\real-play.txt", ForWriting, True)
    On Error Resume Next
    For n = 1 To Len(chars)
        ch = Mid(chars, n, 1)
        .Write ch
        If Err Then Err.Clear Else good = good & ch
    Next
    .Close
End With
Stop
MsgBox good
End Sub


В любом случае ты можешь воспользоваться этим трюком:

Visual Basic
.Write Chr(Asc(Mid(responded, n, 1)))
Или использовать ADO.Stream, выставив нужную кодировку (в данном случае у меня Win-1251):

Кликните здесь для просмотра всего текста
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
Const adTypeBinary = 1, adTypeText = 2
Const adSaveCreateOverWrite = 2
 
Sub aa()
With CreateObject("Microsoft.XMLHTTP")
    .Open "GET", "http://real-play.ru/", False
    .Send
    responded = .ResponseText
End With
 
Set oStream = CreateObject("ADODB.Stream")
With oStream
    .Type = adTypeText 'adTypeBinary
    .Charset = "windows-1251"
    .Open
    'здесь Write не тоже самое, что и в FSO. Write записывает данные в сам объект ADODB.Stream (поток)
    .WriteText responded
    .SaveToFile "h:\real-play.txt", adSaveCreateOverWrite
    .Close
End With
Set oStream = Nothing
End Sub


P.S. Все примеры отлаживал в Excel-е (с пост-проверкой в VBS).
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
14.08.2013, 21:17
Помогаю со студенческими работами здесь

Получение макета внешнего отчета
Если отчет в составе конф-ии, то получение макета: Макет=Отчеты.Отчет1.ПолучитьМакет("Макет"); А если отчет внешний, то как...

Получение Json с внешнего сайта
Нужно получить файл JSon с другого сайта Вот отсюда, посмотрите на него(желательно) ...

Получение локального и внешнего IP-адресов
Давайте обсудим разные способы: встроенными командами VBS сторонними утилитами.

Запуск внешнего IE и получение кода страницы
Как на Delphi открыть внешний браузер Internet Explorer, дождаться загрузки страницы, вывести исходный код страницы (HTML) в memo и закрыть...

Получение значения св-ва из внешнего css-файла. ???
Кусок css-файла : Как на javascript получить, например, св-во height в переменную? Не могу в синтаксисе разобраться, там...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru