com.fastchar.extjs.interceptor.FastExtAfterInterceptor Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of fastchar-extjs Show documentation
Show all versions of fastchar-extjs Show documentation
FastChar-ExtJs is a Java Web framework that uses extjs libraries.Quickly build a background management system
package com.fastchar.extjs.interceptor;
import com.fastchar.core.FastAction;
import com.fastchar.core.FastChar;
import com.fastchar.extjs.FastExtConfig;
import com.fastchar.extjs.annotation.AFastLog;
import com.fastchar.extjs.annotation.AFastSecurityResponse;
import com.fastchar.extjs.entity.ExtManagerEntity;
import com.fastchar.extjs.entity.ExtSystemLogEntity;
import com.fastchar.interfaces.IFastInterceptor;
import com.fastchar.out.FastOutJson;
import com.fastchar.out.FastOutText;
import com.fastchar.utils.*;
import java.awt.image.RenderedImage;
import java.util.*;
import java.util.stream.Stream;
public class FastExtAfterInterceptor implements IFastInterceptor {
@Override
public void onInterceptor(FastAction fastAction) {
try {
if (fastAction.getFastRoute().getMethod().isAnnotationPresent(AFastLog.class)) {
AFastLog fastLog = fastAction.getFastRoute().getMethod().getAnnotation(AFastLog.class);
ExtSystemLogEntity extSystemLogEntity = new ExtSystemLogEntity();
ExtManagerEntity manager = ExtManagerEntity.getSession(fastAction);
if (manager != null) {
extSystemLogEntity.set("managerId", manager.getId());
}
extSystemLogEntity.set("systemLogType", extSystemLogEntity.replaceHolder(fastLog.type(), fastAction.getRequest()));
extSystemLogEntity.set("systemLogContent", extSystemLogEntity.replaceHolder(fastLog.value(), fastAction.getRequest()));
extSystemLogEntity.set("systemSendData", FastChar.getJson().toJson(fastAction.getParamToMap()));
if (fastAction.getFastOut() != null && fastAction.getFastOut().getData() != null) {
boolean dataToJson =
!(fastAction.getFastOut().getData() instanceof RenderedImage)
&& !(fastAction.getFastOut().getData() instanceof Stream);
if (dataToJson) {
extSystemLogEntity.set("systemResultData", FastChar.getJson().toJson(fastAction.getFastOut().getData()));
}
}
extSystemLogEntity.set("systemLogIp", fastAction.getRemoteIp());
extSystemLogEntity.set("systemLogClient", fastAction.getUserAgent());
extSystemLogEntity.put("log", false);
extSystemLogEntity.save();
}
if (fastAction.getFastOut().getStatus() == 500
|| fastAction.getFastOut().getStatus() == 502) {
if (fastAction.getFastOut() instanceof FastOutText) {
fastAction.responseJson(-1, "操作失败!" + fastAction.getFastOut().getData());
} else {
fastAction.responseJson(-1, "操作失败!" + fastAction.getFastOut().getDescription());
}
} else {
if ((fastAction.getFastOut() instanceof FastOutJson) && fastAction.getFastRoute().getMethod().isAnnotationPresent(AFastSecurityResponse.class)) {
AFastSecurityResponse fastSecurityResponse = fastAction.getFastRoute().getMethod().getAnnotation(AFastSecurityResponse.class);
if (fastSecurityResponse.value() && FastExtConfig.getInstance().isSecurityResponse()) {
String responseAESPassword = fastAction.getSession("ResponseAESPassword");
if (FastStringUtils.isNotEmpty(responseAESPassword)) {
String jsonData = FastChar.getJson().toJson(fastAction.getFastOut().getData());
//按照10kb进行分割
List chunks = splitContent(jsonData);
List
© 2015 - 2025 Weber Informatics LLC | Privacy Policy