使用Dart,如何使用Future正确返回HttpResponse

jab*_*son 8 dart dart-io dart-async sqljocky

我试图创建一个非常简单的http服务器做一件事.收到HttpRequest后,它会在本地数据库服务器上运行查询,并根据该查询返回一个字符串.

我正在学习Dart,而且我很难掌握期货.我以为我理解了它们,但是这个例子让我相信我真的不知道它们是如何工作的.所以,我不仅在寻找这个问题的解决方案,而且我也很乐意接受任何指示.

注意:这段代码是我一直试图完成的一个非常原始的例子,为了扩展到Stackoverflow社区,我尽可能地缩短/简化了它,同时保持问题的完整性.

这是我的server.dart代码

import 'dart:io';
import 'package:sqljocky/sqljocky.dart';


final connection = new ConnectionPool(host: 'localhost', port: 3306, user: 'root', password: null, db: 'server1');

main() {

  HttpServer.bind(InternetAddress.ANY_IP_V4, 9090)..then((server) {
    print("serving generic database query on localhost:9090");
    server.listen((request) {
      if (request.method == "GET") {
        request.response.write(getResults());
        request.response.close();
      }
      else {
        request.response.statusCode = HttpStatus.BAD_REQUEST;
      }
    });
  });
}


String getResults() {

  StringBuffer sb = new StringBuffer();
  sb.write("START--");
  connection.query("select name, email, zkey from users")
      ..then((results) {
    results.forEach((row) {
      sb.write(row.toString());
      print(row.toString());
    });
  });

  sb.write("--END");
  print(sb.toString());

  return sb.toString();
}
Run Code Online (Sandbox Code Playgroud)

因此,如果我向此服务器发送请求,则返回"START ---- END".服务器打印出预期的查询结果,然后输出"START ---- END".这使我相信我的请求响应正在关闭并在查询结果完成处理之前返回.

因此,无论我是curl localhost:9090/asdf还是实际构建客户端http请求发送者,我都没有得到我期待的响应......这是一个数据库查询结果.

提前致谢

Gün*_*uer 7

"START----END"是印有"失灵"是混乱大多数开发商在年初期货的行为.返回未来的
调用connection.query()不会立即执行,而是在队列中登记以供稍后执行.当前执行的线程一直持续到完成,然后一个接一个地处理队列.

在您的代码中不起作用的是您执行异步调用connection.query()并继续,就像它是同步调用一样.这在Dart中永远不会起作用.当您启动异步执行时,您无法返回同步.(据我所知,计划的异步/等待应解决此问题).

有关详细信息,请访问dartlang.org .事件循环和Dart

编辑测试代码

import 'dart:io';
import 'package:sqljocky/sqljocky.dart';

final connection = new ConnectionPool(host: 'localhost', port: 3306, user: 'root', password: null, db: 'server1');

main() {    
  HttpServer.bind(InternetAddress.ANY_IP_V4, 9090)..then((server) {
    print("serving generic database query on localhost:9090");
    server.listen((request) {
      if (request.method == "GET") {
        getResults()
        .then((result) { 
          print('Result: $result'); 
          request.response.write(result);
          request.response.close();
        });
      }
      else {
        request.response.statusCode = HttpStatus.BAD_REQUEST;
      }
    });
  });
}

Future<String> getResults() { 

  StringBuffer sb = new StringBuffer();
  sb.write("START--");
  return connection.query("select name, email, zkey from users") 
  .then((Result results) => results.toList())
  .then((list) {
    list.forEach((row) {
      sb.write(row.toString());
    });
    sb.write("--END");
  })
  .then((_) => sb.toString());
}
Run Code Online (Sandbox Code Playgroud)

另请参阅Gregs关于此问题的答案如何读取SqlJocky结果sqljocky同步查询数据库