Гость
Форумы / Microsoft SQL Server [игнор отключен] [закрыт для гостей] / Как записать url для MSXML2.ServerXMLHTTP.6.0 для отправки multipart/form-data ? / 3 сообщений из 3, страница 1 из 1
14.03.2021, 09:47
    #40053270
Verbovsky Innokenty
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Как записать url для MSXML2.ServerXMLHTTP.6.0 для отправки multipart/form-data ?
Я хочу отправить файл в телеграм пользователя. Через браузер прекрасно отправляется
Код: 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
14.03.2021, 16:43
    #40053323
aleks222
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Как записать url для MSXML2.ServerXMLHTTP.6.0 для отправки multipart/form-data ?
Не, ну читать руководства нонича не модно.
Модно искать кнопку "Сделать фсе как я хачу".

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

Тибе надобно разучить POST.
Могешь Fiddler-ом посмотреть, чаво и как отсылает браузер.
...
Рейтинг: 0 / 0
15.03.2021, 08:51
    #40053432
Verbovsky Innokenty
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Как записать url для MSXML2.ServerXMLHTTP.6.0 для отправки multipart/form-data ?
Почти справился. Осталось понять, как подтянуть 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
Форумы / Microsoft SQL Server [игнор отключен] [закрыт для гостей] / Как записать url для MSXML2.ServerXMLHTTP.6.0 для отправки multipart/form-data ? / 3 сообщений из 3, страница 1 из 1
Целевая тема:
Создать новую тему:
Автор:
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


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