0
我在後端使用Node.js,並且需要在GET請求的頭部中發送一些參數(參數)和一個jwt令牌(用於授權)。 我在節點服務器上使用express-jwt模塊。該請求需要在那裏使用jwt令牌進行授權。簡單地將令牌作爲參數發送不起作用。在Volley請求中添加JWT令牌
private void getInfo(final String instanceId, final String token) {
//token is jwt token
StringRequest strReq = new StringRequest(Request.Method.GET,
Config.URL_GET_ID_INFO, new Response.Listener<String>() {
@Override
public void onResponse(String response) {
Log.d(TAG, response);
try {
JSONObject responseObj = new JSONObject(response);
boolean error = responseObj.getBoolean("error");
String message = responseObj.getString("message");
if (!error) {
Toast.makeText(getApplicationContext(), message, Toast.LENGTH_SHORT).show();
} else {
Toast.makeText(getApplicationContext(),
"Error: " + message,
Toast.LENGTH_LONG).show();
}
// hiding the progress bar
//progressBar.setVisibility(View.GONE);
} catch (JSONException e) {
Toast.makeText(getApplicationContext(),
"Error: " + e.getMessage(),
Toast.LENGTH_LONG).show();
// progressBar.setVisibility(View.GONE);
}
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
Log.e(TAG, "Error: " + error.getMessage());
Toast.makeText(getApplicationContext(),
error.getMessage(), Toast.LENGTH_SHORT).show();
//progressBar.setVisibility(View.GONE);
}
}) {
@Override
protected Map<String, String> getParams() {
Map<String, String> params = new HashMap<String , String>();
params.put("instanceId", instanceId);
//Need to send jwt along with params, but do not know how to include it in the request.
Log.e(TAG, "Posting params: " + params.toString());
return params;
}
};
// Adding request to request queue
MyApplication.getInstance().addToRequestQueue(strReq);
}
`
你確定服務器沒想到在你的請求頭令牌?在請求正文中發送令牌是非常不尋常的。通常你會做'''RequestObject.addHeader(「auth-token」,token)''' – Devnetics
然後服務器端用'''const token = req.headers [「token」]來驗證。 //繼續處理標記''' – Devnetics