All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.dreamlu.mica.xss.core.XssCleanDeserializerBase Maven / Gradle / Ivy

There is a newer version: 3.3.2
Show newest version
/*
 * Copyright (c) 2019-2029, Dreamlu 卢春梦 ([email protected] & www.dreamlu.net).
 * 

* Licensed under the GNU LESSER GENERAL PUBLIC LICENSE 3.0; * you may not use this file except in compliance with the License. * You may obtain a copy of the License at *

* http://www.gnu.org/licenses/lgpl.html *

* Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package net.dreamlu.mica.xss.core; import com.fasterxml.jackson.core.JsonParser; import com.fasterxml.jackson.core.JsonToken; import com.fasterxml.jackson.databind.DeserializationContext; import com.fasterxml.jackson.databind.JsonDeserializer; import com.fasterxml.jackson.databind.exc.MismatchedInputException; import java.io.IOException; /** * jackson xss 处理 * * @author L.cm */ public abstract class XssCleanDeserializerBase extends JsonDeserializer { @Override public String deserialize(JsonParser p, DeserializationContext ctx) throws IOException { // json 字段名 String name = p.getCurrentName(); // 字符串类型 if (p.hasToken(JsonToken.VALUE_STRING)) { String text = p.getText(); if (text == null) { return null; } return clean(name, text); } JsonToken jsonToken = p.getCurrentToken(); if (jsonToken.isScalarValue()) { String text = p.getValueAsString(); if (text != null) { return text; } } throw MismatchedInputException.from(p, String.class, "mica-xss: can't deserialize json name:" + name + " value of type java.lang.String from " + jsonToken); } /** * 清理 xss * * @param name json name * @param value json value * @return String */ public abstract String clean(String name, String value) throws IOException; }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy