dart - 如何使用 Dart 正确创建安全的 Web 服务器?

标签 dart ssl ssl-certificate dart-shelf dart-server

这是 Dart 为使用 Shelf 包的服务器提供的典型代码:

import 'dart:io';

import 'package:shelf/shelf.dart';
import 'package:shelf/shelf_io.dart';
import 'package:shelf_router/shelf_router.dart';

// Configure routes.
final _router = Router()
  ..get('/', _rootHandler)
  ..get('/echo/<message>', _echoHandler);

Response _rootHandler(Request req) {
  return Response.ok('Hello, World!\n');
}

Response _echoHandler(Request request) {
  final message = request.params['message'];
  return Response.ok('$message\n');
}

void main(List<String> args) async {
  // Use any available host or container IP (usually `0.0.0.0`).
  final ip = InternetAddress.anyIPv4;

  // Configure a pipeline that logs requests.
  final _handler = Pipeline().addMiddleware(logRequests()).addHandler(_router);

  // For running in containers, we respect the PORT environment variable.
  final port = int.parse(Platform.environment['PORT'] ?? '8080');
  final server = await serve(_handler, ip, port);
  print('Server listening on port ${server.port}');
}

需要对其进行哪些修改/如何修改以支持安全连接 (HTTPS)?

我不是很了解证书,所以如果您能详细解释如何生成/购买它们以及如何将它们链接到服务器或任何引用资料以供引用,那就太好了。

P.S.:我的主机是运行以下 Docker 容器的 Linux 发行版 (Manjaro):文件服务器(Dart with Shelf)和 GraphQL 服务器(Postgraphile)。我是否需要为主机中运行的每个服务进行配置?

最佳答案

首先,感谢@KevinMoore 的回答,但它并不像我希望的那样完整,所以这是我的回答:

根据 Dart help上面的代码修改如下:

import 'dart:io';

import 'package:shelf/shelf.dart';
import 'package:shelf/shelf_io.dart';
import 'package:shelf_router/shelf_router.dart';

// Configure routes.
final _router = Router()
  ..get('/', _rootHandler)
  ..get('/echo/<message>', _echoHandler);

Response _rootHandler(Request req) {
  return Response.ok('Hello, World!\n');
}

Response _echoHandler(Request request) {
  final message = request.params['message'];
  return Response.ok('$message\n');
}

SecurityContext getSecurityContext() { // Bind with a secure HTTPS connection
  final chain = Platform.script.resolve('certificates/server_chain.pem').toFilePath();
  final key = Platform.script.resolve('certificates/server_key.pem').toFilePath();
  
  return SecurityContext()
  ..useCertificateChain(chain)
  ..usePrivateKey(key, password: 'dartdart');
}

void main(List<String> args) async {
  // Use any available host or container IP (usually `0.0.0.0`).
  final ip = InternetAddress.anyIPv4;

  // Configure a pipeline that logs requests.
  final _handler = Pipeline().addMiddleware(logRequests()).addHandler(_router);

  // For running in containers, we respect the PORT environment variable.
  final port = int.parse(Platform.environment['PORT'] ?? '443');
  final server = await serve(_handler, ip, port, securityContext: getSecurityContext());
  print('Server listening on port ${server.port}');
}

对于该代码,我使用了 Dart Team 在 its repository 中提供的证书和密码仅用于教育目的。

如果您的生产服务器需要证书,您可以通过 Let's Encrypt 免费获得它们。 .

这些视频对于如何获取和使用这些证书很有用:

This tutorial (日文)也是一个很好的引用。

关于dart - 如何使用 Dart 正确创建安全的 Web 服务器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69886503/

相关文章:

java - 使用 CA 证书是否足以与 SSLServerSocket 进行安全通信?

json - 如何在 dart flutter 中将 json 字符串转换为 json 对象?

wordpress - 当用户离开页面时,如何强制将 URL 从 https 更改为 http

Apache http : redirect to https:

ssl - HTTPS URL 是否加密?

internet-explorer - 如何为 Mac 的 Apache 设置 SSL,以便我可以在 IE8 上测试跨域 iFrame

c# - FindByThumbprint - 证书存在但未找到

flutter - 将 DEC 转换为 IP Dart

testing - Flutter:测试小部件

flutter - 需要帮助在 Flutter 中导入自定义图标