dartでWebアプリを作りたいです。まず、html があります。
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Dart</title>
<link rel="stylesheet" href="dart.css">
<script type="text/javascript" src="https://www.google.com/jsapi"></script>
<script type="application/dart" src="dart.dart"></script>
<script src="packages/browser/dart.js"></script>
</head>
<body>
<h1>Dart</h1>
<p>Hello world from Dart!</p>
<div id="sample_container_id">
<table id="table">
<tr>
<td>Benutzername:</td>
<td><input type="text" id="inputuser" maxlength="40"></td>
</tr>
<tr>
<td>Passwort:</td>
<td><input type="password" id="inputpass" maxlength="40"></td>
</tr>
<tr>
<td><button id="button"></button></td>
</tr>
</table>
</div>
</body>
</html>
私のダーツファイルで、ローカルのグラスフィッシュサーバーで実行されるサーブレットに接続したい
ダーツ ファイルは次のようになります。
import 'dart:html';
final TableElement table = querySelector('#table');
final DivElement main_div = querySelector('#sample_container_id');
void main() {
TextInputElement user = querySelector('#inputuser');
PasswordInputElement password = querySelector('#inputpass');
ButtonElement button = querySelector('#button');
button.text = 'Send';
button.onClick.listen((e) => checkUser(user, password));
}
void checkUser(TextInputElement user, PasswordInputElement password)
{
var url = 'http://localhost:8080/dartTestServlet';
HttpRequest request = new HttpRequest();
request.open("POST", url);
request.onLoadEnd.listen((e) => onUserChecked(request.response.toString()));
String jsonData = '{"user":"' + user.value + '", "password":"' + password.value + '"}';
request.send(jsonData);
}
サーバーにdart接続すると、次のエラーメッセージが表示されます。
Failed to load resource: No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://127.0.0.1:3030' is therefore not allowed access. http://localhost:8080/dartTestServlet
問題が同一オリジン ポリシーであることはわかっていますが、修正方法がわかりません。
サーバーにはEclipseインスタンスを、クライアントにはDart Editorインスタンスを使用しています。Dart Editor の組み込み Web サーバーのポートを 8080 に変更するにはどうすればよいですか?
それ以外の場合、この問題を修正する必要がありますか?
事前に助けてくれてありがとう。