2016-03-03 41 views
2

目前,我正在使用Android与Retrofit 2.0.0-beta4和OkHttp3。我做的定义是这么@PUT要求:将@PUT与改进版2和OkHttp3一起使用

@Headers({ 
     Constants.CONTENT_TYPE_HEADER + ": " + Constants.JSON_HEADER_VAL, 
     Constants.ACCEPT_HEADER + ": " + Constants.JSON_HEADER_VAL 
}) 
@PUT(Constants.PUT_SKILL_LEVEL) 
Call<EmployeeSkill> updateEmpSkillLevel(@Header(Constants.SESSION_COOKIE_NAME) String cookieValue, @Body EmployeeSkillRequest employeeSkillUpdate); 

终点放在这里:http://apps:8080/employeeSkillsService/employeeSkill。下面是从PUT请求输出日志:

D/OkHttp﹕ --> PUT http://apps:8080/employeeSkillsService/employeeSkill http/1.1 
D/OkHttp﹕ Content-Type: application/json;charset=UTF-8 
D/OkHttp﹕ Content-Length: 99 
D/OkHttp﹕ Accept: application/json 
D/OkHttp﹕ JSESSIONID: D147377AB60AFE499D2A1AAF7C93F7A3 
D/OkHttp﹕ {"employee":{"id":63},"skill":{"isPrimary":false,"isSecondary":false,"id":3},"skillLevel":{"id":5}} 
D/OkHttp﹕ --> END PUT (99-byte body) 
<-- 404 Not Found http://apps:8080/employeeSkillsService/app.html (23ms) 
D/OkHttp﹕ Server: Apache-Coyote/1.1 
D/OkHttp﹕ X-Content-Type-Options: nosniff`D/OkHttp﹕ X-XSS-Protection: 1; mode=block` 
D/OkHttp﹕ X-XSS-Protection: 1; mode=block 
D/OkHttp﹕ Cache-Control: no-cache, no-store, max-age=0, must-revalidate 
D/OkHttp﹕ Pragma: no-cache 
D/OkHttp﹕ Expires: 0 
D/OkHttp﹕ X-Frame-Options: DENY 
D/OkHttp﹕ Content-Type: text/html;charset=utf-8 
D/OkHttp﹕ Content-Language: en 
D/OkHttp﹕ Content-Length: 1029 
D/OkHttp﹕ Date: Mon, 07 Mar 2016 15:39:35 GMT 
D/OkHttp﹕ OkHttp-Sent-Millis: 1457365206407 
D/OkHttp﹕ OkHttp-Received-Millis: 1457365206412 
D/OkHttp﹕ <html><head><title>Apache Tomcat/7.0.52 (Ubuntu) - Error report</title><style><!--H1 
{font-family:Tahoma,Arial,sans-serif;color:white;background-color:#525D76;font-size:22px;} H2 
{font-family:Tahoma,Arial,sans-serif;color:white;background-color:#525D76;font-size:16px;} H3 
{font-family:Tahoma,Arial,sans-serif;color:white;background-color:#525D76;font-size:14px;} BODY {font-family:Tahoma,Arial,sans-serif;color:black;background-color:white;} B{font-family:Tahoma,Arial,sans-serif;color:white;background-color:#525D76;} P {font-family:Tahoma,Arial,sans-serif;background:white;color:black;font-size:12px;}A {color : black;}A.name {color : black;}HR {color : #525D76;}--></style> </head><body><h1>HTTP Status 404 - /employeeSkillsService/app.html</h1><HR size="1" noshade="noshade"><p><b>type</b> Status report</p><p><b>message</b> <u>/employeeSkillsService/app.html</u></p><p><b>description</b> <u>The requested resource is not available.</u></p><HR size="1" noshade="noshade"><h3>Apache Tomcat/7.0.52 (Ubuntu)</h3></body></html> 
D/OkHttp﹕ <-- END HTTP (1029-byte body) 

我在邮差证实在Chrome这个端点与这些报头和有效载荷的作品多次。然而,当我使用Retrofit时,尽管端点在Postman中工作,我仍然收到404错误。下面是代码调用:

Call<EmployeeSkill> updateEmployeeSkillCall = RetrofitApiRestClient.getApiClient().updateEmpSkillLevel(cookieValue, employeeSkillUpdate); 

updateEmployeeSkillCall.enqueue(new Callback<EmployeeSkill>() { 

    @Override 
    public void onResponse(Call<EmployeeSkill> call, Response<EmployeeSkill> response) { 
     // called when response HTTP status is "200 OK" 
     if (response.isSuccess()) { 
      holder.spnSkillLevel.setTag(pos); 
      Toast.makeText(mContext, holder.tvSkillName.getText() + mContext.getString(R.string.skill_updated_success_text) 
       + holder.spnSkillLevel.getSelectedItem().toString(), Toast.LENGTH_LONG).show(); 

      List<EmployeeSkill> updateEmployeeSkillsRow = EmployeeSkill.find(EmployeeSkill.class, "employee = ? and skill = ?", 
       response.body().getEmployee().getId().toString(), response.body().getSkill().getId().toString()); 

      EmployeeSkill updatedSkill = updateEmployeeSkillsRow.get(0); 
      updatedSkill.setSkillLevel(response.body().getSkillLevel()); 
      updatedSkill.setTimeUpdated(response.body().getSkillLevel().getTimeUpdated()); 
      updatedSkill.save(); 
     } 
    } 

    @Override 
    public void onFailure(Call<EmployeeSkill> call, Throwable throwable) { 
     Toast.makeText(mContext, holder.tvSkillName.getText() + mContext.getString(R.string.skill_update_failed_text), Toast.LENGTH_LONG).show(); 
    } 
}); 

我试图改变所述@Body参数JSON字符串,但我接收到指出,JSON必须以与阵列或对象开始一个错误。在这个问题上的任何帮助将是有益的。如果没有这个功能,如果找不到解决方案,我将被迫删除Retrofit,而我并不真的期望这样做。

+0

您确定该方法是PUT而不是POST吗?你可以发布使用改造的请求吗?如果Web服务希望方法不是PUT(即POST,GET),即使URL和标头都是正确的,你也会得到一个404。 – Luis

+0

我可以验证PUT在使用邮递员时的确切JSON有效负载的工作。但这是令人困惑的部分。 “404”不应该发生。这里是使用Retrofit的响应:'D/OkHttp:< - 404 Not Found http:// apps:8080/employeeSkillsService/app.html(27ms)' – Chronos01

+0

尝试使用RequestBody以及得到相同的响应 – Chronos01

回答

0

使用Fiddler2解决了我自己的问题。如果cookie名称和值不正确。邮差可能更容忍它如何发送东西,而不是改造和其他人这样做。但是从中学到了一些东西。感谢所有的帮助。