Форум программистов, компьютерный форум, киберфорум
Visual Basic
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.79/19: Рейтинг темы: голосов - 19, средняя оценка - 4.79
0 / 0 / 0
Регистрация: 08.10.2011
Сообщений: 38

Скачиваю страничку через WinHTTP, но там проблема с кодировкой

24.02.2012, 04:18. Показов 3619. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте

Проблемка в кодировке, скачиваю страничку через WinHTTP, там русские буквы в текстбоксе вижу:
"Eniieucoaiue ycue:"
За место:
"Используемый язык:"

POST запрос:

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
http.Open "POST", "http://" & site & "/index.php"
http.SetRequestHeader "USER-AGENT", "User-Agent: Opera/9.80 (Windows NT 5.1; U; ru) Presto/2.9.168 Version/11.51"
'http.SetRequestHeader "Accept-Encoding", "gzip, deflate"
'http.SetRequestHeader "Accept-Charset", "windows-1251,utf-8;q=0.7,*;q=0.7"
'http.SetRequestHeader "Accept-Language", "ru,en-us;q=0.7,en;q=0.3"
http.SetRequestHeader "Referer", "http://" & site & "/"
http.SetRequestHeader "Cache-Control", "no-cache"
http.SetRequestHeader "Keep-Alive", "300"
http.SetRequestHeader "Connection", "Keep-Alive"
http.SetRequestHeader "Content-Type", "application/x-www-form-urlencoded"
http.Send
Не получается никак нормальный русский язык получить.. Пробовал Accept-Charset вот вставлять и ничего не менялось.. Кто нибудь помогите.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
24.02.2012, 04:18
Ответы с готовыми решениями:

Проблема с кодировкой при записи в MSSQL через WML
По коду: - обычная WML форма через <anchor><go>.. - есть строка Session.Codepage=1251 Косяки: - при добавлении в базу,...

Прием байтов через сокеты в консоль - проблема с кодировкой кириллицы
Через сокет принимаю массив байтов, потом достаю из них символы и вывожу на консоль. Когда принимаю сообщение английской раскладкой - всё...

Пропадает интернет когда скачиваю через торрент
Здравствуйте уважаемые форумчане! Суть проблемы, когда скачиваю любые файлы через торрент клиент (utorrent) пропадает интернет,...

9
0 / 0 / 0
Регистрация: 08.10.2011
Сообщений: 38
27.02.2012, 14:56  [ТС]
Ну ктонибудь помогите) сайт с которого скачиваю страничку:
Visual Basic
1
kisslinka.ru
Посмотрите всё сами увидите.. как быть ? мне нужно исходный код страницы получить таким какой он есть
0
 Аватар для Kogb
367 / 128 / 28
Регистрация: 17.07.2011
Сообщений: 253
Записей в блоге: 1
27.02.2012, 21:15
Советую для достижения этой цели использовать URLDownloadToFile

Visual Basic
1
2
3
4
5
6
7
8
9
10
Private Declare Function URLDownloadToFile Lib "urlmon" Alias "URLDownloadToFileA" (ByVal pCaller As Long, ByVal szURL As String, ByVal szFileName As String, ByVal dwReserved As Long, ByVal lpfnCB As Long) As Long
Public Function DownloadFile(URL As String, LocalFilename As String) As Boolean
    Dim lngRetVal As Long
    lngRetVal = URLDownloadToFile(0, URL, LocalFilename, 0, 0)
    If lngRetVal = 0 Then DownloadFile = True
End Function
Private Sub Form_Load()
    'example by Matthew Gates (Puff0rz@hotmail.com)
    DownloadFile "http://kisslinka.ru/index.php", "c:\kisslinka.htm"
End Sub
1
0 / 0 / 0
Регистрация: 08.10.2011
Сообщений: 38
29.02.2012, 13:00  [ТС]
А вот если куки использовать то так быть то.. ?
0
 Аватар для Kogb
367 / 128 / 28
Регистрация: 17.07.2011
Сообщений: 253
Записей в блоге: 1
01.03.2012, 01:57
Попробуй компонент Webbrowser из Microsoft Internet Controls. Там куки используются от IE, насколько я знаю.
0
0 / 0 / 0
Регистрация: 08.10.2011
Сообщений: 38
01.03.2012, 05:59  [ТС]
Это как вариант, и вроде URLDownloadToFile использует куки от IE или я ошибаюсь.. А вот чтонибудь такое бы как WinHTTP
Подскажите где новичку почитать про Winsock для vb6 ..
нашел один пример в гугле но чего то запутался или пример такой был.. Скачивается не вся страничка а как то урезано..... зато русские буквы в порядке)..
0
 Аватар для Pro_grammer
