[英]Send formData POST request with string parameter
我有Loopback API,我想發送POST請求。 API需要這樣做:
在android中,我這樣做:
public static Api getRetrofit(String token) {
OkHttpClient.Builder httpClient = new OkHttpClient.Builder();
httpClient.addInterceptor(chain -> {
Request original = chain.request();
Request.Builder builder = original.newBuilder()
.addHeader("x-access-token", token)
.method(original.method(),original.body());
return chain.proceed(builder.build());
});
String token = mEtToken.getText().toString();
String password = mEtPassword.getText().toString();
User user = new User();
user.setNewPassword(password);
resetPasswordFinishProgress(user);
它有效。
現在,在HTML表單的網站上,我有一個javascript函數,在其中我發送請求的地方,我從API獲得響應消息,代碼400
說:
{"error":{"statusCode":400,"name":"Error","message":"newPassword is a required argument","stack":"Error: newPassword is a required argument\\n
這是功能:
function post() {
const urlParams = new URLSearchParams(window.location.search);
const token = urlParams.get('access_token');
console.log("TOKEN:", token);
const user = {
newPassword: document.querySelector('#input-password-check').value,
}
const http = new XMLHttpRequest()
http.open('POST', 'https://www.example.com/Users/reset-password')
http.setRequestHeader('x-access-token', token)
http.send(JSON.stringify(user))
console.log(JSON.stringify(user))
http.onload = function() {
alert(http.responseText)
}
}
日志打印此:
{"newPassword":"mypass"}
我究竟做錯了什么? 它看起來和我在android中一樣。
如果有幫助,這是來自Loopback API的CURL調用:
curl -X POST --header 'Content-Type: application/x-www-form-urlencoded' --header 'Accept: application/json' -d 'newPassword=s' 'https://www.example.com:3000/Users/reset-password?access_token=qRBj0mQYB8MHz6p8MHz68MHz6RBj0mQYB8MHz6RBj0mQYB8MHz6
我自己發現了這個問題。
我只有授權標頭集,服務器端沒有得到我發送json
內容,我不得不再添加一個標題Content-Type
:
const http = new XMLHttpRequest()
http.open('POST', 'https://www.example.com/Users/reset-password')
http.setRequestHeader('x-access-token', token)
http.setRequestHeader('Content-Type', 'application/json')
http.send(JSON.stringify(user))
console.log(JSON.stringify(user))
http.onload = function() {
alert(http.responseText)
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.