优化http注释

This commit is contained in:
redkale
2023-03-15 16:23:30 +08:00
parent 1428cd8f10
commit 523c101e25
8 changed files with 72 additions and 69 deletions

View File

@@ -5,10 +5,10 @@
*/ */
package org.redkale.net.http; package org.redkale.net.http;
import java.nio.channels.CompletionHandler; import java.nio.channels.*;
import java.security.SecureRandom; import java.security.*;
import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.*;
import java.util.function.Function; import java.util.function.*;
import org.redkale.annotation.ConstructorParameters; import org.redkale.annotation.ConstructorParameters;
import org.redkale.asm.*; import org.redkale.asm.*;
import static org.redkale.asm.Opcodes.*; import static org.redkale.asm.Opcodes.*;
@@ -41,7 +41,7 @@ public class HttpContext extends Context {
protected final AnyValue rpcAuthenticatorConfig; protected final AnyValue rpcAuthenticatorConfig;
//所有Servlet方法都不需要读取http-header且RestBaseServlet不是自定义HttpServlet且不存在HttpFilter的情况下lazyHeaders=true //所有Servlet方法都不需要读取http-header且RestBaseServlet不是自定义HttpServlet且不存在HttpFilter、WebSocket的情况下lazyHeaders=true
protected boolean lazyHeaders; //存在动态改值 protected boolean lazyHeaders; //存在动态改值
Function<WebSocket, WebSocketWriteIOThread> webSocketWriterIOThreadFunc; Function<WebSocket, WebSocketWriteIOThread> webSocketWriterIOThreadFunc;

View File

@@ -5,17 +5,17 @@
*/ */
package org.redkale.net.http; package org.redkale.net.http;
import java.io.IOException; import java.io.*;
import java.util.*; import java.util.*;
import java.util.concurrent.locks.ReentrantLock; import java.util.concurrent.locks.*;
import java.util.function.*; import java.util.function.*;
import java.util.logging.*; import java.util.logging.*;
import java.util.regex.Pattern; import java.util.regex.*;
import java.util.stream.Stream; import java.util.stream.*;
import org.redkale.net.*; import org.redkale.net.*;
import org.redkale.net.Filter; import org.redkale.net.Filter;
import org.redkale.net.http.Rest.RestDynSourceType; import org.redkale.net.http.Rest.RestDynSourceType;
import org.redkale.service.Service; import org.redkale.service.*;
import org.redkale.util.AnyValue.DefaultAnyValue; import org.redkale.util.AnyValue.DefaultAnyValue;
import org.redkale.util.*; import org.redkale.util.*;
@@ -400,7 +400,7 @@ public class HttpDispatcherServlet extends DispatcherServlet<String, HttpContext
} }
} }
} }
if (this.lazyHeaders && !Rest.isSimpleRestDyn(servlet)) { if (this.lazyHeaders && (!Rest.isSimpleRestDyn(servlet) || servlet instanceof WebSocketServlet)) {
this.lazyHeaders = false; this.lazyHeaders = false;
if (context != null) { if (context != null) {
context.lazyHeaders = this.lazyHeaders; //启动后运行过程中执行addServlet context.lazyHeaders = this.lazyHeaders; //启动后运行过程中执行addServlet
@@ -451,9 +451,9 @@ public class HttpDispatcherServlet extends DispatcherServlet<String, HttpContext
putMapping(mappingPath, servlet); putMapping(mappingPath, servlet);
} }
if (servlet instanceof WebSocketServlet) { if (servlet instanceof WebSocketServlet) {
Map<String, WebSocketServlet> newmappings = new HashMap<>(wsmappings); Map<String, WebSocketServlet> newMappings = new HashMap<>(wsmappings);
newmappings.put(mappingPath, (WebSocketServlet) servlet); newMappings.put(mappingPath, (WebSocketServlet) servlet);
this.wsmappings = newmappings; this.wsmappings = newMappings;
} }
} }
if (this.allMapStrings.containsKey(mappingPath)) { if (this.allMapStrings.containsKey(mappingPath)) {

View File

@@ -5,8 +5,8 @@
*/ */
package org.redkale.net.http; package org.redkale.net.http;
import org.redkale.convert.Convert; import org.redkale.convert.*;
import org.redkale.util.AnyValue; import org.redkale.util.*;
/** /**
* HTTP输出引擎的基类 <br> * HTTP输出引擎的基类 <br>
@@ -28,8 +28,11 @@ import org.redkale.util.AnyValue;
*/ */
public interface HttpRender { public interface HttpRender {
public void init(HttpContext context, AnyValue config); default void init(HttpContext context, AnyValue config) {
}
public void renderTo(HttpRequest request, HttpResponse response, Convert convert, HttpScope scope); public void renderTo(HttpRequest request, HttpResponse response, Convert convert, HttpScope scope);
default void destroy(HttpContext context, AnyValue config) {
}
} }

View File

@@ -6,17 +6,17 @@
package org.redkale.net.http; package org.redkale.net.http;
import java.io.*; import java.io.*;
import java.lang.annotation.Annotation; import java.lang.annotation.*;
import java.net.*; import java.net.*;
import java.nio.ByteBuffer; import java.nio.*;
import java.nio.charset.*; import java.nio.charset.*;
import java.util.*; import java.util.*;
import java.util.function.Supplier; import java.util.function.*;
import java.util.logging.Level; import java.util.logging.*;
import org.redkale.annotation.Comment; import org.redkale.annotation.Comment;
import org.redkale.convert.*; import org.redkale.convert.*;
import org.redkale.convert.json.JsonConvert; import org.redkale.convert.json.*;
import org.redkale.net.Request; import org.redkale.net.*;
import org.redkale.util.*; import org.redkale.util.*;
/** /**
@@ -322,7 +322,7 @@ public class HttpRequest extends Request<HttpContext> {
this.respConvertType = httplast.respConvertType; this.respConvertType = httplast.respConvertType;
this.respConvert = httplast.respConvert; this.respConvert = httplast.respConvert;
this.headerLength = httplast.headerLength; this.headerLength = httplast.headerLength;
this.headerHalfLen = httplast.headerLength; this.headerHalfLen = httplast.headerHalfLen;
this.headerBytes = httplast.headerBytes; this.headerBytes = httplast.headerBytes;
this.headerParsed = httplast.headerParsed; this.headerParsed = httplast.headerParsed;
this.headers.putAll(httplast.headers); this.headers.putAll(httplast.headers);
@@ -448,12 +448,6 @@ public class HttpRequest extends Request<HttpContext> {
} }
} }
// @Override
// protected int readBody(ByteBuffer buffer, int length) {
// int len = buffer.remaining();
// array.put(buffer, len);
// return len;
// }
//解析 GET /xxx HTTP/1.1 //解析 GET /xxx HTTP/1.1
private int readMethodLine(final ByteBuffer buf) { private int readMethodLine(final ByteBuffer buf) {
final ByteBuffer buffer = buf; final ByteBuffer buffer = buf;
@@ -1438,12 +1432,18 @@ public class HttpRequest extends Request<HttpContext> {
+ (this.frombody ? (", \r\n frombody: " + this.frombody) : "") + (this.frombody ? (", \r\n frombody: " + this.frombody) : "")
+ (this.reqConvertType != null ? (", \r\n reqConvertType: " + this.reqConvertType) : "") + (this.reqConvertType != null ? (", \r\n reqConvertType: " + this.reqConvertType) : "")
+ (this.respConvertType != null ? (", \r\n respConvertType: " + this.respConvertType) : "") + (this.respConvertType != null ? (", \r\n respConvertType: " + this.respConvertType) : "")
+ ", \r\n currentUserid: " + (this.currentUserid == CURRUSERID_NIL ? null : this.currentUserid) + ", \r\n remoteAddr: " + this.getRemoteAddr() + (this.currentUserid != CURRUSERID_NIL ? (", \r\n currentUserid: " + (this.currentUserid == CURRUSERID_NIL ? null : this.currentUserid)) : "")
+ ", \r\n cookies: " + this.cookie + ", \r\n contentType: " + this.contentType + (this.getRemoteAddr() != null ? (", \r\n remoteAddr: " + this.getRemoteAddr()) : "")
+ ", \r\n protocol: " + this.protocol + ", \r\n host: " + this.host + (this.cookie != null ? (", \r\n cookies: " + this.cookie) : "")
+ ", \r\n contentLength: " + this.contentLength + ", \r\n bodyLength: " + this.array.length() + (this.contentType != null ? (", \r\n contentType: " + this.contentType) : "")
+ (this.protocol != null ? (", \r\n protocol: " + this.protocol) : "")
+ (this.host != null ? (", \r\n host: " + this.host) : "")
+ (this.contentLength >= 0 ? (", \r\n contentLength: " + this.contentLength) : "")
+ (this.array.length() > 0 ? (", \r\n bodyLength: " + this.array.length()) : "")
+ (this.boundary || this.array.isEmpty() ? "" : (", \r\n bodyContent: " + (this.respConvertType == null || this.respConvertType == ConvertType.JSON ? this.getBodyUTF8() : Arrays.toString(getBody())))) + (this.boundary || this.array.isEmpty() ? "" : (", \r\n bodyContent: " + (this.respConvertType == null || this.respConvertType == ConvertType.JSON ? this.getBodyUTF8() : Arrays.toString(getBody()))))
+ ", \r\n params: " + toMapString(this.params, 4) + ", \r\n header: " + toMapString(this.headers, 4) + "\r\n}"; //this.headers.toString(4) + ", \r\n params: " + toMapString(this.params, 4)
+ ", \r\n header: " + toMapString(this.headers, 4)
+ "\r\n}"; //this.headers.toString(4)
} }
private static CharSequence toMapString(Map<String, String> map, int indent) { private static CharSequence toMapString(Map<String, String> map, int indent) {

View File

@@ -5,24 +5,24 @@
*/ */
package org.redkale.net.http; package org.redkale.net.http;
import java.lang.reflect.Field; import java.lang.reflect.*;
import java.net.HttpCookie; import java.net.*;
import java.text.*; import java.text.*;
import java.time.ZoneId; import java.time.*;
import static java.time.format.DateTimeFormatter.RFC_1123_DATE_TIME; import static java.time.format.DateTimeFormatter.RFC_1123_DATE_TIME;
import java.util.*; import java.util.*;
import java.util.concurrent.*; import java.util.concurrent.*;
import java.util.concurrent.atomic.LongAdder; import java.util.concurrent.atomic.*;
import java.util.concurrent.locks.ReentrantLock; import java.util.concurrent.locks.*;
import java.util.function.Supplier; import java.util.function.*;
import java.util.logging.Level; import java.util.logging.*;
import org.redkale.boot.Application; import org.redkale.boot.*;
import org.redkale.mq.*; import org.redkale.mq.*;
import org.redkale.net.Server; import org.redkale.net.*;
import org.redkale.net.http.HttpContext.HttpContextConfig; import org.redkale.net.http.HttpContext.HttpContextConfig;
import org.redkale.net.http.HttpResponse.HttpResponseConfig; import org.redkale.net.http.HttpResponse.HttpResponseConfig;
import org.redkale.net.sncp.Sncp; import org.redkale.net.sncp.*;
import org.redkale.service.Service; import org.redkale.service.*;
import org.redkale.util.*; import org.redkale.util.*;
/** /**
@@ -90,6 +90,11 @@ public class HttpServer extends Server<String, HttpContext, HttpRequest, HttpRes
if (context.rpcAuthenticator != null) { if (context.rpcAuthenticator != null) {
context.rpcAuthenticator.destroy(context.rpcAuthenticatorConfig); context.rpcAuthenticator.destroy(context.rpcAuthenticatorConfig);
} }
HttpResponseConfig respConf = this.respConfig;
HttpRender httpRender = respConf.httpRender;
if (httpRender != null) {
httpRender.destroy(context, respConf.renderConfig);
}
} }
public List<HttpServlet> getHttpServlets() { public List<HttpServlet> getHttpServlets() {

View File

@@ -5,18 +5,18 @@
*/ */
package org.redkale.net.http; package org.redkale.net.http;
import java.io.IOException; import java.io.*;
import java.lang.annotation.Annotation; import java.lang.annotation.*;
import java.lang.reflect.*; import java.lang.reflect.*;
import java.util.*; import java.util.*;
import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.*;
import java.util.function.BiConsumer; import java.util.function.*;
import java.util.logging.Level; import java.util.logging.*;
import org.redkale.annotation.NonBlocking; import org.redkale.annotation.*;
import static org.redkale.asm.ClassWriter.COMPUTE_FRAMES; import static org.redkale.asm.ClassWriter.COMPUTE_FRAMES;
import org.redkale.asm.*; import org.redkale.asm.*;
import static org.redkale.asm.Opcodes.*; import static org.redkale.asm.Opcodes.*;
import org.redkale.boot.Application; import org.redkale.boot.*;
import org.redkale.net.*; import org.redkale.net.*;
import org.redkale.util.*; import org.redkale.util.*;
@@ -36,7 +36,7 @@ public class HttpServlet extends Servlet<HttpContext, HttpRequest, HttpResponse>
//@Deprecated(since = "2.8.0") //@Deprecated(since = "2.8.0")
//public static final int RET_METHOD_ERROR = 1200_0002; //public static final int RET_METHOD_ERROR = 1200_0002;
// //
String _actionSimpleMappingUrl; //只给HttpActionServlet使用_actionSimpleMappingUrl不能包含正则表达式比如 /json /createRecord, 不能是 /user/** String _actionSimpleMappingUrl; //只给HttpActionServlet使用_actionSimpleMappingUrl不能包含正则表达式比如: /json/createRecord, 不能是/user/**
String _prefix = ""; //当前HttpServlet的path前缀 String _prefix = ""; //当前HttpServlet的path前缀
@@ -269,7 +269,7 @@ public class HttpServlet extends Servlet<HttpContext, HttpRequest, HttpResponse>
preExecute(request, response); preExecute(request, response);
} }
static Boolean isNonBlocking(Class<?> servletClass) { static Boolean isNonBlocking(Class<? extends HttpServlet> servletClass) {
Class clz = servletClass; Class clz = servletClass;
Boolean preNonBlocking = null; Boolean preNonBlocking = null;
Boolean authNonBlocking = null; Boolean authNonBlocking = null;

View File

@@ -6,11 +6,11 @@
package org.redkale.net.http; package org.redkale.net.http;
import java.net.*; import java.net.*;
import java.nio.ByteBuffer; import java.nio.*;
import java.nio.channels.CompletionHandler; import java.nio.channels.*;
import java.nio.charset.StandardCharsets; import java.nio.charset.*;
import java.util.Map; import java.util.*;
import java.util.concurrent.CompletableFuture; import java.util.concurrent.*;
import org.redkale.net.*; import org.redkale.net.*;
import static org.redkale.net.http.HttpRequest.parseHeaderName; import static org.redkale.net.http.HttpRequest.parseHeaderName;
import org.redkale.util.*; import org.redkale.util.*;
@@ -20,7 +20,7 @@ import org.redkale.util.*;
* 1、使用HTTPS<br> * 1、使用HTTPS<br>
* 2、上传下载文件<br> * 2、上传下载文件<br>
* 3、返回超大响应包<br> * 3、返回超大响应包<br>
* 类似JDK11的 java.net.http.HttpSimpleClient <br> * 类似JDK11的 java.net.http.HttpClient <br>
* *
* <p> * <p>
* 详情见: https://redkale.org * 详情见: https://redkale.org

View File

@@ -6,9 +6,9 @@
package org.redkale.service; package org.redkale.service;
import java.util.concurrent.*; import java.util.concurrent.*;
import org.redkale.annotation.Resource; import org.redkale.annotation.*;
import org.redkale.boot.Application; import org.redkale.boot.*;
import org.redkale.net.WorkThread; import org.redkale.net.*;
import org.redkale.util.*; import org.redkale.util.*;
/** /**
@@ -31,11 +31,6 @@ public abstract class AbstractService implements Service {
return serviceName; return serviceName;
} }
/**
* 当前Service类的原始Service类型 由于Service会动态重载所以getClass()得到的不是原始Service类型
*
* @return Class
*/
protected Class serviceType() { protected Class serviceType() {
return serviceType; return serviceType;
} }