我正在学习Spring Core认证,并且与在Spring MVC中进行RESTful webapp *的练习有关。
因此,在示例中,我具有以下创建新 Account 对象的方法
/**
* Creates a new Account, setting its URL as the Location header on the
* response.
*/
@RequestMapping(value = "/accounts", method = RequestMethod.POST)
@ResponseStatus(HttpStatus.CREATED)
public HttpEntity<String> createAccount(@RequestBody Account newAccount,
@Value("#{request.requestURL}") StringBuffer url) {
Account account = accountManager.save(newAccount);
return entityWithLocation(url, account.getEntityId());
}
我知道:
*在这种情况下,@ *RequestMapping 批注指定此方法处理对 / accounts* 资源的 POST HttpRequest 。我知道它使用 POST 请求,因为根据REST风格,POST“动词”意味着必须创建一个新资源。 ***
我认为这个注释:
@ResponseStatus(HttpStatus.CREATED)
表示当方法正确结束时(将 HttpResponse 发送到客户端时),它将 201 ( CREATED
)放入HttpResponse状态字段。因此,它指定可以成功创建新对象。是真的还是我错过了什么?
@RequestBody Account newAccount
在阅读文档时,在我看来,此参数已绑定到Web请求的正文中。请求的主体通过HttpMessageConverter传递,以根据请求的内容类型解析方法参数。
那么,到底是什么意思呢?我认为这意味着在HttpRequest 主体中
,我具有JSON格式的Account对象,并且使用Jackson将其转换为经典的 Account Java对象。是对的还是我错过了什么?
@Value(“#{request.requestURL}”)StringBuffer网址
到底是什么意思?
然后,该方法将获得的对象保存在数据库中。
最后它返回:
return entityWithLocation(url, account.getEntityId());
但是到底是什么意思呢?什么回来了?在哪里?结果不是进入HttpResponse吗?
编辑1:
所述 entityWithLocation() 方法在同一类中的以前的方法的definied,这是它的代码:
private HttpEntity<String> entityWithLocation(StringBuffer url,
Object resourceId) {
// Configure and return an HttpEntity object - it will be used to build
// the HttpServletResponse
HttpHeaders headers = new HttpHeaders();
headers.setLocation(getLocationForChildResource(url, resourceId));
return new HttpEntity<String>(headers);
}
以下是我对您问题的理解。
@RequestBody帐户newAccount
关于这一点,您的理解是正确的。
- @Value(“#{request.requestURL}”)StringBuffer网址
它等效于request.getRequestURL();
见API
- entityWithLocation(url,account.getEntityId())
根据此方法中的代码。它返回HttpEntity
Object,它代表http请求或响应entity(which includes headers and body
),在您的情况下为response
。里面的方法,你已经添加了location
的resource(account)
创建。
因此,我有以下内容,这似乎令人难以置信的骇客,我一直在想,Go有比这更好的设计库,但我找不到Go处理JSON数据POST请求的例子。它们都是表格帖子。 下面是一个示例请求: 下面是嵌入日志的代码: 肯定有更好的办法,对吧?我只是很难找到最好的做法。 对搜索引擎来说,Go也被称为Golang,这里提到了它,这样其他人就可以找到它。)
基础的 Servlet 接口定义了 service 方法用于处理客户端的请求。当有请求到达时,该方法由 servlet 容器路由到一个 servlet 实例来调用。 Web 应用的并发请求处理通常需要 Web 开发人员去设计适合多线程执行的Servlet,从而保证 service 方法能在一个特定时间点处理多线程并发执行。(译者注: Servlet 默认是线程不安全的,需要开发人员处理多线程问题)
我使用Postman(chrome扩展)来测试这个REST服务,并且我能够成功地测试GET和DELETE:<code>http://localhost:8080/mt-rest/rest/user/321,但不是POST,即使在给出表单数据之后也是如此。我得到..服务器拒绝了此请求,因为请求实体的格式不受请求方法的请求资源的支持。我在这里做错了什么? 更新: 在我的POST方法中,我从@Reque
我试图根据Spring的RequestMapping注释方法上存在的注释来实现一些逻辑。 所以我在我的方法中有一个实例,我想问Spring“给我一个方法,它将被调用来处理这个请求”,所以我可以使用反射API来询问我的注释是否存在或不存在,所以我可以更改处理。 有没有什么简单的方法可以从Spring MVC获取这些信息?
我有一个使用Jersey编写的RESTful web服务,看起来如下所示: 问题:是否有方法接受空请求负载,并在服务器端处理它? 注意:我使用的是Jersey提供的POJO支持。
问题内容: 看来我应该这样做: 通过将其设置为来配置dispatcherServlet 但是,考虑到我没有XML配置,或者代码中没有任何各种初始化程序类(此答案提到),该怎么做? 在一个类中,我有一个像这样的方法,当前不会被调用。 Spring Boot 1.2.7.RELEASE; 一个简单的设置与Spring REST指南并没有太大区别 。 问题答案: 选项1:Spring Boot属性(仅适