質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
MQL4

MQL4とは、MT4(MetaTrader4)で用いられるプログラム言語です。MT4は無料で使えるチャートソフトあり、MQL4を使うことで分析ツールのオリジナルスクリプトの作成ができます。

Q&A

0回答

785閲覧

【MQL4】wininet.dllを使って、gasのappにpost通信がしたいです

t-_.

総合スコア55

MQL4

MQL4とは、MT4(MetaTrader4)で用いられるプログラム言語です。MT4は無料で使えるチャートソフトあり、MQL4を使うことで分析ツールのオリジナルスクリプトの作成ができます。

0グッド

0クリップ

投稿2022/05/26 06:21

wininet.dllを使って、gasのpost通信をしたいです。

gasの方は、htmlファイルで確認して、post通信できていました。
そもそも、mt4からの通信は行ってないです。

エラーは、「ページが見つかりません」となっています。
詳しくは以下の通りです。

error

1<!DOCTYPE html><html lang="ja"> 2<head> 3<meta name="description" content="ウェブ ワープロ、プレゼンテーション、スプレッドシート"> 4<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0, user-scalable=0"> 5<link rel="shortcut icon" href="//docs.google.com/favicon.ico"> 6<title>ページが見つかりません</title> 7<meta name="referrer" content="origin"> 8<link href="//fonts.googleapis.com/css?family=Product+Sans" rel="stylesheet" type="text/css" nonce="UhiRvDbc7RMIj55gUC_5gw"><style nonce="UhiRvDbc7RMIj55gUC_5gw"> 9/* Copyright 2022 Google Inc. All Rights Reserved. */ 10...

mql4

1#property strict 2#property indicator_chart_window 3 4 5#import "wininet.dll" 6 #define INTERNET_OPEN_TYPE_DIRECT 0 7 #define AGENT "MetaTrader 5 Terminal ss Auth 2022" 8 #define READURL_BUFFER_SIZE 100000 9 10 #define INTERNET_DEFAULT_HTTPS_PORT 443 11 #define INTERNET_DEFAULT_HTTP_PORT 80 12 #define INTERNET_SERVICE_HTTP 3 13 #define INTERNET_FLAG_RELOAD -2147483648 14 15 int InternetOpenW( string sAgent, int lAccessType, string sProxyName="", string sProxyBypass="", int lFlags=0 ); 16 int InternetOpenA( string lpszAgent, int dwAccessType, string lpszProxy, string lpszProxyBypass , int dwFlags); 17 int InternetOpenUrlW( int hInternetSession, string sUrl, string sHeaders="", int lHeadersLength=0, int lFlags=0, int lContext=0 ); 18 int InternetConnectW( int iHandle, string, int, string, string, int, int, int ); 19 int InternetReadFile( int, uchar &arr[], int, int &arr[] ); 20 int InternetCloseHandle( int hInet ); 21 22 int HttpOpenRequestW( int iConnect, string lpszVerb, string lpszObjectName, string lpszVersion, string lpszReferrer, string lplpszAcceptTypes, int dwFlags, int dwContext ); 23 bool HttpSendRequestW( int iRequest, string& lpszHeaders, int dwHeadersLength, uchar& lpOptional[], int dwOptionalLength ); 24#import 25 26 27//https://script.google.com/macros/s/AKfycbwn9nAniZRpsheIzHcSsjO8Q01NW61pjzIMwRN4TxorC-m3k8LqGdfr65egboaN-Bh35A/exec 28string post_request() 29{ 30 int lReturn[1]; 31 uchar arrReceive[]; 32 uchar data[]; 33 34 //string strUrl = "https://script.google.com"; 35 //string header = "Content-Type: text/plain;charset=utf-8"; 36 //string header = "Content-Type: application/x-www-form-urlencoded"; 37 string header = "Content-Type: application/json"; 38 string domain = "script.google.com"; 39 string methods = "POST"; 40 string http_type = "HTTP/1.1"; 41 string request_url = "macros/s/AKfycbwn9nAniZRpsheIzHcSsjO8Q01NW61pjzIMwRN4TxorC-m3k8LqGdfr65egboaN-Bh35A/exec"; 42 string mydata = "{\"value\": \"AAA\"}"; 43 44 45 StringToCharArray( mydata, data ); 46 47 int hSession = InternetOpenW( AGENT, INTERNET_OPEN_TYPE_DIRECT, "0", "0", 0 ); 48 int hConnect = InternetConnectW( hSession, domain, INTERNET_DEFAULT_HTTPS_PORT, NULL, NULL, 2, 0, 0 ); 49 int hRequest = HttpOpenRequestW( hConnect, methods, request_url, http_type, NULL, NULL, INTERNET_FLAG_RELOAD, 0 ); 50 bool check = HttpSendRequestW( hRequest, header, StringLen( header ), data, ArraySize( data ) - 1 ); 51 if( !check ) 52 Alert( "check : ", check ); 53 54 Alert( "mydata : ", mydata ); 55 56 ArrayResize( arrReceive, READURL_BUFFER_SIZE + 1 ); 57 int success = InternetReadFile( hRequest, arrReceive, READURL_BUFFER_SIZE, lReturn ); 58 string errmes = "Authentication failure - Error connecting to server : by ss"; 59 if( success == 0 ){ 60 InternetCloseHandle( hSession ); 61 //return errmes; 62 } 63 64 string strThisRead = CharArrayToString( arrReceive, 0, ArraySize( arrReceive ), CP_UTF8 ); 65 InternetCloseHandle( hSession ); 66 67 Alert( strThisRead ); 68 69 return "ok"; 70} 71int OnInit() 72{ 73 Alert( post_request() ); 74 75 return INIT_SUCCEEDED; 76} 77void OnDeinit( const int reason ) 78{ 79 80} 81int OnCalculate( const int rates_total, 82 const int prev_calculated, 83 const datetime &time[], 84 const double &open[], 85 const double &high[], 86 const double &low[], 87 const double &close[], 88 const long &tick_volume[], 89 const long &volume[], 90 const int &spread[] ) 91{ 92 93 return rates_total; 94} 95

gas

1function get_sheet() { 2 const SHEET_NAME = "シート1" 3 var active_st = SpreadsheetApp.getActiveSpreadsheet(); 4 var sheet = active_st.getSheetByName( SHEET_NAME ); 5 6 return sheet; 7} 8 9function doPost(e) { 10 Logger.log(e); 11 /* 12 var name = e.parameter.name; 13 var hobby = e.parameter.hobby; 14 15 var sheet = get_sheet(); 16 sheet.appendRow( [name, hobby] ) 17 return ContentService.createTextOutput('私の名前は'+name+'、趣味は'+hobby); 18 */ 19 var params = JSON.parse(e.postData.getDataAsString()); // ※ 20 var value = params.value; // => "AAA"が取れる 21 22 // 何らかの処理... 23 24 var output = ContentService.createTextOutput(); 25 output.setMimeType(ContentService.MimeType.JSON); 26 output.setContent(JSON.stringify({ message: "success!" })); 27 28 return output; 29}

以上、よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問