Dart开发服务端,我是不是发烧(骚)了?
前言
最近一段时间,我和我的团队开发了两个 APP
。
客户端方面采用了 Flutter
,方便跨平台。
服务端方面剑走偏锋,没有采用 php
, pythod
, java
之类的,而是采用了与 Flutter
一样的 Dart
语言。
回顾整个过程,觉得自己烧(骚)的不轻,写下这篇文章,全当是记录病情了。若是还有其他青年才俊,也有 Dart
开发服务端的想法,可以有个参考。
我为什么想到使用 Dart 开发服务端
很多开发者听说 Dart
语言,是从 Flutter
这个客户端开发框架开始的。
使用 Flutter
框架开发跨平台应用,可以最大程度保证各平台一致性,并且与原生语言一致的使用体验,同时提高工作效率,减少重复工作成本。基于 Dart
语言,使用 Flutter
框架,目前已经开发出了很多令人满意的客户端应用,各大公司也在积极推进这方面的工作。
实际上,Dart
语言不仅仅适用于做客户端开发,同样的,Dart
也可以作为服务端开发。
Dart
拥有的重要特性如下:
Dart
支持静态编译,相比较 PHP
, Pythod
等语言,可以有更高的执行性能。
Dart
支持异步任务,相比较 Java
等,天生支持高并发。
Dart
支持面向对象,相比较 Go
等,更容易建模和理解。
另外还有一点,需要特别提醒:
Dart
在客户端开发领域,已经取得了有目共睹的成功,如果在服务端领域也采用 Dart
,可以更高复用代码,减少沟通成本,提高开发效率。
因此,使用 Dart
语言做服务端开发,是一件非常值得尝试的事情。
写下第一行服务端代码
在Dart
的服务端世界里,目前一切都是那么原始和荒芜,就连WEB服务器都需要自己编写。
新建 main.dart
文件
import 'dart:io';
main() async {
var server = await HttpServer.bind(
InternetAddress.loopbackIPv4,
4040,
);
print('Listening on localhost:${server.port}');
await for (HttpRequest request in server) {
request.response
..write('Hello, world!')
..close();
}
}
上述代码,在本地计算机 4040
端口,开启了 HTTP
服务,并且接收 HTTP
请求,
打开浏览器,访问 localhost:4040
即可看到浏览器输出 Hello, world!
代码看起来还是很简单,不复杂。
简单的路由先用起来
从上面的代码,也能看出来, HttpRequest
就是我们在浏览器访问网页地址的时候产生的,我们猜测他应该包含的有请求信息。
果不其然,打开 HttpRequest
的源码,你能看见很多信息,比如:
- method
- uri
- headers
- cookies
- session
- connectionInfo
可以看到,都是一些非常常见的 WEB
概念。
其中 uri
下又有 path
, 即是请求路径,也就是说:
当你在浏览器里请求 \
路径时候, request.uri.path 的值就是 \
当你在浏览器里请求 \abc
路径时候, request.uri.path 的值就是 \abc
当你在浏览器里请求 \admin
路径时候, request.uri.path 的值就是 \admin
那这是事就好办了, if
, else
走起来
import 'dart:io';
main() async {
var server = await HttpServer.bind(
InternetAddress.loopbackIPv4,
4040,
);
print('Listening on localhost:${server.port}');
await for (HttpRequest request in server) {
routeHandle(request);
}
}
void routeHandle(HttpRequest request) {
if (request.uri.path == '/abc') {
request.response
..write('Hello, abc!')
..close();
} else if (request.uri.path == '/admin') {
request.response
..write('Hello, admin!')
..close();
} else {
request.response
..write('Hello, world!')
..close();
}
}
嗯嗯,这里还需要优化,先看看效果。
简单的控制器用起来
控制器一般用来接收请求信息,然后调用系统内部代码处理信息,最后返回响应信息。
废话少说,拿代码来。
新建文件 HomeController.dart
, 键入如下代码
import 'dart:io';
class HomeController {
static String index(HttpRequest request) {
// some other code
return 'hello world';
}
static String abc(HttpRequest request) {
// some other code
return 'hello abc';
}
static String admin(HttpRequest request) {
// some other code
return 'hello admin';
}
}
在 main.dart
导入该控制器,并且修改内容
import 'dart:io';
import 'HomeController.dart';
main() async {
var server = await HttpServer.bind(
InternetAddress.loopbackIPv4,
4040,
);
print('Listening on localhost:${server.port}');
await for (HttpRequest request in server) {
routeHandle(request);
}
}
void routeHandle(HttpRequest request) {
String content = '';
if (request.uri.path == '/abc') {
content = HomeController.abc(request);
} else if (request.uri.path == '/admin') {
content = HomeController.admin(request);
} else {
content = HomeController.index(request);
}
request.response
..write(content)
..close();
}
嗯嗯,这里还需要优化,以后再说。
简单的数据库操作用起来
在项目依赖文件 pubspec.yaml
添加新的依赖项 mysql1: ^0.19.2
使用 mysql1
来一个简单的查询
ConnectionSettings settings = new ConnectionSettings(
host: 'localhost',
port: 3306,
user: 'bob',
password: 'wibble',
db: 'mydb'
);
MySqlConnection conn = await MySqlConnection.connect(settings);
var results = await conn.query('select name, email from users where id = ?', [1]);
for (var row in results) {
print('Name: ${row[0]}, email: ${row[1]}');
});
直接写SQL,那不得掉很多头发,简单封装下再来
List<Column> condition = [Column('id', '=', 1)];
List<Map<String,dynamic>> list = await Db('users').where(condition).select();
print(list);
嗯嗯,链式操作,用起来方便多了。
总结
至此,我们使用 Dart
语言,实现了从浏览器请求,到路由,到控制器,并且可以操作数据库。
当然它很简单,真正用起来还需要其他工作。
但是(一定要加但是),至少我们验证了 Dart
开发服务端的可行性,在后端开发的技术选型上又多另一个选择。
你们说呢?## 前言
最近一段时间,我和我的团队开发了两个 APP
。
客户端方面采用了 Flutter
,方便跨平台。
服务端方面剑走偏锋,没有采用 php
, pythod
, java
之类的,而是采用了与 Flutter
一样的 Dart
语言。
回顾整个过程,觉得自己烧(骚)的不轻,写下这篇文章,全当是记录病情了。若是还有其他青年才俊,也有 Dart
开发服务端的想法,可以有个参考。
我为什么想到使用 Dart 开发服务端
很多开发者听说 Dart
语言,是从 Flutter
这个客户端开发框架开始的。
使用 Flutter
框架开发跨平台应用,可以最大程度保证各平台一致性,并且与原生语言一致的使用体验,同时提高工作效率,减少重复工作成本。基于 Dart
语言,使用 Flutter
框架,目前已经开发出了很多令人满意的客户端应用,各大公司也在积极推进这方面的工作。
实际上,Dart
语言不仅仅适用于做客户端开发,同样的,Dart
也可以作为服务端开发。
Dart
拥有的重要特性如下:
Dart
支持静态编译,相比较 PHP
, Pythod
等语言,可以有更高的执行性能。
Dart
支持异步任务,相比较 Java
等,天生支持高并发。
Dart
支持面向对象,相比较 Go
等,更容易建模和理解。
另外还有一点,需要特别提醒:
Dart
在客户端开发领域,已经取得了有目共睹的成功,如果在服务端领域也采用 Dart
,可以更高复用代码,减少沟通成本,提高开发效率。
因此,使用 Dart
语言做服务端开发,是一件非常值得尝试的事情。
写下第一行服务端代码
在Dart
的服务端世界里,目前一切都是那么原始和荒芜,就连WEB服务器都需要自己编写。
新建 main.dart
文件
import 'dart:io';
main() async {
var server = await HttpServer.bind(
InternetAddress.loopbackIPv4,
4040,
);
print('Listening on localhost:${server.port}');
await for (HttpRequest request in server) {
request.response
..write('Hello, world!')
..close();
}
}
上述代码,在本地计算机 4040
端口,开启了 HTTP
服务,并且接收 HTTP
请求,
打开浏览器,访问 localhost:4040
即可看到浏览器输出 Hello, world!
代码看起来还是很简单,不复杂。
简单的路由先用起来
从上面的代码,也能看出来, HttpRequest
就是我们在浏览器访问网页地址的时候产生的,我们猜测他应该包含的有请求信息。
果不其然,打开 HttpRequest
的源码,你能看见很多信息,比如:
- method
- uri
- headers
- cookies
- session
- connectionInfo
可以看到,都是一些非常常见的 WEB
概念。
其中 uri
下又有 path
, 即是请求路径,也就是说:
当你在浏览器里请求 \
路径时候, request.uri.path 的值就是 \
当你在浏览器里请求 \abc
路径时候, request.uri.path 的值就是 \abc
当你在浏览器里请求 \admin
路径时候, request.uri.path 的值就是 \admin
那这是事就好办了, if
, else
走起来
import 'dart:io';
main() async {
var server = await HttpServer.bind(
InternetAddress.loopbackIPv4,
4040,
);
print('Listening on localhost:${server.port}');
await for (HttpRequest request in server) {
routeHandle(request);
}
}
void routeHandle(HttpRequest request) {
if (request.uri.path == '/abc') {
request.response
..write('Hello, abc!')
..close();
} else if (request.uri.path == '/admin') {
request.response
..write('Hello, admin!')
..close();
} else {
request.response
..write('Hello, world!')
..close();
}
}
嗯嗯,这里还需要优化,先看看效果。
简单的控制器用起来
控制器一般用来接收请求信息,然后调用系统内部代码处理信息,最后返回响应信息。
废话少说,拿代码来。
新建文件 HomeController.dart
, 键入如下代码
import 'dart:io';
class HomeController {
static String index(HttpRequest request) {
// some other code
return 'hello world';
}
static String abc(HttpRequest request) {
// some other code
return 'hello abc';
}
static String admin(HttpRequest request) {
// some other code
return 'hello admin';
}
}
在 main.dart
导入该控制器,并且修改内容
import 'dart:io';
import 'HomeController.dart';
main() async {
var server = await HttpServer.bind(
InternetAddress.loopbackIPv4,
4040,
);
print('Listening on localhost:${server.port}');
await for (HttpRequest request in server) {
routeHandle(request);
}
}
void routeHandle(HttpRequest request) {
String content = '';
if (request.uri.path == '/abc') {
content = HomeController.abc(request);
} else if (request.uri.path == '/admin') {
content = HomeController.admin(request);
} else {
content = HomeController.index(request);
}
request.response
..write(content)
..close();
}
嗯嗯,这里还需要优化,以后再说。
简单的数据库操作用起来
在项目依赖文件 pubspec.yaml
添加新的依赖项 mysql1: ^0.19.2
使用 mysql1
来一个简单的查询
ConnectionSettings settings = new ConnectionSettings(
host: 'localhost',
port: 3306,
user: 'bob',
password: 'wibble',
db: 'mydb'
);
MySqlConnection conn = await MySqlConnection.connect(settings);
var results = await conn.query('select name, email from users where id = ?', [1]);
for (var row in results) {
print('Name: ${row[0]}, email: ${row[1]}');
});
直接写SQL,那不得掉很多头发,简单封装下再来
List<Column> condition = [Column('id', '=', 1)];
List<Map<String,dynamic>> list = await Db('users').where(condition).select();
print(list);
嗯嗯,链式操作,用起来方便多了。
总结
至此,我们使用 Dart
语言,实现了从浏览器请求,到路由,到控制器,并且可以操作数据库。
当然它很简单,真正用起来还需要其他工作。
但是(一定要加但是),至少我们验证了 Dart
开发服务端的可行性,在后端开发的技术选型上又多另一个选择。
你们说呢?
Dart开发服务端,我是不是发烧(骚)了?的更多相关文章
- WebService-03-使用CXF开发服务端和客户端
写在前面的话 前面两节说了使用Java提供的包开发服务端和客户端,现在使用CXF来开发,CXF提供了两个类发而服务,一个是ServerFactoryBean,另一个是JaxWsServerFactor ...
- 用beego开发服务端应用
用beego开发服务端应用 说明 Quick Start 安装 创建应用 编译运行 打包发布 代码生成 开发文档 目录结构说明 使用配置文件 beego默认参数 路由设置 路由的表述方式 直接设置路由 ...
- nodejs 开发服务端 child_process 调试方法(1)
由于最近正在做一个服务端项目,采用了nodejs引擎开发,主要是master-worker工作机制;主进程可以直接调试,但是子进程调试好像有点麻烦,我没有找到好的方法; worker这里,我分拆成了几 ...
- 【笔记6-支付及订单模块】从0开始 独立完成企业级Java电商网站开发(服务端)
支付模块 实际开发工作中经常会遇见如下场景,一个支付模块,一个订单模块,有一定依赖,一个同事负责支付模块,另一个同事负责订单模块,但是开发支付模块的时候要依赖订单模块的相关类 ,方法,或者工具类,这些 ...
- nodejs 开发服务端 部署到 iis 服务器环境 -- iisnode 安装问题解决记录
开发环境 nodejs: v10.15.3 windows: 10 iis: 10 需求: 用Nodejs开发了服务端,要部署到IIS 需要在IIS服务器上安装iisnode,结果遇到问题:安装不上 ...
- Delphi 三层框架开发 服务端开发
采用Delphi7+SQL2008 一.创建数据库和表 CREATE TABLE [dbo].[tb_Department]( [FKey] [uniqueidentifier] NOT NULL, ...
- maven版cxf集合spring开发服务端(二)
一.新建一个maven项目 二.pom.xml引入依赖 <dependency> <groupId>org.apache.cxf</groupId> <art ...
- maven版cxf集合jetty开发服务端(一)
一.首先新建一个maven项目 二.pom.xml引入依赖 <dependency> <groupId>org.apache.cxf</groupId> <a ...
- 【笔记7-部署发布】从0开始 独立完成企业级Java电商网站开发(服务端)
阿里云服务 购买 连接 购买域名 域名备案 域名解析 源配置步骤 资源地址 http://learning.happymmall.com/ 配置阿里云的yum源 1.备份 mv /etc/yum.re ...
- 【笔记4-商品模块】从0开始 独立完成企业级Java电商网站开发(服务端)
分类管理模块 数据表结构设计 分类表 CREATE TABLE.mmall_ category' ( 'id' int(11) NOT NULL AUTO_ INCREMENT COMMENT ' 类 ...
随机推荐
- 使用KVM的命令行方式安装centos7虚拟机
前提条件 1.宿主机上已经安装KVM软件,参考网址:https://www.cnblogs.com/sanduzxcvbnm/p/15538881.html 2.已经上传centos7镜像到宿主机里 ...
- Centos7搭建 KVM 环境
注意:使用KVM管理虚拟机分命令行和图形化界面两种方式,这里最后一步安装的工具是图形化管理工具 安装前准备 验证CPU是否支持KVM 如果结果中有vmx(Intel)或svm(AMD)字样,就说明CP ...
- centos7.5升级系统内核版本
1.yum update curl nss 2.yum install wget 3.rpm --import https://www.elrepo.org/RPM-GPG-KEY-elrepo.or ...
- MyCLI :一个支持自动补全和语法高亮的 MySQL/MariaDB 客户端
MyCLI 是一个易于使用的命令行客户端,可用于受欢迎的数据库管理系统 MySQL.MariaDB 和 Percona,支持自动补全和语法高亮.它是使用 prompt_toolkit 库写的,需要 P ...
- vue this.$router.push query传递对象方法
this.$router.push({ path: '/home', query: { params: JSON.stringify({ name: 'lokka', age: 18 }) } }); ...
- iOS Social和Accounts简单使用
ACAccountStore *account = [[ACAccountStore alloc] init]; ACAccountType *type = [account accountTypeW ...
- 2_CSS
1. 什么是CSS 1.1 什么是CSS Cascading Style Sheet 层叠样式表 是一种用来表现HTML(标准通用标记语言的一个应用)或XML(标准通用标记语言的一个子集)等文件样式的 ...
- 实验02_Proteus仿真数码管显示代码
一.原理总结 利用两个寄存器R4和R5来存储两个数码管的显示效果,R4是前一个数码管显示所需,而R5是后一个数码管显示所需,利用左移操作RLC来使之每一位被依次输入到C中,然后将C输入到LED中(当L ...
- [题解] LOJ 3300 洛谷 P6620 [省选联考 2020 A 卷] 组合数问题 数学,第二类斯特林数,下降幂
题目 题目里要求的是: \[\sum_{k=0}^n f(k) \times X^k \times \binom nk \] 这里面出现了给定的多项式,还有组合数,这种题目的套路就是先把给定的普通多项 ...
- SQLServer配置开启TCP/IP连接
一 先启用SQLServer的TCP/IP协议 1.1 打开SQLServer配置管理器 1.2 启用TCP/IP 二 设置SQLServer端口 2.1 双击TCP/IP,弹出属性设置框 2.2 将 ...