powered by simpleCommunicator - 2.0.51     © 2025 Programmizd 02
Форумы / Microsoft SQL Server [игнор отключен] [закрыт для гостей] / Как записать url для MSXML2.ServerXMLHTTP.6.0 для отправки multipart/form-data ?
3 сообщений из 3, страница 1 из 1
Как записать url для MSXML2.ServerXMLHTTP.6.0 для отправки multipart/form-data ?
    #40053270
Verbovsky Innokenty
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Я хочу отправить файл в телеграм пользователя. Через браузер прекрасно отправляется
Код: html
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
<form action="https://api.telegram.org/botToken/sendDocument" enctype="multipart/form-data" method="post">
	<p><b>ID пользователя:</b>
	<input type="text" name="chat_id" value="123456789"></p>
	<p><b>Заголовок:</b>
	<input type="text" name="caption" value="Caption"></p>

	<p><b>Файл для отправки:</b>
	<input type="file" name="document"></p>

	<p><input type="submit" value="Отправить"></p>
</form>



Как это сделать через MSXML2.ServerXMLHTTP.6.0 ?

Код: sql
1.
2.
3.
4.
5.
6.
7.
8.
9.
declare @retVal INT, @oXML INT, @url varchar(max), @ResponseText  varchar(max)

	EXEC @retVal = sp_OACreate 'MSXML2.ServerXMLHTTP.6.0', @oXML OUTPUT
        select @url = 'https://api.telegram.org/botToken/sendDocument?chat_id=123456789&document='

	EXEC @retVal = sp_OAMethod @oXML, 'open', NULL,'post', @url + ??????????, 'false'

	EXEC @retVal = sp_OAMethod @oXML, 'send'
	EXEC @retVal = sp_OAMethod @oXML, 'responseText', @ResponseText OUTPUT
...
Рейтинг: 0 / 0
Как записать url для MSXML2.ServerXMLHTTP.6.0 для отправки multipart/form-data ?
    #40053323
aleks222
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Не, ну читать руководства нонича не модно.
Модно искать кнопку "Сделать фсе как я хачу".

HTTP-протокол определяет два основных запроса
GET и POST.

Тибе надобно разучить POST.
Могешь Fiddler-ом посмотреть, чаво и как отсылает браузер.
...
Рейтинг: 0 / 0
Как записать url для MSXML2.ServerXMLHTTP.6.0 для отправки multipart/form-data ?
    #40053432
Verbovsky Innokenty
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Почти справился. Осталось понять, как подтянуть varbinary file_stream из талицы файлов
Код: sql
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.
DECLARE @Boundary nvarchar(64) = N'----' + CAST(newid() AS nvarchar(64))
DECLARE @ContentType nvarchar(1000) = N'multipart/form-data; boundary=' + @Boundary

DECLARE @document nvarchar(max)

SELECT @document = '--' + @Boundary + 
N'
Content-Disposition: form-data; name="document"; filename="Тестовый файл.txt"
Content-Type: plain/text

Привет!
--' + @Boundary + '--'
	declare @url varchar(8000), @retVal INT, @oXML INT, @ResponseText nvarchar(max), @bot_token varchar(64)
	SELECT @bot_token = [value] from Constants where code = 'bot'
	select @url = 'https://api.telegram.org/bottoken/sendDocument?chat_id=123456789'


	EXEC @retVal = sp_OACreate 'MSXML2.XMLHTTP', @oXML OUTPUT

	EXEC @retVal = sp_OAMethod @oXML, 'open', NULL,'post', @url,'false'
	
	EXEC @retVal = sp_OAMethod @oXML, 'setRequestHeader',NULL, 'Connection', 'keep-alive' 
	
	EXEC @retVal = sp_OAMethod @oXML, 'setRequestHeader',NULL, 'Content-Type', @ContentType

	EXEC @retVal = sp_OAMethod @oXML, 'send', NULL, @document
		
	EXEC @retVal = sp_OAMethod @oXML, 'responseText', @ResponseText OUTPUT
		

	EXEC sp_OADestroy @oXML

	SELECT @ResponseText ResponseText
...
Рейтинг: 0 / 0
3 сообщений из 3, страница 1 из 1
Форумы / Microsoft SQL Server [игнор отключен] [закрыт для гостей] / Как записать url для MSXML2.ServerXMLHTTP.6.0 для отправки multipart/form-data ?
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]