API returning error: "field cannot be empty"

API returning error: "field cannot be empty"

我目前正在尝试连接 Tidal API,但遇到了一些问题。这是我的代码,我正在使用 Volley 库:

JSONObject pload = new JSONObject();
        try {
            pload.put("username", username);
            pload.put("password", password);
        } catch (JSONException e) {
            e.printStackTrace();
        }

        JsonObjectRequest request = new JsonObjectRequest(Request.Method.POST, ENDPOINT, pload, response->{
            Gson gson = new Gson();
            JSONArray data = response.optJSONArray("data");
            Log.d("RESPONSE", response.toString());
        }, error -> {
            String responseBody = null;
            try {
                responseBody = new String(error.networkResponse.data, "utf-8");
            } catch (UnsupportedEncodingException e) {
                e.printStackTrace();
            }
            Log.d("ERROR", responseBody);
        }){
            @Override
            public Map<String, String> getHeaders() throws AuthFailureError {
                Map<String, String> headers = new HashMap<>();
                headers.put("X-Tidal-Token", "q--------------------------k");
                headers.put("Content-Type", "application/json");
                return headers;
            }
        };
        mqueue.add(request);

LogCat:

 D/REQUEST: body: {"username":"b-------@gmail.com","password":"p------"} ___ headers: {X-Tidal-Token=q---------------k, Content-Type=application/json} ___ request.tostring: [ ] https://api.tidalhifi.com/v1/login/username 0xcc20303d NORMAL null
 E/Volley: [309] BasicNetwork.performRequest: Unexpected response code 400 for https://api.tidalhifi.com/v1/login/username
 D/ERROR: {"status":400,"subStatus":1002,"userMessage":"password cannot be blank,username cannot be blank"}

如您所见,有效负载不为空,所以我有点困惑。 Tidal 没有官方的 API 但有一些非官方的包装器我一直在使用以供参考,这里是一些使用过的代码示例:

Java脚本:

  request({
    method: 'POST',
    uri: '/login/username?token=kgsOOmYk3zShYrNP',
    headers: {
     'Content-Type': 'application/x-www-form-urlencoded'
    },
    form: {
      username: authInfo.username,
      password: authInfo.password,
    }

Java:

 var url = baseUrl.newBuilder()
            .addPathSegment("login")
            .addPathSegment("username")
            .build();

        var body = new FormBody.Builder()
            .add("username", username)
            .add("password", password)
            .build();

        var req = new Request.Builder()
            .url(url)
            .post(body)
            .header(TOKEN_HEADER, token)
            .build();

Java 再一次:

   HttpResponse<JsonNode> jsonResponse = restHelper.executeRequest(Unirest.post(API_URL + "login/username")
                .header("X-Tidal-Token", "wdgaB1CilGA-S_s2")
                .field("username", username)
                .field("password", password));

如果需要,我可以 post 所有包装器的链接并提供用于测试的潮汐令牌(获取它相当容易,您只需要从潮汐桌面应用程序中嗅探数据包)。我试过覆盖 getParams() 但这没有用。感谢您的帮助!

您使用了错误的格式发送请求,当您需要Url编码格式时,您使用了Json,link供参考:Send form-urlencoded parameters in post request android volley 一种解决方案:字符串请求:

final String api = "http://api.url";
final StringRequest stringReq = new StringRequest(Request.Method.POST, api, new Response.Listener<JSONObject>() {
                @Override
                public void onResponse(JSONObject response) {
                    Toast.makeText(getApplicationContext(), "Login Successful!", Toast.LENGTH_LONG).show();
  //do other things with the received JSONObject
                }
            }, new Response.ErrorListener() {
                @Override
                public void onErrorResponse(VolleyError error) {
                    Toast.makeText(getApplicationContext(), "Error!", Toast.LENGTH_LONG).show();
               }
            }) {
                @Override
                public Map<String, String> getHeaders() throws AuthFailureError {
                    Map<String, String> pars = new HashMap<String, String>();
                    pars.put("Content-Type", "application/x-www-form-urlencoded");
                    return pars;
                }

                @Override
                public Map<String, String> getParams() throws AuthFailureError {
                    Map<String, String> pars = new HashMap<String, String>();
                    pars.put("Username", "usr");
                    pars.put("Password", "passwd");
                    pars.put("grant_type", "password");
                    return pars;
                }
            };
  //add to the request queue
  requestqueue.AddToRequestQueue(stringReq);