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

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

新規登録して質問してみよう
ただいま回答率
85.48%
コンパイル

コンパイルとは、プログラミング言語のテキストソース(ソースコード)をコンピュータ上で実行可能な形式(オブジェクトコード)に変換することをいいます

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

API

APIはApplication Programming Interfaceの略です。APIはプログラムにリクエストされるサービスがどのように動作するかを、デベロッパーが定めたものです。

Q&A

解決済

1回答

2564閲覧

APIに値をPOSTできません

Monkuma

総合スコア3

コンパイル

コンパイルとは、プログラミング言語のテキストソース(ソースコード)をコンピュータ上で実行可能な形式(オブジェクトコード)に変換することをいいます

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

API

APIはApplication Programming Interfaceの略です。APIはプログラムにリクエストされるサービスがどのように動作するかを、デベロッパーが定めたものです。

0グッド

0クリップ

投稿2021/05/30 03:01

編集2021/05/30 08:43

前提・実現したいこと

ブラウザで利用できる簡易オンラインコンパイラを作りたい。
AceEditorでコードを受け取りJdoodleAPIにコードを送信し出力結果を得るという流れを実現させようとしています。
JdoodleAPIにテストコードを送信しましたがエラー(下に記述)が発生している状態です。
(JavaScript,APIを使用するのはほぼ初めで該当のソースコードの記述意図を答えられない場合がございます)

・JdoodleAPI Document
https://docs.jdoodle.com/compiler-api/compiler-api

発生している問題・エラーメッセージ

以下、Googlechromeのコンソールで確認しました。

Console

1Failed to load resource: the server responded with a status of 415 () 2POST https://api.jdoodle.com/v1/execute net::ERR_ABORTED 415

該当のソースコード

JavaScript

1async function compilerAPI(userCode) { 2 3const myHeaders = new Headers(); 4myHeaders.append('Content-Type', 'application/json; charset=UTF-8'); 5var raw = { 6 clientId: "***", 7 clientSecret: "***", 8 script: userCode, 9 stdin: "", 10 language: "java", 11 versionIndex: "0", 12}; 13var send = JSON.stringify(raw); 14 15var requestOptions = { 16 17 mode: 'no-cors', 18 method: "POST", 19 headers: myHeaders, 20 body: send, 21 redirect: "follow", 22 23}; 24const url = 'https://api.jdoodle.com/v1/execute'; 25 26var data = await fetch(url,requestOptions ) 27.then((response) => response.text()) 28.then((result) => result) 29.catch((error) => console.log("error", error)); 30 31return data; 32} 33 34compilerAPI("public class Main{public static void main(String[] a){System.out.println(5555);}}"); 35

試したこと

・415エラーについて調べたことろ、適切なフォーマットでないためサーバーがリクエストを拒否してるとのことでしたので以下のページのJava Exampleを実装しました。うまくコンパイルでき、出力結果を得ることができました。
したがって、該当のソースコードに問題があると考えています。
https://docs.jdoodle.com/compiler-api/compiler-api#java-example-for-execute-api-call

・以下のページに従ってmode: 'no-cors'を削除して実行すると別のエラーが発生しました。
https://stackoverflow.com/questions/66781784/post-https-api-jdoodle-com-v1-execute-neterr-aborted-415

Console

1Access to fetch at 'https://api.jdoodle.com/v1/execute' from origin 'http://localhost:8080' has been blocked by CORS policy: Response to preflight request doesn't pass access control check: No 'Access-Control-Allow-Origin' header is present on the requested resource. If an opaque response serves your needs, set the request's mode to 'no-cors' to fetch the resource with CORS disabled. 2script.js:27 POST https://api.jdoodle.com/v1/execute net::ERR_FAILED

よろしくお願いいたします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

(手元でコードの確認とかを改めて行い、まるごと書き換えてます)

コードについて

もとのコードをブラウザで動作されるように実行すると、JDoodleへのAPI呼び出し時のリクエストヘッダーがtext/plainになっています。
これは、Fetch APIにおけるmode: no-corsの条件を満たさなくなるために、myHeaderでのContent-Typeの上書きが機能していないためだと思います。

MDNより

目的について

ブラウザで利用できる簡易オンラインコンパイラを作りたい。

上記理由により、Fetch APIで直接APIコールするのは不可能と考えたほうが良さそうです。
(一泊おいて考えたら、ID/Secretを両方使用してコールする機能をブラウザ上で実行出来るのはアカウント利用者側にとっての不利益も大きいし、塞がれてて然るべきではあります)

もし仮に、静的HTML以外の手段を取れるのであれば、バックエンドで「JDoodle APIをコールして」「結果を中継する」ようなAPIを1個だけ自作するような形式で、簡易的なWebアプリとして実装する必要があります。

投稿2021/05/30 10:00

編集2021/05/30 10:35
attakei

総合スコア2738

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

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

Monkuma

2021/05/30 10:06

ご回答ありがとうございます! 試してみましたが変わらずエラーですね...????
Monkuma

2021/05/30 23:34

詳しく調べていただきありがとうございます! 数週間くらい悩んでいたので本当に助かりました。 バックエンド側で処理を実装しようと思います(^^)
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問