Scala微服务架构 三
四 Controller层
之前我们已经把基层架构搭建好了,那么要如何使用呢?
首先看看我的Controller层代码
@Singleton
class BMAuthController @Inject()(implicit cc: ControllerComponents, actorSystem: ActorSystem)
extends AbstractController(cc) with Circe with CirceJsonapiSupport {
val entry = PlayEntry()
def parseJson(jsonString: String) : Json = io.circe.parser.parse(jsonString).right.get
def decodeJson[T](json: Json)(implicit d: io.circe.Decoder[T]) : T = json.as[T].right.get
def login = Action(circe.json[RootObject]) { implicit request =>
request
import model.request.requestsJsonApiOpt.requestsJsonapiRootObjectReader._
val tt = fromJsonapi(request.body)
val reVal = entry.commonExcution(
SequenceSteps(testStep(tt.reqs.head) :: Nil, None))
val ctest = company("12", "alfred")
val ctestj = asJsonApi(ctest)
println(ctestj)
val result = asJsonApiResult(reVal.asInstanceOf[userdetailresult])
Ok(result.asJson)
}
}
4.1 Controller 的声明
4.1.1 @Inject() 注解
@Inject()(implicit cc: ControllerComponents, actorSystem: ActorSystem)
首先这个@Inject会查询Play的System环境,并将查到的单例实例注入到参数中.
4.1.2 AbstractController 特质
官网解释
- AbstractController: an abstract class extending BaseController with a ControllerComponents constructor parameter that can be injected using constructor injection.
也就是说,这就是BaseController的抽象子类,但是要带有一个ControllerComponents作为构造函数.
4.1.3 Circe 特质
circe是一个Scala的Json解析库.并且目前已经支持Play.
Play的使用方式很简单,首先引入项目:
libraryDependencies += "com.dripower" %% "play-circe" % "2609.1"
然后继承play.api.libs.circe.Circe特质
使用起来也很简单,上面代码的
circe.json[RootObject]
部分就是在使用Circe解析JsonApi的Root部分.
4.1.4 CirceJsonapiSupport 特质
对JsonApi协议的支持,里面主要就是两个隐式,代码如下:
trait CirceJsonapiSupport extends CirceJsonapiEncoders with CirceJsonapiDecoders {
implicit val circeJsonapiMarshaller = Marshaller.delegate[RootObject, String](
`application/vnd.api+json`,
`application/json`,
ContentTypes.`application/json`
)(_.asJson.noSpaces)
implicit val circeJsonapiUnmarshaller = Unmarshaller.delegate[String, RootObject](
`application/vnd.api+json`,
`application/json`
)(decode[RootObject](_).right.get)
}
object CirceJsonapiSupport extends CirceJsonapiSupport
4.2 login 代码解析
对不起,各位,暂时没写!!! ,有兴趣的可以私信我,后期我会补上.
※. 本期语法糖
※.1 Scala的构造函数
学自https://www.w3cschool.cn/scala/scala-constructors.html
今天要说的当然不是大家熟知的构造函数,而是以前我们可能忽略的细节.
class User1(var id: String, var name: String)
class User2(val id: String, val name: String)
class User3(private var id: String,private var name: String)
class User4(id: String, name: String)
上面代码定义了四个User类,每个类都有两个参数id和name,当然,他们构造函数的区别也很明显.那么这几种不同的定义方式,有什么区别呢?
- User1,定义了可变构造参数,同时编译器会自动生成setter和getter方法,但因为是默认修饰符,所以外部可以直接访问
user1.id,或者赋值user1.id("001") - User2,因为定义的构造参数是不可变的,所以只会生成getter方法,不会有setter方法,也是默认修饰符,所以外部只可以访问
user2.id,无法赋值 - User3,和User1很像,但是修饰符改为private,所以即便是var的构造参数,也不会生成getter方法和setter方法
- User4,我们最常用的写法,其实就是
private[this] val,也就是说对于自己和伴生类而言是可见的
应杨总要求,我们打印上面四个User类的编译信息
def tree1 = reify { class User1(var id: String, var name: String) }.tree
def tree2 = reify { class User2(val id: String, val name: String) }.tree
def tree3 = reify { class User3(private var id: String,private var name: String) }.tree
def tree4 = reify { class User4(id: String, name: String) }.tree
然后分别打印上面的四个树,输出结果如下:
tree1:
{
class User1 extends AnyRef {
<paramaccessor> var id: Predef.String = _;
<paramaccessor> var name: Predef.String = _;
def <init>(id: Predef.String, name: Predef.String) = {
super.<init>();
()
}
};
()
}
tree2:
{
class User2 extends AnyRef {
<paramaccessor> val id: Predef.String = _;
<paramaccessor> val name: Predef.String = _;
def <init>(id: Predef.String, name: Predef.String) = {
super.<init>();
()
}
};
()
}
tree3:
{
class User3 extends AnyRef {
<paramaccessor> private var id: Predef.String = _;
<paramaccessor> private var name: Predef.String = _;
def <init>(id: Predef.String, name: Predef.String) = {
super.<init>();
()
}
};
()
}
tree4:
{
class User3 extends AnyRef {
<paramaccessor> private[this] val id: Predef.String = _;
<paramaccessor> private[this] val name: Predef.String = _;
def <init>(id: Predef.String, name: Predef.String) = {
super.<init>();
()
}
};
()
}
Scala微服务架构 三的更多相关文章
- Scala微服务架构 一
因为公司的一个项目需求变动会非常频繁,同时改动在可控范围内,加上产品同学喜欢一些超前思维,我们的CTO决定提前开启八门,使用微服务架构. 划重点 微服务架构主要特点: ==独立组件(自主开发升级)== ...
- Re:从 0 开始的微服务架构--(三)微服务架构 API 的开发与治理--转
原文来自:聊聊架构公众号 前面的文章中有说到微服务的通信方式,Martin Folwer 先生在他对微服务的定义中也提到“每个服务运行在其独立的进程中,服务与服务间采用 轻量级的通信机制 互相协作(通 ...
- Scala微服务架构 二
三. Scala的Macro(宏) Scala Macros对scala函数库编程人员来说是一项不可或缺的编程工具,可以通过它来解决一些用普通编程或者类层次编程(type level programm ...
- springcloud微服务架构搭建
SpringCloud微服务框架搭建 一.微服务架构 1.1什么是分布式 不同模块部署在不同服务器上 作用:分布式解决网站高并发带来问题 1.2什么是集群 多台服务器部署相同应用构成一个集群 作用:通 ...
- spring cloud+dotnet core搭建微服务架构:Api网关(三)
前言 国庆假期,一直没有时间更新. 根据群里面的同学的提问,强烈推荐大家先熟悉下spring cloud.文章下面有纯洁大神的spring cloud系列. 上一章最后说了,因为服务是不对外暴露的,所 ...
- JHipster生成微服务架构的应用栈(三)- 业务微服务示例
本系列文章演示如何用JHipster生成一个微服务架构风格的应用栈. 环境需求:安装好JHipster开发环境的CentOS 7.4(参考这里) 应用栈名称:appstack 认证微服务: uaa 业 ...
- spring cloud+.net core搭建微服务架构:Api网关(三)
前言 国庆假期,一直没有时间更新. 根据群里面的同学的提问,强烈推荐大家先熟悉下spring cloud.文章下面有纯洁大神的spring cloud系列. 上一章最后说了,因为服务是不对外暴露的,所 ...
- 中小型研发团队架构实践三:微服务架构(MSA)
一.MSA 简介 1.1.MSA 是什么 微服务架构 MSA 是 Microservice Architect 的简称,它是一种架构模式,它提倡将单一应用程序划分成一组小的服务,服务之间互相通讯.互相 ...
- 微服务架构攀登之路(三)之gRPC入门
一.gRPC入门 1. gRPC 简介 gRPC 由 google 开发,是一款语言中立.平台中立.开源的远程过程调用系统 gRPC 客户端和服务端可以在多种环境中运行和交互,例如用 java 写一个 ...
随机推荐
- css:pointer-events: none
css3新属性pointer-events: none: pointer-events: none 顾名思义,就是鼠标事件拜拜的意思.元素应用了该 CSS 属性,链接啊,点击啊什么的都变成了 “浮云牌 ...
- JavaScript: RegExp + replace
We can use RegExp + replace to change Specific text into others we want. This picture shows the resu ...
- Linux下编译安装FFmpeg
FFmpeg官网:http://www.ffmpeg.org 官网介绍 FFmpeg is the leading multimedia framework, able to decode, enco ...
- Linux网络编程学习(五) ----- 信号(第四章)
1.基本概念 进程阻塞: 进程执行条件得不到满足,就自动放弃CPU资源而进入休眠状态,以等待条件满足,当条件满足时,系统就将控制权还给该进程进行未完成的操作 共享资源: 进程间协调使用的系统资源 锁定 ...
- uname命令详解
1.简介: uname命令用于打印当前系统相关信息(内核版本号.硬件架构.主机名称和操作系统类型等). 2.命令语法: uname (选项) 3.选项: -a或--all:显示全部的信息: -m或-- ...
- 配置远程主机http服务器 打包资源
<1> 搭建nginx 验证nginx是否启动成功 https://blog.csdn.net/wdsdsdsds/article/details/51179780 https://ww ...
- python获取文件夹的大小(即取出所有文件计算大小)
import os path = r'/Users/authurchen/PycharmProjects/Demo' # print(os.listdir(path)) ls = os.listdir ...
- Linux进程的原理及与信号的联系
第1节 程序.进程.守护进程.僵尸进程的区别 程序.进程.守护进程.僵尸进程: 程序:c/php/java,代码文件,静态的,放在磁盘里的数据. 进程:正在内存中运行的程序,进程是动态的,会申请和使用 ...
- 动画之一:视图动画 View Animation
原文:https://blog.csdn.net/pzm1993/article/details/77167049 view动画支持4中动画效果,分别是: 透明度动画(AlphaAnimation) ...
- c#: 界面多语言动态切换简单实现
终于有空整理下多语言实现思路.查阅已有方案,有用不同resx文件的,有每个控件动态设置的,有用反射去整的,颇为繁琐. 结合项目中实现方法,并做简化,实现通用的多语言切换方案,以做备忘. 它支持语言自定 ...