我试图使用SpringBoot创建一个RESTfulWeb服务,它将接收JSON并使用Jackson验证它。
以下是RESTful Web服务:
import java.util.Map;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
import com.fasterxml.jackson.core.JsonFactory;
import com.fasterxml.jackson.core.JsonParser;
import com.google.gson.Gson;
@RestController
@RequestMapping("/myservice")
public class ValidationService {
@RequestMapping(value="/validate", method = RequestMethod.POST)
public void validate(@RequestBody Map<String, Object> payload) throws Exception {
Gson gson = new Gson();
String json = gson.toJson(payload);
System.out.println(json);
boolean retValue = false;
try {
retValue = Validator.isValid(json);
}
catch(Throwable t) {
t.printStackTrace();
}
System.out.println(retValue);
}
}
这是验证器的代码:
import java.io.IOException;
import com.fasterxml.jackson.core.JsonParseException;
import com.fasterxml.jackson.core.JsonParser;
import com.fasterxml.jackson.databind.DeserializationFeature;
import com.fasterxml.jackson.databind.ObjectMapper;
public class Validator {
public static boolean isValid(String json) {
boolean retValue = false;
try {
ObjectMapper objectMapper = new ObjectMapper();
objectMapper.enable(DeserializationFeature.FAIL_ON_READING_DUP_TREE_KEY);
JsonParser parser = objectMapper.getFactory().createParser(json);
while (parser.nextToken() != null) {}
retValue = true;
objectMapper.readTree(json);
}catch(JsonParseException jpe) {
jpe.printStackTrace();
}
catch(IOException ioe) {
}
return retValue;
}
}
因此,当我使用curl发送有效的JSON时:
curl -H "Accept: application/json" -H "Content-type: application/json" \
-X POST -d '{"name":"value"}' http://localhost:8080/myservice/validate
我收到以下发送给stdout的邮件:
{"name":"value"}
true
但是当对无效JSON使用以下curl命令时(故意删除了右大括号):
curl -H "Accept: application/json" -H "Content-type: application/json" \
-X POST -d '{"name":"value"' http://localhost:8080/myservice/validate
我收到以下内部标准输出:
{"timestamp":1427698779063,
"status":400,"error":
"Bad Request",
"exception":"org.springframework.http.converter.HttpMessageNotReadableException",
"message":"Could not read JSON:
Unexpected end-of-input: expected close marker for OBJECT
(from [Source: java.io.PushbackInputStream@1edeb3e; line: 1, column: 0])\n
at [Source: java.io.PushbackInputStream@1edeb3e; line: 1, column: 31];
nested exception is
com.fasterxml.jackson.core.JsonParseException:
Unexpected end-of-input: expected close marker for OBJECT
(from [Source: java.io.PushbackInputStream@1edeb3e; line: 1, column: 0])\n
at [Source: java.io.PushbackInputStream@1edeb3e; line: 1, column: 31]",
"path":"/myservice/validate"
有没有办法确保在服务器端处理异常,但不在标准输出中抛出,然后让我的代码响应:
false
感谢您抽出时间阅读此。。。
我猜问题出在@刚体映射上
但是,因为你想接受任何输入,使用
@刚体字符串有效载荷
代替,作为奖励,你可以摆脱GSON转换到字符串:)
在Spring 3.2之后,您可以使用org.springframework.web.bind.annotation.控件建议来处理这些全局抛出的异常
示例代码
@ExceptionHandler(HttpMessageNotReadableException.class)
public ResponseEntity<?> handleHttpMessageNotReadable(HttpMessageNotReadableException ex,
MultipleReadHttpRequest request) {
Map<String, String> errorResponse = new HashMap<>();
errorResponse.put("error", ex.getMessage());
errorResponse.put("code", "01");
return new ResponseEntity<>(errorResponse, HttpStatus.BAD_REQUEST);
}
如果存在JSON格式无效错误,将执行此方法。您可以自定义您的响应。
想出来了!
添加了以下更改:
在@RequestMapping代码部分中:
consumes = "text/plain",
produces = "application/json"
将@RequestBody从映射更改为字符串负载。
ValidationService类:
@RequestMapping(value="/validate",
method = RequestMethod.POST,
consumes="text/plain",
produces="application/json")
public ValidationResponse process(@RequestBody String payload) throws JsonParseException,
IOException {
ValidationResponse response = new ValidationResponse();
boolean retValue = false;
retValue = Validator.isValid(payload);
System.out.println(retValue);
if (retValue == false) {
response.setMessage("Invalid JSON");
}
else {
response.setMessage("Valid JSON");
}
return response;
}
验证程序类:
import java.io.IOException;
import com.fasterxml.jackson.core.JsonFactory;
import com.fasterxml.jackson.core.JsonParseException;
import com.fasterxml.jackson.core.JsonParser;
import com.fasterxml.jackson.databind.DeserializationFeature;
import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.ObjectMapper;
public class Validator {
public static boolean isValid(String json) {
boolean retValue = true;
try {
ObjectMapper mapper = new ObjectMapper();
mapper.enable(DeserializationFeature.FAIL_ON_READING_DUP_TREE_KEY);
JsonFactory factory = mapper.getFactory();
JsonParser parser = factory.createParser(json);
JsonNode jsonObj = mapper.readTree(parser);
System.out.println(jsonObj.toString());
}
catch(JsonParseException jpe) {
retValue = false;
}
catch(IOException ioe) {
retValue = false;
}
return retValue;
}
}
验证响应:
public class ValidationResponse {
public String message;
public String getMessage() {
return message;
}
public void setMessage(String message) {
this.message = message;
}
}
对内容类型使用“文本/普通”:
curl -H "Accept: application/json" -H "Content-type: text/plain" -X POST -d \
'{"name":"value"}' http://localhost:8080/myservice/validate
现在,一切正常!这石头!
问题内容: 我正在尝试使用Jackson JSON接受一个字符串,并确定它是否为有效JSON。谁能建议要使用的代码示例(Java)? 问题答案: 不知道您的用例是什么,但是应该这样做:
我试图用Laravel的护照测试身份验证,没有办法...总是收到401的客户端是无效的,我会告诉你我试过什么: 我的phpunit配置是一个来自基地与拉威尔 我方便的护照认证用于测试目的
问题内容: 我正在使用Jackson JSON库将一些JSON对象转换为POJO类。问题是,当我使用具有重复属性的JSON对象时,例如: 杰克逊报告最后一封电子邮件对,然后解析该对象。 我从JSON语法中获悉了对象中的重复键吗?反序列化具有重复属性的JSON对象时发生的情况取决于库的实现,是抛出错误还是将最后一个用于重复键。 尽管跟踪所有属性会产生开销,但是在这种情况下,是否有任何方法可以告诉Ja
我试图通过AzureAD使用OAuth2保护APIM API的安全,方法是阅读文章:使用OAuth 2.0 authorization with Azure AD保护Azure API管理中的web API后端 Azureapim-Oauth2 授权终结点URL(v1):https://login.microsoftonline.com/{tenant}/oauth2/authorize 令牌终结
问题内容: 发现我的浏览器正在通过软件运行,因此我得到了。当我手动启动铬并执行相同的步骤时,不会出现reCaptcha。 是否可以以编程方式解决验证码或在使用时摆脱它?有什么办法解决这个问题? 只有在没有选择的情况下才会发生这种情况 还是这是我们必须接受并继续前进的事实? 问题答案: 尝试使用此npm软件包生成随机useragent 。这通常可以解决基于用户代理的保护。 在伪造者页面中,可以使用