debug
This commit is contained in:
parent
0e6c0c0395
commit
a62ca0125d
@ -104,4 +104,10 @@ public class SpiderContext extends HashMap<String, Object>{
|
||||
return cookieContext;
|
||||
}
|
||||
|
||||
public void pause(String nodeId,String event,String key,Object value){}
|
||||
|
||||
public void resume(){}
|
||||
|
||||
public void stop(){}
|
||||
|
||||
}
|
||||
|
@ -192,7 +192,7 @@ public class Spider {
|
||||
return;
|
||||
}
|
||||
//判断箭头上的条件,如果不成立则不执行
|
||||
if (!executeCondition(fromNode, node, variables)) {
|
||||
if (!executeCondition(fromNode, node, variables, context)) {
|
||||
return;
|
||||
}
|
||||
logger.debug("执行节点[{}:{}]", node.getNodeName(), node.getNodeId());
|
||||
@ -270,7 +270,7 @@ public class Spider {
|
||||
/**
|
||||
* 判断箭头上的表达式是否成立
|
||||
*/
|
||||
private boolean executeCondition(SpiderNode fromNode, SpiderNode node, Map<String, Object> variables) {
|
||||
private boolean executeCondition(SpiderNode fromNode, SpiderNode node, Map<String, Object> variables, SpiderContext context) {
|
||||
if (fromNode != null) {
|
||||
boolean hasException = variables.get("ex") != null;
|
||||
String exceptionFlow = node.getExceptionFlow(fromNode.getNodeId());
|
||||
|
@ -73,6 +73,7 @@ public class ExecuteSQLExecutor implements ShapeExecutor, Grammerable {
|
||||
return;
|
||||
}
|
||||
sql = sqlObject.toString();
|
||||
context.pause(node.getNodeId(),"common",SQL,sql);
|
||||
} catch (Exception e) {
|
||||
logger.error("获取sql出错,异常信息:{}", e.getMessage(), e);
|
||||
ExceptionUtils.wrapAndThrow(e);
|
||||
@ -93,7 +94,6 @@ public class ExecuteSQLExecutor implements ShapeExecutor, Grammerable {
|
||||
parameterSize = Math.max(parameterSize, Array.getLength(parameter));
|
||||
}
|
||||
}
|
||||
|
||||
params[i] = parameter;
|
||||
}
|
||||
String statementType = node.getStringJsonValue(STATEMENT_TYPE);
|
||||
|
@ -75,6 +75,7 @@ public class OutputExecutor implements ShapeExecutor{
|
||||
String outputName = item.get(OUTPUT_NAME);
|
||||
try {
|
||||
value = ExpressionUtils.execute(outputValue, variables);
|
||||
context.pause(node.getNodeId(),"common",outputName,value);
|
||||
logger.debug("输出{}={}", outputName,value);
|
||||
} catch (Exception e) {
|
||||
logger.error("输出{}出错,异常信息:{}", outputName,e);
|
||||
|
@ -107,6 +107,7 @@ public class RequestExecutor implements ShapeExecutor,Grammerable{
|
||||
sleepTime = lastExecuteTime + sleepTime - System.currentTimeMillis();
|
||||
}
|
||||
if (sleepTime > 0) {
|
||||
context.pause(node.getNodeId(),"common",SLEEP,sleepTime);
|
||||
logger.debug("设置延迟时间:{}ms", sleepTime);
|
||||
Thread.sleep(sleepTime);
|
||||
}
|
||||
@ -126,6 +127,7 @@ public class RequestExecutor implements ShapeExecutor,Grammerable{
|
||||
logger.error("设置请求url出错,异常信息:{}", e);
|
||||
ExceptionUtils.wrapAndThrow(e);
|
||||
}
|
||||
context.pause(node.getNodeId(),"common",URL,url);
|
||||
logger.info("设置请求url:{}", url);
|
||||
request.url(url);
|
||||
//设置请求超时时间
|
||||
@ -150,11 +152,11 @@ public class RequestExecutor implements ShapeExecutor,Grammerable{
|
||||
}
|
||||
SpiderNode root = context.getRootNode();
|
||||
//设置请求header
|
||||
setRequestHeader(request, root.getListJsonValue(HEADER_NAME,HEADER_VALUE), context, variables);
|
||||
setRequestHeader(request, node.getListJsonValue(HEADER_NAME,HEADER_VALUE), context, variables);
|
||||
setRequestHeader(root, request, root.getListJsonValue(HEADER_NAME,HEADER_VALUE), context, variables);
|
||||
setRequestHeader(node, request, node.getListJsonValue(HEADER_NAME,HEADER_VALUE), context, variables);
|
||||
|
||||
//设置全局Cookie
|
||||
Map<String, String> cookies = getRequestCookie(request, root.getListJsonValue(COOKIE_NAME, COOKIE_VALUE), context, variables);
|
||||
Map<String, String> cookies = getRequestCookie(root, root.getListJsonValue(COOKIE_NAME, COOKIE_VALUE), context, variables);
|
||||
if(!cookies.isEmpty()){
|
||||
logger.info("设置全局Cookie:{}", cookies);
|
||||
request.cookies(cookies);
|
||||
@ -162,23 +164,15 @@ public class RequestExecutor implements ShapeExecutor,Grammerable{
|
||||
//设置自动管理的Cookie
|
||||
boolean cookieAutoSet = !"0".equals(node.getStringJsonValue(COOKIE_AUTO_SET));
|
||||
if(cookieAutoSet && !cookieContext.isEmpty()){
|
||||
context.pause(node.getNodeId(),COOKIE_AUTO_SET,COOKIE_AUTO_SET,cookieContext);
|
||||
request.cookies(cookieContext);
|
||||
logger.info("自动设置Cookie:{}", cookieContext);
|
||||
}
|
||||
//设置本节点Cookie
|
||||
cookies = getRequestCookie(request, node.getListJsonValue(COOKIE_NAME, COOKIE_VALUE), context, variables);
|
||||
cookies = getRequestCookie(node, node.getListJsonValue(COOKIE_NAME, COOKIE_VALUE), context, variables);
|
||||
if(!cookies.isEmpty()){
|
||||
cookies.entrySet().forEach(entry->{
|
||||
try {
|
||||
Object value = ExpressionUtils.execute(entry.getValue(), variables);
|
||||
entry.setValue(Objects.toString(value));
|
||||
} catch (Exception e) {
|
||||
logger.error("设置Cookie出错:{}",e);
|
||||
}
|
||||
|
||||
});
|
||||
logger.debug("设置Cookie:{}", cookies);
|
||||
request.cookies(cookies);
|
||||
logger.debug("设置Cookie:{}", cookies);
|
||||
}
|
||||
if(cookieAutoSet){
|
||||
cookieContext.putAll(cookies);
|
||||
@ -191,6 +185,7 @@ public class RequestExecutor implements ShapeExecutor,Grammerable{
|
||||
request.contentType(contentType);
|
||||
try {
|
||||
Object requestBody = ExpressionUtils.execute(node.getStringJsonValue(REQUEST_BODY), variables);
|
||||
context.pause(node.getNodeId(),"request-body",REQUEST_BODY,requestBody);
|
||||
request.data(requestBody);
|
||||
logger.info("设置请求Body:{}", requestBody);
|
||||
} catch (Exception e) {
|
||||
@ -198,17 +193,18 @@ public class RequestExecutor implements ShapeExecutor,Grammerable{
|
||||
}
|
||||
}else if("form-data".equals(bodyType)){
|
||||
List<Map<String, String>> formParameters = node.getListJsonValue(PARAMETER_FORM_NAME,PARAMETER_FORM_VALUE,PARAMETER_FORM_TYPE,PARAMETER_FORM_FILENAME);
|
||||
streams = setRequestFormParameter(request,formParameters,context,variables);
|
||||
streams = setRequestFormParameter(node,request,formParameters,context,variables);
|
||||
}else{
|
||||
//设置请求参数
|
||||
setRequestParameter(request,root.getListJsonValue(PARAMETER_NAME,PARAMETER_VALUE), context, variables);
|
||||
setRequestParameter(request,node.getListJsonValue(PARAMETER_NAME,PARAMETER_VALUE),context,variables);
|
||||
setRequestParameter(root, request, root.getListJsonValue(PARAMETER_NAME,PARAMETER_VALUE), context, variables);
|
||||
setRequestParameter(node, request, node.getListJsonValue(PARAMETER_NAME,PARAMETER_VALUE), context, variables);
|
||||
}
|
||||
//设置代理
|
||||
String proxy = node.getStringJsonValue(PROXY);
|
||||
if(proxy != null){
|
||||
if(StringUtils.isNotBlank(proxy)){
|
||||
try {
|
||||
Object value = ExpressionUtils.execute(proxy, variables);
|
||||
context.pause(node.getNodeId(),"common",PROXY,value);
|
||||
if(value != null){
|
||||
String[] proxyArr = value.toString().split(":");
|
||||
if(proxyArr.length == 2){
|
||||
@ -246,11 +242,11 @@ public class RequestExecutor implements ShapeExecutor,Grammerable{
|
||||
}
|
||||
}
|
||||
|
||||
private List<InputStream> setRequestFormParameter(HttpRequest request,List<Map<String, String>> parameters,SpiderContext context,Map<String,Object> variables){
|
||||
private List<InputStream> setRequestFormParameter(SpiderNode node, HttpRequest request,List<Map<String, String>> parameters,SpiderContext context,Map<String,Object> variables){
|
||||
List<InputStream> streams = new ArrayList<>();
|
||||
if(parameters != null){
|
||||
for (Map<String,String> nameValue : parameters) {
|
||||
Object value = null;
|
||||
Object value;
|
||||
String parameterName = nameValue.get(PARAMETER_FORM_NAME);
|
||||
if(StringUtils.isNotBlank(parameterName)){
|
||||
String parameterValue = nameValue.get(PARAMETER_FORM_VALUE);
|
||||
@ -271,12 +267,14 @@ public class RequestExecutor implements ShapeExecutor,Grammerable{
|
||||
if(stream != null){
|
||||
streams.add(stream);
|
||||
request.data(parameterName, parameterFilename, stream);
|
||||
context.pause(node.getNodeId(),"request-body",parameterName,parameterFilename);
|
||||
logger.info("设置请求参数:{}={}",parameterName,parameterFilename);
|
||||
}else{
|
||||
logger.warn("设置请求参数:{}失败,无二进制内容",parameterName);
|
||||
}
|
||||
}else{
|
||||
request.data(parameterName, value);
|
||||
context.pause(node.getNodeId(),"request-body",parameterName,value);
|
||||
logger.info("设置请求参数:{}={}",parameterName,value);
|
||||
}
|
||||
|
||||
@ -289,18 +287,19 @@ public class RequestExecutor implements ShapeExecutor,Grammerable{
|
||||
return streams;
|
||||
}
|
||||
|
||||
private Map<String,String> getRequestCookie(HttpRequest request, List<Map<String, String>> cookies, SpiderContext context, Map<String, Object> variables) {
|
||||
private Map<String,String> getRequestCookie(SpiderNode node, List<Map<String, String>> cookies, SpiderContext context, Map<String, Object> variables) {
|
||||
Map<String,String> cookieMap = new HashMap<>();
|
||||
if (cookies != null) {
|
||||
for (Map<String, String> nameValue : cookies) {
|
||||
Object value = null;
|
||||
Object value;
|
||||
String cookieName = nameValue.get(COOKIE_NAME);
|
||||
if (StringUtils.isNotBlank(cookieName)) {
|
||||
String cookieValue = nameValue.get(COOKIE_VALUE);
|
||||
try {
|
||||
value = ExpressionUtils.execute(cookieValue, variables);
|
||||
if (value != null) {
|
||||
cookieMap.put(cookieName, cookieValue);
|
||||
cookieMap.put(cookieName, value.toString());
|
||||
context.pause(node.getNodeId(),"request-cookie",cookieName,value.toString());
|
||||
logger.info("设置请求Cookie:{}={}", cookieName, value);
|
||||
}
|
||||
} catch (Exception e) {
|
||||
@ -312,7 +311,7 @@ public class RequestExecutor implements ShapeExecutor,Grammerable{
|
||||
return cookieMap;
|
||||
}
|
||||
|
||||
private void setRequestParameter(HttpRequest request, List<Map<String, String>> parameters, SpiderContext context, Map<String, Object> variables) {
|
||||
private void setRequestParameter(SpiderNode node, HttpRequest request, List<Map<String, String>> parameters, SpiderContext context, Map<String, Object> variables) {
|
||||
if (parameters != null) {
|
||||
for (Map<String, String> nameValue : parameters) {
|
||||
Object value = null;
|
||||
@ -321,6 +320,7 @@ public class RequestExecutor implements ShapeExecutor,Grammerable{
|
||||
String parameterValue = nameValue.get(PARAMETER_VALUE);
|
||||
try {
|
||||
value = ExpressionUtils.execute(parameterValue, variables);
|
||||
context.pause(node.getNodeId(),"request-parameter",parameterName,value);
|
||||
logger.info("设置请求参数:{}={}", parameterName, value);
|
||||
} catch (Exception e) {
|
||||
logger.error("设置请求参数:{}出错,异常信息:{}", parameterName, e);
|
||||
@ -331,7 +331,7 @@ public class RequestExecutor implements ShapeExecutor,Grammerable{
|
||||
}
|
||||
}
|
||||
|
||||
private void setRequestHeader(HttpRequest request, List<Map<String, String>> headers, SpiderContext context, Map<String, Object> variables) {
|
||||
private void setRequestHeader(SpiderNode node,HttpRequest request, List<Map<String, String>> headers, SpiderContext context, Map<String, Object> variables) {
|
||||
if (headers != null) {
|
||||
for (Map<String, String> nameValue : headers) {
|
||||
Object value = null;
|
||||
@ -340,6 +340,7 @@ public class RequestExecutor implements ShapeExecutor,Grammerable{
|
||||
String headerValue = nameValue.get(HEADER_VALUE);
|
||||
try {
|
||||
value = ExpressionUtils.execute(headerValue, variables);
|
||||
context.pause(node.getNodeId(),"request-header",headerName,value);
|
||||
logger.info("设置请求Header:{}={}", headerName, value);
|
||||
} catch (Exception e) {
|
||||
logger.error("设置请求Header:{}出错,异常信息:{}", headerName, e);
|
||||
|
@ -36,6 +36,7 @@ public class VariableExecutor implements ShapeExecutor{
|
||||
try {
|
||||
value = ExpressionUtils.execute(variableValue, variables);
|
||||
logger.debug("设置变量{}={}",variableName,value);
|
||||
context.pause(node.getNodeId(),"common",variableName,value);
|
||||
} catch (Exception e) {
|
||||
logger.error("设置变量{}出错,异常信息:{}",variableName,e);
|
||||
ExceptionUtils.wrapAndThrow(e);
|
||||
|
@ -19,10 +19,22 @@ public class SpiderWebSocketContext extends SpiderContext {
|
||||
|
||||
private Session session;
|
||||
|
||||
private boolean debug;
|
||||
|
||||
private Object lock = new Object();
|
||||
|
||||
public SpiderWebSocketContext(Session session) {
|
||||
this.session = session;
|
||||
}
|
||||
|
||||
public boolean isDebug() {
|
||||
return debug;
|
||||
}
|
||||
|
||||
public void setDebug(boolean debug) {
|
||||
this.debug = debug;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void addOutput(SpiderOutput output) {
|
||||
super.addOutput(output);
|
||||
@ -44,4 +56,89 @@ public class SpiderWebSocketContext extends SpiderContext {
|
||||
} catch (Throwable ignored) {
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void pause(String nodeId, String event, String key, Object value) {
|
||||
if(this.debug && this.isRunning()) {
|
||||
synchronized (this) {
|
||||
if(this.debug && this.isRunning()) {
|
||||
synchronized (lock) {
|
||||
try {
|
||||
write(new WebSocketEvent<>("debug", new DebugInfo(nodeId, event, key, value)));
|
||||
lock.wait();
|
||||
} catch (InterruptedException ignored) {
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void resume() {
|
||||
if(this.debug){
|
||||
synchronized (lock){
|
||||
lock.notify();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void stop() {
|
||||
if(this.debug){
|
||||
synchronized (lock){
|
||||
lock.notifyAll();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
class DebugInfo{
|
||||
|
||||
private String nodeId;
|
||||
|
||||
private String event;
|
||||
|
||||
private String key;
|
||||
|
||||
private Object value;
|
||||
|
||||
public DebugInfo(String nodeId, String event, String key, Object value) {
|
||||
this.nodeId = nodeId;
|
||||
this.event = event;
|
||||
this.key = key;
|
||||
this.value = value;
|
||||
}
|
||||
|
||||
public String getNodeId() {
|
||||
return nodeId;
|
||||
}
|
||||
|
||||
public void setNodeId(String nodeId) {
|
||||
this.nodeId = nodeId;
|
||||
}
|
||||
|
||||
public String getEvent() {
|
||||
return event;
|
||||
}
|
||||
|
||||
public void setEvent(String event) {
|
||||
this.event = event;
|
||||
}
|
||||
|
||||
public String getKey() {
|
||||
return key;
|
||||
}
|
||||
|
||||
public void setKey(String key) {
|
||||
this.key = key;
|
||||
}
|
||||
|
||||
public Object getValue() {
|
||||
return value;
|
||||
}
|
||||
|
||||
public void setValue(Object value) {
|
||||
this.value = value;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -30,8 +30,10 @@ public class WebSocketEditorServer {
|
||||
public void onMessage(String message, Session session) {
|
||||
JSONObject event = JSON.parseObject(message);
|
||||
String eventType = event.getString("eventType");
|
||||
if ("test".equals(eventType)) {
|
||||
boolean isDebug = "debug".equalsIgnoreCase(eventType);
|
||||
if ("test".equalsIgnoreCase(eventType) || isDebug) {
|
||||
context = new SpiderWebSocketContext(session);
|
||||
context.setDebug(isDebug);
|
||||
context.setRunning(true);
|
||||
new Thread(() -> {
|
||||
String xml = event.getString("message");
|
||||
@ -45,12 +47,15 @@ public class WebSocketEditorServer {
|
||||
}).start();
|
||||
} else if ("stop".equals(eventType) && context != null) {
|
||||
context.setRunning(false);
|
||||
context.stop();
|
||||
} else if("resume".equalsIgnoreCase(eventType) && context != null){
|
||||
context.resume();
|
||||
}
|
||||
}
|
||||
|
||||
@OnClose
|
||||
public void onClose(Session session) {
|
||||
context.setRunning(false);
|
||||
context.stop();
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -20,7 +20,7 @@ html,body{
|
||||
width : 46px;
|
||||
left : 0px;
|
||||
top : 30px;
|
||||
bottom:300px;
|
||||
bottom:200px;
|
||||
max-height: 100%;
|
||||
overflow: auto;
|
||||
background: #F6F6F6;
|
||||
@ -59,7 +59,7 @@ html,body{
|
||||
.main-container .resize-container{
|
||||
cursor: n-resize;
|
||||
position: absolute;
|
||||
bottom : 290px;
|
||||
bottom : 190px;
|
||||
width : 100%;
|
||||
height : 20px;
|
||||
background: transparent;
|
||||
@ -69,7 +69,7 @@ html,body{
|
||||
left : 38px;
|
||||
width : 100%;
|
||||
top : 30px;
|
||||
bottom : 300px;
|
||||
bottom : 200px;
|
||||
background-image: linear-gradient(90deg, rgba(153, 153, 153, 0.3) 1px, rgba(0, 0, 0, 0) 1px),linear-gradient(rgba(153, 153, 153, 0.3) 1px, rgba(0, 0, 0, 0) 1px);
|
||||
background-size: 8px 8px;
|
||||
overflow: auto;
|
||||
@ -78,7 +78,7 @@ html,body{
|
||||
position: absolute;
|
||||
width : 100%;
|
||||
bottom : 0px;
|
||||
height : 300px;
|
||||
height : 200px;
|
||||
box-shadow: -2px 1px 3px #eee;
|
||||
overflow: auto;
|
||||
}
|
||||
@ -237,7 +237,7 @@ html,body{
|
||||
white-space: nowrap;
|
||||
}
|
||||
#test-window{
|
||||
padding:0px 10px;
|
||||
padding:0px 0px;
|
||||
overflow: hidden;
|
||||
}
|
||||
.layui-layer.codemirror .layui-input-block{
|
||||
@ -267,13 +267,134 @@ html,body{
|
||||
word-break: break-all;
|
||||
}
|
||||
|
||||
|
||||
.toolbar-container ul li {
|
||||
background-repeat: no-repeat;
|
||||
background-size: 18px 18px;
|
||||
background-position: center center;
|
||||
width: 20px;
|
||||
height: 20px;
|
||||
padding : 0 4px;
|
||||
}
|
||||
.toolbar-container ul li.btn-save{
|
||||
background-image : url("");
|
||||
}
|
||||
.toolbar-container ul li.btn-return{
|
||||
background-image : url("");
|
||||
}
|
||||
.toolbar-container ul li.btn-selectAll{
|
||||
background-image : url("");
|
||||
}
|
||||
.toolbar-container ul li.btn-console-xml{
|
||||
background-image : url("");
|
||||
}
|
||||
.toolbar-container ul li.btn-graphical-xml{
|
||||
background-image : url("");
|
||||
}
|
||||
.toolbar-container ul li.btn-edit-xml{
|
||||
background-image : url("");
|
||||
}
|
||||
.toolbar-container ul li.btn-copy{
|
||||
background-image : url("");
|
||||
}
|
||||
.toolbar-container ul li.btn-paste{
|
||||
background-image : url("");
|
||||
}
|
||||
.toolbar-container ul li.btn-delete{
|
||||
background-image : url("");
|
||||
}
|
||||
.toolbar-container ul li.btn-cut{
|
||||
background-image : url("");
|
||||
}
|
||||
.toolbar-container ul li.btn-undo{
|
||||
background-image : url("");
|
||||
}
|
||||
.toolbar-container ul li.btn-redo{
|
||||
background-image : url("");
|
||||
}
|
||||
.toolbar-container ul li.btn-debug{
|
||||
background-image : url("");
|
||||
}
|
||||
.toolbar-container ul li.btn-debug.disabled{
|
||||
background-image : url("");
|
||||
}
|
||||
.toolbar-container ul li.btn-stop{
|
||||
background-image : url("");
|
||||
}
|
||||
.toolbar-container ul li.btn-stop.disabled{
|
||||
background-image : url("");
|
||||
}
|
||||
.toolbar-container ul li.btn-test{
|
||||
background-image : url("");
|
||||
}
|
||||
.toolbar-container ul li.btn-test.disabled{
|
||||
background-image : url("");
|
||||
}
|
||||
.toolbar-container ul li.btn-resume{
|
||||
background-image : url("");
|
||||
}
|
||||
.toolbar-container ul li.btn-resume.disabled{
|
||||
background-image : url("");
|
||||
}
|
||||
.spiderflow-debug-tooltip{
|
||||
position: absolute;
|
||||
z-index: 2147483647;
|
||||
background: #fefefe;
|
||||
border-radius: 2px;
|
||||
padding: 5px;
|
||||
border: 1px solid #eee;
|
||||
box-shadow : 2px 0px 5px 1px rgba(0, 0, 0, 0.6)
|
||||
}
|
||||
.spiderflow-debug-tooltip .content{
|
||||
max-height: 500px;
|
||||
overflow: auto;
|
||||
max-width: 500px;
|
||||
}
|
||||
.spiderflow-debug-tooltip .content::-webkit-scrollbar {
|
||||
width: 5px;
|
||||
height: 5px;
|
||||
}
|
||||
.spiderflow-debug-tooltip .content::-webkit-scrollbar-track {
|
||||
background-color:#ccc;
|
||||
-webkit-border-radius: 2em;
|
||||
-moz-border-radius: 2em;
|
||||
border-radius:2em;
|
||||
}
|
||||
.spiderflow-debug-tooltip .content::-webkit-scrollbar-thumb {
|
||||
background-color:#999;
|
||||
-webkit-border-radius: 2em;
|
||||
-moz-border-radius: 2em;
|
||||
border-radius:2em;
|
||||
}
|
||||
.spiderflow-debug-tooltip::before{
|
||||
content: ' ';
|
||||
width: 0px;
|
||||
height: 0px;
|
||||
position: absolute;
|
||||
bottom: -17px;
|
||||
left: 50%;
|
||||
border-width: 8px;
|
||||
border-style: solid;
|
||||
border-color: #eee transparent transparent transparent;
|
||||
margin-left: -4px;
|
||||
}
|
||||
.spiderflow-debug-tooltip::after{
|
||||
content: ' ';
|
||||
width: 0px;
|
||||
height: 0px;
|
||||
position: absolute;
|
||||
bottom: -16px;
|
||||
left: 50%;
|
||||
border-width: 8px;
|
||||
border-style: solid;
|
||||
border-color: #fefefe transparent transparent transparent;
|
||||
margin-left: -4px;
|
||||
}
|
||||
|
||||
/*样式调整*/
|
||||
.properties-container .editor-form-node input, .properties-container .editor-form-node textarea{
|
||||
font-size : 12px;
|
||||
}
|
||||
.layui-input, .layui-select, .layui-textarea{
|
||||
.properties-container .editor-form-node .layui-input,.properties-container .editor-form-node .layui-select,.properties-container .editor-form-node .layui-textarea{
|
||||
height : 24px;
|
||||
}
|
||||
.layui-form-label{
|
||||
@ -356,4 +477,45 @@ html,body{
|
||||
}
|
||||
.properties-container .layui-form-item .layui-input-inline{
|
||||
width : auto;
|
||||
}
|
||||
|
||||
.layer-test .layui-layer-title{
|
||||
height: 24px;
|
||||
line-height: 24px;
|
||||
}
|
||||
.layer-test .layui-layer-setwin{
|
||||
top : 6px;
|
||||
}
|
||||
.layer-test .layui-tab{
|
||||
margin : 0px;
|
||||
}
|
||||
.layer-test .layui-tab-content{
|
||||
padding : 2px;
|
||||
}
|
||||
.layer-test .layui-layer-btn{
|
||||
padding-top:2px !important;
|
||||
margin-top:-5px;
|
||||
}
|
||||
.layer-test .layui-layer-btn .layui-inline{
|
||||
margin-top:5px;
|
||||
}
|
||||
.layer-test .layui-layer-btn .layui-inline input{
|
||||
font-size:12px;
|
||||
height : 26px;
|
||||
}
|
||||
.layer-test .layui-layer-btn a{
|
||||
height: 24px;
|
||||
line-height: 24px;
|
||||
margin: 5px 5px 0;
|
||||
padding: 0px 10px;
|
||||
font-size:12px;
|
||||
}
|
||||
.layer-test .layui-layer-max{
|
||||
display: none;
|
||||
}
|
||||
.layer-test .layui-layer-max.layui-layer-maxmin{
|
||||
display: inline-block;
|
||||
}
|
||||
#test-window{
|
||||
height:340px !important;
|
||||
}
|
@ -1,6 +1,6 @@
|
||||
.layui-body .layui-tab{margin:0px;height:100%;}
|
||||
.layui-body .layui-tab .layui-tab-content{position: absolute;top: 40px;bottom: 0px;width: 100%;padding:0px;overflow: hidden;}
|
||||
.layui-body .layui-tab .layui-tab-content .layui-tab-item{height:100%;width:calc(100% - 48px);}
|
||||
.layui-body .layui-tab .layui-tab-content .layui-tab-item{height:100%;}
|
||||
/***********************/
|
||||
|
||||
.layui-layout-admin .layui-search-menu{
|
||||
|
@ -102,10 +102,8 @@ iframe{
|
||||
color:rgba(0, 0, 0, 0.65);
|
||||
}
|
||||
.layui-body .layui-tab .layui-tab-content{
|
||||
top:64px !important;
|
||||
left:24px;
|
||||
right:24px;
|
||||
bottom:24px !important;
|
||||
top:41px !important;
|
||||
left:1px;
|
||||
}
|
||||
.layui-layout-admin .layui-body,.layui-layout-admin .layui-footer{
|
||||
background-color: #f0f2f5;
|
||||
|
@ -29,19 +29,21 @@
|
||||
<div class="main-container">
|
||||
<div class="toolbar-container">
|
||||
<ul>
|
||||
<li class="btn-return">返回</li>
|
||||
<li class="btn-selectAll" title="Ctrl+A">全选</li>
|
||||
<li class="btn-save" title="Ctrl+S">保存</li>
|
||||
<li class="btn-test" title="Ctrl+Q">测试</li>
|
||||
<li class="btn-console-xml">打印XML</li>
|
||||
<li class="btn-edit-xml">XML编辑</li>
|
||||
<li class="btn-graphical-xml">图形化编辑</li>
|
||||
<li class="btn-copy" title="Ctrl+C">复制</li>
|
||||
<li class="btn-paste" title="Ctrl+V">粘贴</li>
|
||||
<li class="btn-cut" title="Ctrl+X">剪切</li>
|
||||
<li class="btn-undo" title="Ctrl+Z">撤销</li>
|
||||
<li class="btn-redo" title="Ctrl+Y">恢复</li>
|
||||
<li class="btn-delete" title="Delete">删除</li>
|
||||
<li class="btn-return"></li>
|
||||
<li class="btn-selectAll" title="全选(Ctrl+A)"></li>
|
||||
<li class="btn-save" title="保存(Ctrl+S)"></li>
|
||||
<li class="btn-console-xml" title="打印XML"></li>
|
||||
<li class="btn-edit-xml" title="XML编辑"></li>
|
||||
<li class="btn-copy" title="复制(Ctrl+C)"></li>
|
||||
<li class="btn-paste" title="粘贴(Ctrl+V)"></li>
|
||||
<li class="btn-cut" title="剪切(Ctrl+X)"></li>
|
||||
<li class="btn-undo" title="撤销(Ctrl+Z)"></li>
|
||||
<li class="btn-redo" title="反撤销(Ctrl+Y)"></li>
|
||||
<li class="btn-delete" title="删除(Delete)"></li>
|
||||
<li class="btn-test" title="测试(Ctrl+Q)"></li>
|
||||
<li class="btn-debug" title="调试(Ctrl+Q)"></li>
|
||||
<li class="btn-resume disabled" title="下一步"></li>
|
||||
<li class="btn-stop disabled" title="停止"></li>
|
||||
</ul>
|
||||
</div>
|
||||
<div class="sidebar-container"></div>
|
||||
|
@ -18,7 +18,8 @@
|
||||
<ul class="layui-nav layui-layout-right">
|
||||
<li class="layui-nav-item"><a target="_blank" href="https://www.spiderflow.org">帮助文档</a></li>
|
||||
<li class="layui-nav-item"><a target="_blank" href="https://shang.qq.com/wpa/qunwpa?idkey=10faa4cf9743e0aa379a72f2ad12a9e576c81462742143c8f3391b52e8c3ed8d">加入QQ群</li>
|
||||
<li class="layui-nav-item"><a target="_blank" href='https://gitee.com/jmxd/spider-flow'><img src='https://gitee.com/jmxd/spider-flow/badge/star.svg?theme=white' alt='star'></img></a></li>
|
||||
<li class="layui-nav-item"><a target="_blank" href='https://gitee.com/jmxd/spider-flow'><img src='https://gitee.com/jmxd/spider-flow/badge/star.svg?theme=white' alt='gitee star' /></a></li>
|
||||
<li class="layui-nav-item"><a target="_blank" href='https://github.com/javamxd/spider-flow'><img src='https://img.shields.io/github/stars/javamxd/spider-flow.svg?style=social' alt='github star' style="background: none"/></a></li>
|
||||
</ul>
|
||||
</div>
|
||||
<div class="layui-side">
|
||||
|
@ -2,6 +2,7 @@ var $ = layui.$;
|
||||
var editor;
|
||||
var flows;
|
||||
var codeMirrorInstances = {};
|
||||
var socket;
|
||||
function renderCodeMirror(){
|
||||
codeMirrorInstances = {};
|
||||
$('[codemirror]').each(function(){
|
||||
@ -221,9 +222,13 @@ $(function(){
|
||||
render();
|
||||
return;
|
||||
}
|
||||
$.get('resources/templates/' + template +".html",function(content){
|
||||
templateCache[template] = content;
|
||||
render();
|
||||
$.ajax({
|
||||
url : 'resources/templates/' + template +".html",
|
||||
async :false,
|
||||
success : function(content){
|
||||
templateCache[template] = content;
|
||||
render();
|
||||
}
|
||||
});
|
||||
}
|
||||
if (!mxClient.isBrowserSupported()){
|
||||
@ -649,267 +654,360 @@ function bindToolbarClickAction(editor){
|
||||
$(".editor-container").hide();
|
||||
$(".xml-container textarea").val(editor.getXML());
|
||||
$(".xml-container").show();
|
||||
$(this).removeClass('btn-edit-xml').addClass('btn-graphical-xml');
|
||||
}).on('click',".btn-graphical-xml",function(){
|
||||
$(".editor-container").show();
|
||||
$(".xml-container").hide();
|
||||
$(this).removeClass('btn-graphical-xml').addClass('btn-edit-xml');
|
||||
// editor.setXML($(".xml-container textarea").val());
|
||||
// editor.onSelectedCell();
|
||||
}).on('click','.btn-stop:not(.disabled)',function () {
|
||||
socket.send(JSON.stringify({
|
||||
eventType : 'stop'
|
||||
}));
|
||||
}).on('click','.btn-resume:not(.disabled)',function () {
|
||||
$(this).addClass('disabled')
|
||||
$(".spiderflow-debug-tooltip").remove();
|
||||
socket.send(JSON.stringify({
|
||||
eventType : 'resume'
|
||||
}));
|
||||
}).on('click','.btn-test',function(){
|
||||
validXML(function(){
|
||||
var LogViewer;
|
||||
var tableMap = {};
|
||||
var socket;
|
||||
var first = true;
|
||||
var filterText = '';
|
||||
var testWindowIndex = layui.layer.open({
|
||||
id : 'test-window',
|
||||
type : 1,
|
||||
content : '<div class="test-window-container"><div class="output-container"><div class="layui-tab layui-tab-fixed layui-tab-brief"><ul class="layui-tab-title"></ul><div class="layui-tab-content"></div></div></div><canvas class="log-container" width="960" height="100"></canvas></div>',
|
||||
area : ["980px","500px"],
|
||||
shade : 0,
|
||||
maxmin : true,
|
||||
maxWidth : 700,
|
||||
maxHeight : 400,
|
||||
title : '测试窗口',
|
||||
btn : ['关闭','显示/隐藏输出','显示/隐藏日志','停止'],
|
||||
btn2 : function(){
|
||||
var $output = $(".test-window-container .output-container");
|
||||
var $log = $(".test-window-container .log-container");
|
||||
if($output.is(":hidden")){
|
||||
$output.show();
|
||||
$output.find("canvas").each(function(){
|
||||
if($log.is(":hidden")){
|
||||
this.height = 320;
|
||||
}else{
|
||||
this.height = 200;
|
||||
}
|
||||
})
|
||||
$log.attr('height',100)
|
||||
LogViewer.resize();
|
||||
for(var tableId in tableMap){
|
||||
tableMap[tableId].instance.resize();
|
||||
}
|
||||
}else{
|
||||
$output.hide();
|
||||
$log.attr('height',400);
|
||||
LogViewer.resize();
|
||||
for(var tableId in tableMap){
|
||||
tableMap[tableId].instance.resize();
|
||||
}
|
||||
}
|
||||
return false;
|
||||
},
|
||||
btn3 : function(){
|
||||
var $output = $(".test-window-container .output-container");
|
||||
var $log = $(".test-window-container .log-container");
|
||||
if($log.is(":hidden")){
|
||||
$log.show();
|
||||
$log.attr('height',$output.is(":hidden") ? 400 : 100)
|
||||
$output.find("canvas").each(function(){
|
||||
runSpider(false);
|
||||
}).on('click','.btn-debug',function(){
|
||||
runSpider(true);
|
||||
}).on('click',".btn-return",function(){
|
||||
location.href="spiderList.html"
|
||||
}).on('click','.btn-save',function(){
|
||||
Save();
|
||||
})
|
||||
}
|
||||
function runSpider(debug){
|
||||
validXML(function(){
|
||||
$(".btn-debug,.btn-test,.btn-resume").addClass('disabled');
|
||||
$(".btn-stop").removeClass('disabled');
|
||||
var LogViewer;
|
||||
var tableMap = {};
|
||||
var first = true;
|
||||
var filterText = '';
|
||||
var testWindowIndex = layui.layer.open({
|
||||
id : 'test-window',
|
||||
type : 1,
|
||||
skin : 'layer-test',
|
||||
content : '<div class="test-window-container"><div class="output-container"><div class="layui-tab layui-tab-fixed layui-tab-brief"><ul class="layui-tab-title"></ul><div class="layui-tab-content"></div></div></div><canvas class="log-container" width="677" height="100"></canvas></div>',
|
||||
area : ["680px","400px"],
|
||||
shade : 0,
|
||||
offset : 'rt',
|
||||
maxmin :true,
|
||||
maxWidth : 700,
|
||||
maxHeight : 400,
|
||||
title : '测试窗口',
|
||||
btn : ['关闭','显示/隐藏输出','显示/隐藏日志','停止'],
|
||||
btn2 : function(){
|
||||
var $output = $(".test-window-container .output-container");
|
||||
var $log = $(".test-window-container .log-container");
|
||||
if($output.is(":hidden")){
|
||||
$output.show();
|
||||
$output.find("canvas").each(function(){
|
||||
if($log.is(":hidden")){
|
||||
this.height = 290;
|
||||
}else{
|
||||
this.height = 200;
|
||||
});
|
||||
LogViewer.resize();
|
||||
for(var tableId in tableMap){
|
||||
tableMap[tableId].instance.resize();
|
||||
}
|
||||
}else{
|
||||
$log.hide();
|
||||
$output.find("canvas").each(function(){
|
||||
this.height = 320;
|
||||
});
|
||||
LogViewer.resize();
|
||||
for(var tableId in tableMap){
|
||||
tableMap[tableId].instance.resize();
|
||||
}
|
||||
})
|
||||
$log.attr('height',100)
|
||||
LogViewer.resize();
|
||||
for(var tableId in tableMap){
|
||||
tableMap[tableId].instance.resize();
|
||||
}
|
||||
return false;
|
||||
},
|
||||
btn4 : function(){
|
||||
var $btn = $("#layui-layer" + testWindowIndex).find('.layui-layer-btn3');
|
||||
if($btn.html() == '停止'){
|
||||
}else{
|
||||
$output.hide();
|
||||
$log.attr('height',320);
|
||||
LogViewer.resize();
|
||||
for(var tableId in tableMap){
|
||||
tableMap[tableId].instance.resize();
|
||||
}
|
||||
}
|
||||
return false;
|
||||
},
|
||||
btn3 : function(){
|
||||
var $output = $(".test-window-container .output-container");
|
||||
var $log = $(".test-window-container .log-container");
|
||||
if($log.is(":hidden")){
|
||||
$log.show();
|
||||
$log.attr('height',$output.is(":hidden") ? 320 : 100)
|
||||
$output.find("canvas").each(function(){
|
||||
this.height = 200;
|
||||
});
|
||||
LogViewer.resize();
|
||||
for(var tableId in tableMap){
|
||||
tableMap[tableId].instance.resize();
|
||||
}
|
||||
}else{
|
||||
$log.hide();
|
||||
$output.find("canvas").each(function(){
|
||||
this.height = 320;
|
||||
});
|
||||
LogViewer.resize();
|
||||
for(var tableId in tableMap){
|
||||
tableMap[tableId].instance.resize();
|
||||
}
|
||||
}
|
||||
return false;
|
||||
},
|
||||
btn4 : function(){
|
||||
var $btn = $("#layui-layer" + testWindowIndex).find('.layui-layer-btn3');
|
||||
if($btn.html() == '停止'){
|
||||
socket.send(JSON.stringify({
|
||||
eventType : 'stop'
|
||||
}));
|
||||
}else{
|
||||
$(".btn-debug,.btn-test,.btn-resume").addClass('disabled');
|
||||
$(".btn-stop").removeClass('disabled');
|
||||
socket.send(JSON.stringify({
|
||||
eventType : debug ? 'debug' : 'test',
|
||||
message : editor.getXML()
|
||||
}));
|
||||
$btn.html('停止');
|
||||
}
|
||||
return false;
|
||||
},
|
||||
end : function(){
|
||||
if(socket){
|
||||
socket.close();
|
||||
$(".spiderflow-debug-tooltip").remove();
|
||||
$(".btn-stop,.btn-resume").addClass('disabled');
|
||||
$(".btn-test,.btn-debug").removeClass('disabled')
|
||||
}
|
||||
if(LogViewer){
|
||||
LogViewer.destory();
|
||||
}
|
||||
for(var tableId in tableMap){
|
||||
tableMap[tableId].instance.destory();
|
||||
}
|
||||
},
|
||||
success : function(layero,index){
|
||||
var logElement = $(".test-window-container .log-container")[0];
|
||||
var colors = {
|
||||
'array' : '#2a00ff',
|
||||
'object' : '#2a00ff',
|
||||
'boolean' : '#600100',
|
||||
'number' : '#000E59'
|
||||
}
|
||||
LogViewer = new CanvasViewer({
|
||||
element : logElement,
|
||||
onClick : function(e){
|
||||
onCanvasViewerClick(e,'日志');
|
||||
}
|
||||
});
|
||||
$(layero).find(".layui-layer-btn")
|
||||
.append('<div class="layui-inline"><input type="text" class="layui-input" placeholder="输入关键字过滤日志"/></div>')
|
||||
.on("keyup","input",function(){
|
||||
LogViewer.filter(this.value);
|
||||
});
|
||||
socket = createWebSocket({
|
||||
onopen : function(){
|
||||
socket.send(JSON.stringify({
|
||||
eventType : 'stop'
|
||||
}));
|
||||
}else{
|
||||
socket.send(JSON.stringify({
|
||||
eventType : 'test',
|
||||
eventType : debug ? 'debug' : 'test',
|
||||
message : editor.getXML()
|
||||
}));
|
||||
$btn.html('停止');
|
||||
}
|
||||
return false;
|
||||
},
|
||||
end : function(){
|
||||
if(socket){
|
||||
socket.close();
|
||||
}
|
||||
if(LogViewer){
|
||||
LogViewer.destory();
|
||||
}
|
||||
for(var tableId in tableMap){
|
||||
tableMap[tableId].instance.destory();
|
||||
}
|
||||
},
|
||||
success : function(layero,index){
|
||||
var logElement = $(".test-window-container .log-container")[0];
|
||||
var colors = {
|
||||
'array' : '#2a00ff',
|
||||
'object' : '#2a00ff',
|
||||
'boolean' : '#600100',
|
||||
'number' : '#000E59'
|
||||
}
|
||||
LogViewer = new CanvasViewer({
|
||||
element : logElement,
|
||||
onClick : function(e){
|
||||
onCanvasViewerClick(e,'日志');
|
||||
}
|
||||
});
|
||||
$(layero).find(".layui-layer-btn")
|
||||
.append('<div class="layui-inline"><input type="text" class="layui-input" placeholder="输入关键字过滤日志"/></div>')
|
||||
.on("keyup","input",function(){
|
||||
LogViewer.filter(this.value);
|
||||
});
|
||||
socket = createWebSocket({
|
||||
onopen : function(){
|
||||
socket.send(JSON.stringify({
|
||||
eventType : 'test',
|
||||
message : editor.getXML()
|
||||
}));
|
||||
},
|
||||
onmessage : function(e){
|
||||
var event = JSON.parse(e.data);
|
||||
var eventType = event.eventType;
|
||||
var message = event.message;
|
||||
if(eventType == 'finish'){
|
||||
$("#layui-layer" + testWindowIndex).find('.layui-layer-btn3').html('重新开始');
|
||||
}else if(eventType == 'output'){
|
||||
var tableId = 'output-' + message.nodeId;
|
||||
var $table = $('#' + tableId);
|
||||
if($table.length == 0){
|
||||
tableMap[tableId] = {
|
||||
index : 0
|
||||
};
|
||||
var $tab = $(".test-window-container .output-container .layui-tab")
|
||||
var outputTitle = '输出-'+tableId;
|
||||
var cell = editor.getModel().cells[message.nodeId];
|
||||
if(cell){
|
||||
outputTitle = cell.value;
|
||||
}
|
||||
if(first){
|
||||
$tab.find(".layui-tab-title").append('<li class="layui-this">' + outputTitle + '</li>');
|
||||
$tab.find(".layui-tab-content").append('<div class="layui-tab-item layui-show" data-output="'+tableId+'"></div>');
|
||||
first = false;
|
||||
}else{
|
||||
$tab.find(".layui-tab-title").append('<li>' + outputTitle + '</li>');
|
||||
$tab.find(".layui-tab-content").append('<div class="layui-tab-item" data-output="'+tableId+'"></div>');
|
||||
}
|
||||
$table = $('<canvas width="960" height="200"/>').appendTo($(".test-window-container .output-container .layui-tab-item[data-output="+tableId+"]"));
|
||||
$table.attr('id',tableId);
|
||||
tableMap[tableId].instance = new CanvasViewer({
|
||||
element : document.getElementById(tableId),
|
||||
grid : true,
|
||||
header : true,
|
||||
style : {
|
||||
font : 'bold 13px Consolas'
|
||||
},
|
||||
onClick : function(e){
|
||||
onCanvasViewerClick(e,'表格');
|
||||
}
|
||||
})
|
||||
var cols = [];
|
||||
var texts = [new CanvasText({
|
||||
text : '序号',
|
||||
maxWidth : 100
|
||||
})];
|
||||
for(var i =0,len = message.outputNames.length;i<len;i++){
|
||||
texts.push(new CanvasText({
|
||||
text : message.outputNames[i],
|
||||
maxWidth : 200,
|
||||
click : true
|
||||
}));
|
||||
}
|
||||
tableMap[tableId].instance.append(texts);
|
||||
},
|
||||
onmessage : function(e){
|
||||
var event = JSON.parse(e.data);
|
||||
var eventType = event.eventType;
|
||||
var message = event.message;
|
||||
if(eventType == 'finish'){
|
||||
$(".spiderflow-debug-tooltip").remove();
|
||||
$("#layui-layer" + testWindowIndex).find('.layui-layer-btn3').html('重新开始');
|
||||
$(".btn-stop,.btn-resume").addClass('disabled');
|
||||
$(".btn-test,.btn-debug").removeClass('disabled')
|
||||
}else if(eventType == 'output'){
|
||||
var tableId = 'output-' + message.nodeId;
|
||||
var $table = $('#' + tableId);
|
||||
if($table.length == 0){
|
||||
tableMap[tableId] = {
|
||||
index : 0
|
||||
};
|
||||
var $tab = $(".test-window-container .output-container .layui-tab")
|
||||
var outputTitle = '输出-'+tableId;
|
||||
var cell = editor.getModel().cells[message.nodeId];
|
||||
if(cell){
|
||||
outputTitle = cell.value;
|
||||
}
|
||||
if(first){
|
||||
$tab.find(".layui-tab-title").append('<li class="layui-this">' + outputTitle + '</li>');
|
||||
$tab.find(".layui-tab-content").append('<div class="layui-tab-item layui-show" data-output="'+tableId+'"></div>');
|
||||
first = false;
|
||||
}else{
|
||||
$tab.find(".layui-tab-title").append('<li>' + outputTitle + '</li>');
|
||||
$tab.find(".layui-tab-content").append('<div class="layui-tab-item" data-output="'+tableId+'"></div>');
|
||||
}
|
||||
$table = $('<canvas width="677" height="200"/>').appendTo($(".test-window-container .output-container .layui-tab-item[data-output="+tableId+"]"));
|
||||
$table.attr('id',tableId);
|
||||
tableMap[tableId].instance = new CanvasViewer({
|
||||
element : document.getElementById(tableId),
|
||||
grid : true,
|
||||
header : true,
|
||||
style : {
|
||||
font : 'bold 13px Consolas'
|
||||
},
|
||||
onClick : function(e){
|
||||
onCanvasViewerClick(e,'表格');
|
||||
}
|
||||
})
|
||||
var cols = [];
|
||||
var texts = [new CanvasText({
|
||||
text : ++tableMap[tableId].index,
|
||||
maxWidth : 200,
|
||||
click : true
|
||||
text : '序号',
|
||||
maxWidth : 100
|
||||
})];
|
||||
for(var i =0,len = message.outputNames.length;i<len;i++){
|
||||
var displayText = message.values[i];
|
||||
var variableType = 'string';
|
||||
if(Array.isArray(displayText)){
|
||||
texts.push(new CanvasText({
|
||||
text : message.outputNames[i],
|
||||
maxWidth : 200,
|
||||
click : true
|
||||
}));
|
||||
}
|
||||
tableMap[tableId].instance.append(texts);
|
||||
}
|
||||
var texts = [new CanvasText({
|
||||
text : ++tableMap[tableId].index,
|
||||
maxWidth : 200,
|
||||
click : true
|
||||
})];
|
||||
for(var i =0,len = message.outputNames.length;i<len;i++){
|
||||
var displayText = message.values[i];
|
||||
var variableType = 'string';
|
||||
if(Array.isArray(displayText)){
|
||||
variableType = 'array';
|
||||
displayText = JSON.stringify(displayText);
|
||||
}else{
|
||||
variableType = typeof displayText;
|
||||
if(variableType == 'object'){
|
||||
displayText = JSON.stringify(displayText);
|
||||
}
|
||||
}
|
||||
texts.push(new CanvasText({
|
||||
text : displayText,
|
||||
maxWidth : 200,
|
||||
color : colors[variableType] || 'black',
|
||||
click : true
|
||||
}));
|
||||
}
|
||||
tableMap[tableId].instance.append(texts);
|
||||
tableMap[tableId].instance.scrollTo(-1);
|
||||
}else if(eventType == 'log'){
|
||||
var texts = [];
|
||||
var defaultColor = message.level == 'error' ? 'red' : '';
|
||||
texts.push(new CanvasText({
|
||||
text : message.level,
|
||||
color : defaultColor
|
||||
}));
|
||||
texts.push(new CanvasText({
|
||||
text : event.timestamp,
|
||||
color : defaultColor
|
||||
}));
|
||||
var temp = message.message.split("{}");
|
||||
message.variables = message.variables || [];
|
||||
for(var i=0,len=temp.length;i<len;i++){
|
||||
if(temp[i]!=''){
|
||||
texts.push(new CanvasText({
|
||||
text : temp[i],
|
||||
color : defaultColor
|
||||
}))
|
||||
}
|
||||
var object = message.variables[i];
|
||||
if(object != undefined){
|
||||
var variableType = '';
|
||||
var displayText = object;
|
||||
if(Array.isArray(object)){
|
||||
variableType = 'array';
|
||||
displayText = JSON.stringify(displayText);
|
||||
}else{
|
||||
variableType = typeof displayText;
|
||||
variableType = typeof object;
|
||||
if(variableType == 'object'){
|
||||
displayText = JSON.stringify(displayText);
|
||||
}
|
||||
}
|
||||
texts.push(new CanvasText({
|
||||
text : displayText,
|
||||
maxWidth : 200,
|
||||
color : colors[variableType] || 'black',
|
||||
maxWidth : 330,
|
||||
color : colors[variableType] || '#025900',
|
||||
click : true
|
||||
}));
|
||||
}))
|
||||
}
|
||||
tableMap[tableId].instance.append(texts);
|
||||
tableMap[tableId].instance.scrollTo(-1);
|
||||
}else if(eventType == 'log'){
|
||||
var texts = [];
|
||||
var defaultColor = message.level == 'error' ? 'red' : '';
|
||||
texts.push(new CanvasText({
|
||||
text : message.level,
|
||||
color : defaultColor
|
||||
}));
|
||||
texts.push(new CanvasText({
|
||||
text : event.timestamp,
|
||||
color : defaultColor
|
||||
}));
|
||||
var temp = message.message.split("{}");
|
||||
message.variables = message.variables || [];
|
||||
for(var i=0,len=temp.length;i<len;i++){
|
||||
if(temp[i]!=''){
|
||||
texts.push(new CanvasText({
|
||||
text : temp[i],
|
||||
color : defaultColor
|
||||
}))
|
||||
}
|
||||
var object = message.variables[i];
|
||||
if(object != undefined){
|
||||
var variableType = '';
|
||||
var displayText = object;
|
||||
if(Array.isArray(object)){
|
||||
variableType = 'array';
|
||||
displayText = JSON.stringify(displayText);
|
||||
}else{
|
||||
variableType = typeof object;
|
||||
if(variableType == 'object'){
|
||||
displayText = JSON.stringify(displayText);
|
||||
}
|
||||
}
|
||||
texts.push(new CanvasText({
|
||||
text : displayText,
|
||||
maxWidth : 330,
|
||||
color : colors[variableType] || '#025900',
|
||||
click : true
|
||||
}))
|
||||
}
|
||||
}
|
||||
LogViewer.append(texts);
|
||||
LogViewer.scrollTo(-1);
|
||||
}
|
||||
LogViewer.append(texts);
|
||||
LogViewer.scrollTo(-1);
|
||||
}else if(eventType == 'debug'){
|
||||
console.log(message);
|
||||
$(".btn-resume").removeClass('disabled');
|
||||
var type = message.event;
|
||||
editor.selectCell(editor.graph.model.cells[message.nodeId]);
|
||||
var selector;
|
||||
if(type == 'request-parameter'){
|
||||
$('.layui-tab-title li:eq(1)').click();
|
||||
}
|
||||
if(type == 'request-cookie'){
|
||||
$('.layui-tab-title li:eq(2)').click();
|
||||
}
|
||||
if(type == 'request-header'){
|
||||
$('.layui-tab-title li:eq(3)').click();
|
||||
}
|
||||
if(type == 'request-body'){
|
||||
$('.layui-tab-title li:eq(4)').click();
|
||||
}
|
||||
if(type == 'common' || type == 'request-parameter' || type == 'request-header' || type == 'request-cookie'){
|
||||
selector = '.layui-table-cell input[value='+message.key+']';
|
||||
}
|
||||
if($(selector).length == 0){
|
||||
selector = '.properties-container input[name='+message.key+']';
|
||||
}
|
||||
if($(selector).length == 0){
|
||||
selector = '.properties-container [codemirror='+message.key+']';
|
||||
}
|
||||
var o1 = $(selector).offset();
|
||||
var $parent = $(".properties-container");
|
||||
var o2 = $parent.offset();
|
||||
if(o1.top > o2.top + $parent.height()){
|
||||
$parent[0].scrollTop = o1.top - o2.top;
|
||||
}
|
||||
var msg = message.value;
|
||||
var isJson = Array.isArray(msg) || typeof msg == 'object';
|
||||
if(!isJson){
|
||||
var temp = document.createElement("div");
|
||||
(temp.textContent != null) ? (temp.textContent = msg) : (temp.innerText = msg);
|
||||
msg = temp.innerHTML;
|
||||
temp = null;
|
||||
}
|
||||
var content = '<div class="message-content" style="padding:10px;'+(isJson ? '':'font-weight: bold;font-family:Consolas;font-size:12px;')+'">'+(isJson ? '' : msg.replace(/\n/g,'<br>')).replace(/ /g,' ').replace(/\t/g,' ')+'</div>';
|
||||
var tooltip = bindTooltip(content,selector);
|
||||
if(isJson){
|
||||
var $dom = $(tooltip.dom).find(".message-content");
|
||||
jsonTree.create(msg,$dom[0]);
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
})
|
||||
});
|
||||
}).on('click',".btn-return",function(){
|
||||
location.href="spiderList.html"
|
||||
}).on('click','.btn-save',function(){
|
||||
Save();
|
||||
})
|
||||
}
|
||||
});
|
||||
}
|
||||
})
|
||||
});
|
||||
}
|
||||
function bindTooltip(content,selector){
|
||||
var dom = document.createElement('div');
|
||||
var $target = $(selector);
|
||||
var offset = $target.offset();
|
||||
dom.className = 'spiderflow-debug-tooltip';
|
||||
dom.style.bottom = ($("body").height() - offset.top) + 'px';
|
||||
dom.style.left = (offset.left + $target.width() / 2) + 'px';
|
||||
dom.innerHTML = '<div class="content">' + content + '</div>';
|
||||
document.body.appendChild(dom);
|
||||
$(selector).offset();
|
||||
return {
|
||||
dom : dom,
|
||||
close : function(){
|
||||
document.body.removeChild(dom);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
//最近点击打开的弹窗
|
||||
var index;
|
||||
|
Loading…
Reference in New Issue
Block a user