mirror of
https://github.com/tursom/TursomServer.git
synced 2025-01-07 19:00:16 +08:00
优化性能
This commit is contained in:
parent
a775ba1b5e
commit
f3ac61c346
@ -2,5 +2,5 @@ dependencies {
|
|||||||
compileOnly 'com.alibaba:fastjson:1.2.62'
|
compileOnly 'com.alibaba:fastjson:1.2.62'
|
||||||
compileOnly group: 'com.google.code.gson', name: 'gson', version: '2.8.6'
|
compileOnly group: 'com.google.code.gson', name: 'gson', version: '2.8.6'
|
||||||
compileOnly group: 'com.fasterxml.jackson.core', name: 'jackson-core', version: '2.10.1'
|
compileOnly group: 'com.fasterxml.jackson.core', name: 'jackson-core', version: '2.10.1'
|
||||||
compile group: 'com.fasterxml.jackson.core', name: 'jackson-databind', version: '2.10.1'
|
compileOnly group: 'com.fasterxml.jackson.core', name: 'jackson-databind', version: '2.10.1'
|
||||||
}
|
}
|
@ -20,4 +20,8 @@ class JsonWorkerImpl : JsonWorker {
|
|||||||
|
|
||||||
override fun <T> fromJson(json: String, clazz: Class<T>): T? =
|
override fun <T> fromJson(json: String, clazz: Class<T>): T? =
|
||||||
gson?.fromJson(json, clazz) ?: jackson?.readValue(json, clazz)
|
gson?.fromJson(json, clazz) ?: jackson?.readValue(json, clazz)
|
||||||
|
|
||||||
|
override fun toString(): String {
|
||||||
|
return "JsonWorkerImpl(gson=$gson, jackson=$jackson)"
|
||||||
|
}
|
||||||
}
|
}
|
@ -128,18 +128,21 @@ open class RoutedHttpHandler<T : HttpContent, in E : ExceptionContent>(
|
|||||||
}
|
}
|
||||||
routes.forEach { route ->
|
routes.forEach { route ->
|
||||||
log?.info("method route {} mapped to {}", route, method)
|
log?.info("method route {} mapped to {}", route, method)
|
||||||
router[safeRoute(route)] = handler@{ content ->
|
router[safeRoute(route)] = if (method.parameterTypes.isEmpty()) when {
|
||||||
if (method.parameterTypes.isEmpty()) {
|
method.getAnnotation(Html::class.java) != null -> { content ->
|
||||||
val result = method(obj) ?: return@handler
|
method(obj)?.let { result -> finishHtml(result, content) }
|
||||||
when {
|
|
||||||
method.getAnnotation(Html::class.java) != null -> finishHtml(result, content)
|
|
||||||
method.getAnnotation(Text::class.java) != null -> finishText(result, content)
|
|
||||||
method.getAnnotation(Json::class.java) != null -> finishJson(result, content)
|
|
||||||
else -> autoReturn(result, content)
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
method(obj, content)
|
|
||||||
}
|
}
|
||||||
|
method.getAnnotation(Text::class.java) != null -> { content ->
|
||||||
|
method(obj)?.let { result -> finishText(result, content) }
|
||||||
|
}
|
||||||
|
method.getAnnotation(Json::class.java) != null -> { content ->
|
||||||
|
method(obj)?.let { result -> finishJson(result, content) }
|
||||||
|
}
|
||||||
|
else -> { content ->
|
||||||
|
method(obj)?.let { result -> autoReturn(result, content) }
|
||||||
|
}
|
||||||
|
} else { content ->
|
||||||
|
method(obj, content)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -173,42 +176,55 @@ open class RoutedHttpHandler<T : HttpContent, in E : ExceptionContent>(
|
|||||||
|
|
||||||
private fun safeRoute(route: String) = if (route.first() == '/') route else "/$route"
|
private fun safeRoute(route: String) = if (route.first() == '/') route else "/$route"
|
||||||
|
|
||||||
private fun autoReturn(result: Any, content: HttpContent) = when (result) {
|
private fun autoReturn(result: Any, content: HttpContent) {
|
||||||
is String -> content.finishText(result.toByteArray())
|
log?.debug("{}: autoReturn: {}", content.clientIp, result)
|
||||||
is ByteArray -> content.finishText(result)
|
when (result) {
|
||||||
is File -> {
|
is String -> content.finishText(result.toByteArray())
|
||||||
content.autoContextType(result.name)
|
is ByteArray -> content.finishText(result)
|
||||||
content.finishFile(result)
|
is File -> {
|
||||||
|
content.autoContextType(result.name)
|
||||||
|
content.finishFile(result)
|
||||||
|
}
|
||||||
|
is RandomAccessFile -> {
|
||||||
|
content.finishFile(result)
|
||||||
|
}
|
||||||
|
is Chunked -> content.finishChunked(result)
|
||||||
|
else -> finishJson(result, content)
|
||||||
}
|
}
|
||||||
is RandomAccessFile -> content.finishFile(result)
|
|
||||||
is Chunked -> content.finishChunked(result)
|
|
||||||
else -> finishJson(result, content)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun finishHtml(result: Any, content: HttpContent) = when (result) {
|
private fun finishHtml(result: Any, content: HttpContent) {
|
||||||
is ByteBuffer -> content.finishHtml(result)
|
log?.debug("{}: finishHtml: {}", content.clientIp, result)
|
||||||
is ByteArray -> content.finishHtml(result)
|
when (result) {
|
||||||
is String -> content.finishHtml(result.toByteArray())
|
is ByteBuffer -> content.finishHtml(result)
|
||||||
else -> content.finishHtml(result.toString().toByteArray())
|
is ByteArray -> content.finishHtml(result)
|
||||||
|
is String -> content.finishHtml(result.toByteArray())
|
||||||
|
else -> content.finishHtml(result.toString().toByteArray())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun finishText(result: Any, content: HttpContent) = when (result) {
|
private fun finishText(result: Any, content: HttpContent) {
|
||||||
is ByteBuffer -> content.finishText(result)
|
log?.debug("{}: finishText: {}", content.clientIp, result)
|
||||||
is ByteArray -> content.finishText(result)
|
when (result) {
|
||||||
is String -> content.finishText(result.toByteArray())
|
is ByteBuffer -> content.finishText(result)
|
||||||
else -> content.finishText(result.toString().toByteArray())
|
is ByteArray -> content.finishText(result)
|
||||||
|
is String -> content.finishText(result.toByteArray())
|
||||||
|
else -> content.finishText(result.toString().toByteArray())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun finishJson(result: Any, content: HttpContent) {
|
private fun finishJson(result: Any, content: HttpContent) {
|
||||||
|
log?.debug("{}: finishJson: {}", content.clientIp, result)
|
||||||
when (result) {
|
when (result) {
|
||||||
is ByteBuffer -> content.finishJson(result)
|
is ByteBuffer -> content.finishJson(result)
|
||||||
is ByteArray -> content.finishJson(result)
|
is ByteArray -> content.finishJson(result)
|
||||||
is String -> content.finishJson("\"$result\"".toByteArray())
|
is String -> content.finishJson("\"$result\"".toByteArray())
|
||||||
is Byte, Short, Int, Long, Float, Double, Boolean -> content.finishJson(result.toString().toByteArray())
|
is Byte, Short, Int, Long, Float, Double, Boolean -> content.finishJson(result.toString().toByteArray())
|
||||||
else -> {
|
else -> {
|
||||||
val json = json?.toJson(result)?.toByteArray()
|
val json = json?.toJson(result)
|
||||||
|
log?.debug("{}: finishJson: generate json: {}", content.clientIp, json)
|
||||||
if (json != null) {
|
if (json != null) {
|
||||||
content.finishJson(json)
|
content.finishJson(json.toByteArray())
|
||||||
} else {
|
} else {
|
||||||
content.finishText(result.toString().toByteArray())
|
content.finishText(result.toString().toByteArray())
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user