mirror of
https://gitee.com/BDWare/front-base
synced 2025-01-25 01:04:01 +00:00
merge update
This commit is contained in:
parent
dffcadd116
commit
1785426e53
@ -30,7 +30,7 @@ dependencies {
|
|||||||
api 'com.google.code.gson:gson:2.8.8'
|
api 'com.google.code.gson:gson:2.8.8'
|
||||||
testImplementation 'junit:junit:4.13.2'
|
testImplementation 'junit:junit:4.13.2'
|
||||||
}
|
}
|
||||||
version = "1.0.0"
|
version = "1.0.1"
|
||||||
task classJar(type: Jar, dependsOn: classes) {
|
task classJar(type: Jar, dependsOn: classes) {
|
||||||
classifier = "jar"
|
classifier = "jar"
|
||||||
}
|
}
|
||||||
|
@ -17,7 +17,7 @@ import static io.netty.handler.codec.http.HttpVersion.HTTP_1_1;
|
|||||||
|
|
||||||
public class URIHandler {
|
public class URIHandler {
|
||||||
private static final Logger LOGGER = LogManager.getLogger(URIHandler.class);
|
private static final Logger LOGGER = LogManager.getLogger(URIHandler.class);
|
||||||
Map<io.netty.handler.codec.http.HttpMethod, List<Tuple<String, Method, Object>>> handlers;
|
private Map<io.netty.handler.codec.http.HttpMethod, List<Tuple<String, Method, Object>>> handlers;
|
||||||
|
|
||||||
public URIHandler() {
|
public URIHandler() {
|
||||||
handlers = new HashMap<>();
|
handlers = new HashMap<>();
|
||||||
@ -59,14 +59,26 @@ public class URIHandler {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public void handle(ChannelHandlerContext ctx, FullHttpRequest msg) {
|
public Tuple<String, Method, Object> findHandler(FullHttpRequest msg) {
|
||||||
try {
|
|
||||||
List<Tuple<String, Method, Object>> handlerList = handlers.get(msg.method());
|
List<Tuple<String, Method, Object>> handlerList = handlers.get(msg.method());
|
||||||
for (Tuple<String, Method, Object> t : handlerList)
|
for (Tuple<String, Method, Object> t : handlerList)
|
||||||
if (msg.uri().startsWith(t.t)) {
|
if (msg.uri().startsWith(t.t)) {
|
||||||
t.u.invoke(t.s, ctx, msg);
|
return t;
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void handle(ChannelHandlerContext ctx, FullHttpRequest msg) {
|
||||||
|
Tuple<String, Method, Object> t = findHandler(msg);
|
||||||
|
handle(ctx, msg, t);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void handle(ChannelHandlerContext ctx, FullHttpRequest msg,
|
||||||
|
Tuple<String, Method, Object> t) {
|
||||||
|
try {
|
||||||
|
if (t != null)
|
||||||
|
t.u.invoke(t.s, ctx, msg);
|
||||||
|
else
|
||||||
sendUnsupported(ctx);
|
sendUnsupported(ctx);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
@ -95,10 +107,10 @@ public class URIHandler {
|
|||||||
ctx.writeAndFlush(response).addListener(ChannelFutureListener.CLOSE);
|
ctx.writeAndFlush(response).addListener(ChannelFutureListener.CLOSE);
|
||||||
}
|
}
|
||||||
|
|
||||||
static class Tuple<T, U, S> {
|
public static class Tuple<T, U, S> {
|
||||||
T t;
|
public T t;
|
||||||
U u;
|
public U u;
|
||||||
S s;
|
public S s;
|
||||||
|
|
||||||
Tuple(T t, U u, S s) {
|
Tuple(T t, U u, S s) {
|
||||||
this.t = t;
|
this.t = t;
|
||||||
|
Loading…
Reference in New Issue
Block a user