6807 / 2839 / 527
Регистрация: 24.04.2011
Сообщений: 5,308
Записей в блоге: 10
01.03.2012, 07:38
Цитата Сообщение от RedBox Посмотреть сообщение
Подскажите где новичку почитать про Winsock для vb6
Самая первая тема тут "О том как узнать внешний IP"
Там и ещё один способ есть - InternetOpenUrl
0
0 / 0 / 0
Регистрация: 08.10.2011
Сообщений: 38
02.03.2012, 16:01  [ТС]
Я этот пример и находил про него говорю выше
всяко пробовал...
0
1 / 1 / 0
Регистрация: 03.08.2007
Сообщений: 155
03.03.2012, 22:34
Может это подойдет:

текст модуля

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
Declare Function MultiByteToWideChar& Lib "kernel32" (ByVal CodePage As Long, _
            ByVal dwFlags As Long, _
            ByVal lpMultiByteStr As String, _
            ByVal cchMultiByte As Long, _
            ByVal lpWideCharStr As String, _
            ByVal cchWideChar As Long)
 
Declare Function WideCharToMultiByte& Lib "kernel32" (ByVal CodePage As Long, _
            ByVal dwFlags As Long, _
            ByVal lpWideCharStr As String, _
            ByVal cchWideChar As Long, _
            ByVal lpMultiByteStr As String, _
            ByVal cchMultiByte As Long, _
            ByVal lpDefaultChar As String, _
            ByVal lpUsedDefaultChar As Long)
 
' MBCS and Unicode Translation Flags.
 
Public Const MB_PRECOMPOSED = &H1 ' use precomposed chars
Public Const MB_COMPOSITE = &H2 ' use composite chars
Public Const MB_USEGLYPHCHARS = &H4 ' use glyph chars, not ctrl chars
 
' в форму
'Text1.Text = Convert(Text1.Text, 866, 1251) 'dos->win
'Text1.Text = Convert(Text1.Text, 1251, 866) 'win->dos
'Text1.Text = Convert(Text1.Text, 28595, 1251) 'iso->win
'Text1.Text = Convert(Text1.Text, 1251, 28595) 'win->iso
'Text1.Text = Convert(Text1.Text, 20866, 1251) 'koi8r->win
'Text1.Text = Convert(Text1.Text, 20866, 1251) 'win->koi8r
 
 
Public Function Convert(ByVal strSrc As String, ByVal nFromCP As Long, ByVal nToCP As Long) As String
Dim nLen As Long
Dim strDst As String
Dim strRet As String
Dim nRet As Long
nLen = Len(strSrc)
strDst = String(nLen * 2, Chr(0))
strRet = String(nLen * 2, Chr(0))
nRet = MultiByteToWideChar(nFromCP, MB_PRECOMPOSED, strSrc, nLen, strDst, nLen)
nRet = WideCharToMultiByte(nToCP, 0, strDst, nRet, strRet, nLen * 2, ByVal 0, 0)
Convert = Left(strRet, nRet)
End Function




---------------------

вызов

Visual Basic
1
2
3
4
5
6
7
' в форму
'Text1.Text = Convert(Text1.Text, 866, 1251) 'dos->win
'Text1.Text = Convert(Text1.Text, 1251, 866) 'win->dos
'Text1.Text = Convert(Text1.Text, 28595, 1251) 'iso->win
'Text1.Text = Convert(Text1.Text, 1251, 28595) 'win->iso
'Text1.Text = Convert(Text1.Text, 20866, 1251) 'koi8r->win
'Text1.Text = Convert(Text1.Text, 20866, 1251) 'win->koi8r
1
0 / 0 / 0
Регистрация: 08.10.2011
Сообщений: 38
04.03.2012, 08:04  [ТС]
Никакого эффекта
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
04.03.2012, 08:04
Помогаю со студенческими работами здесь

такая проблема: дома 2 компъютера , один с Windows Vista, другой с Windows XP. Там, где Vista - интернет работает как часы, а там, где ХР - интернета
Здравствуйте, у меня такая проблема: дома 2 компъютера , один с Windows Vista, другой с Windows XP. Там, где Vista - интернет работает как...

С кодировкой базы данных и кодировкой сайтом и кодировкой файла разобраться не могу
С кодировкой базы данных и сайтом файлом разобраться не могу. Я на своем сайте вывожу данные из другой mysql.... МММ сайт на win 1251 а...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru