Próbuję wysłać żądanie POST, ale nie mogę go uruchomić:
testRequest() {
var body = 'username=myusername?password=mypassword';
var headers = new Headers();
headers.append('Content-Type', 'application/x-www-form-urlencoded');
this.http
.post('/api',
body, {
headers: headers
})
.subscribe(data => {
alert('ok');
}, error => {
console.log(JSON.stringify(error.json()));
});
}
Zasadniczo chcę replikować to żądanie http (nie ajax), tak jakby zostało zapoczątkowane przez formularz HTML:
URL: / api
Params: nazwa użytkownika i hasło
typescript
angular
Krzysztof
źródło
źródło
user_name
ipassword
, stackoverflow.com/a/45879409/2803344Odpowiedzi:
Myślę, że
application/x-www-form-urlencoded
treść nie jest poprawna dla typu zawartości. Możesz spróbować użyć tego:var body = 'username=myusername&password=mypassword';
Mam nadzieję, że ci to pomoże, Thierry
źródło
import { URLSearchParams } from "@angular/http"
nie jest to domyślny, więc 1) nie musisz na nim robić.toString
i 2) nie musisz ustawiać typu zawartości. Angular wywnioskuje to automatycznie (patrz github.com/angular/angular/blob/4.4.4/packages/http/src/… )Aktualizacja dla Angualar 4.3+
Teraz możemy użyć
HttpClient
zamiastHttp
Przewodnik jest tutaj
Przykładowy kod
const myheader = new HttpHeaders().set('Content-Type', 'application/x-www-form-urlencoded') let body = new HttpParams(); body = body.set('username', USERNAME); body = body.set('password', PASSWORD); http .post('/api', body, { headers: myheader), }) .subscribe();
Przestarzałe
Lub możesz to zrobić:
let urlSearchParams = new URLSearchParams(); urlSearchParams.append('username', username); urlSearchParams.append('password', password); let body = urlSearchParams.toString()
Aktualizacja październik / 2017
Od angular4 + , nie potrzebujemy
headers
, lub.toString()
pasz. Zamiast tego możesz zrobić jak poniżej przykładimport { URLSearchParams } from '@angular/http';
Metoda POST / PUT
let urlSearchParams = new URLSearchParams(); urlSearchParams.append('username', username); urlSearchParams.append('password', password); this.http.post('/api', urlSearchParams).subscribe( data => { alert('ok'); }, error => { console.log(JSON.stringify(error.json())); } )
GET / DELETE metoda
let urlSearchParams = new URLSearchParams(); urlSearchParams.append('username', username); urlSearchParams.append('password', password); this.http.get('/api', { search: urlSearchParams }).subscribe( data => { alert('ok'); }, error => { console.log(JSON.stringify(error.json())); } )
Dla typu
application/json
zawartości JSONthis.http.post('/api', JSON.stringify({ username: username, password: password, })).subscribe( data => { alert('ok'); }, error => { console.log(JSON.stringify(error.json())); } )
źródło
import { URLSearchParams } from "angular2/http"
W późniejszych wersjach Angular2 nie ma potrzeby ręcznego ustawiania
Content-Type
nagłówka i kodowania treści, jeśli przekazujesz obiekt odpowiedniego typu jakobody
.Po prostu możesz to zrobić
import { URLSearchParams } from "@angular/http" testRequest() { let data = new URLSearchParams(); data.append('username', username); data.append('password', password); this.http .post('/api', data) .subscribe(data => { alert('ok'); }, error => { console.log(error.json()); }); }
W ten sposób angular zakoduje dla Ciebie body i ustawi poprawny
Content-Type
nagłówek.PS Nie zapomnij importować
URLSearchParams
z@angular/http
lub to nie zadziała.źródło
FormData
, a kątowy ustawiszContent-Type
jakomultipart/form-data
który również działa.żeby była to pełna odpowiedź:
login(username, password) { var headers = new Headers(); headers.append('Content-Type', 'application/x-www-form-urlencoded'); let urlSearchParams = new URLSearchParams(); urlSearchParams.append('username', username); urlSearchParams.append('password', password); let body = urlSearchParams.toString() return this.http.post('http://localHost:3000/users/login', body, {headers:headers}) .map((response: Response) => { // login successful if there's a jwt token in the response console.log(response); var body = response.json(); console.log(body); if (body.response){ let user = response.json(); if (user && user.token) { // store user details and jwt token in local storage to keep user logged in between page refreshes localStorage.setItem('currentUser', JSON.stringify(user)); } } else{ return body; } }); }
źródło
Te odpowiedzi są nieaktualne dla osób korzystających z HttpClient zamiast Http. Zacząłem szaleć, myśląc: „Zaimportowałem URLSearchParams, ale nadal nie działa bez .toString () i jawnego nagłówka!”
W przypadku HttpClient użyj HttpParams zamiast URLSearchParams i zanotuj
body = body.append()
składnię, aby uzyskać wiele parametrów w treści, ponieważ pracujemy z niezmiennym obiektem:login(userName: string, password: string): Promise<boolean> { if (!userName || !password) { return Promise.resolve(false); } let body: HttpParams = new HttpParams(); body = body.append('grant_type', 'password'); body = body.append('username', userName); body = body.append('password', password); return this.http.post(this.url, body) .map(res => { if (res) { return true; } return false; }) .toPromise(); }
źródło
Jeśli ktoś boryka się z wersją kątową 4+ (u mnie było 4.3.6) . To był przykładowy kod, który działał dla mnie.
Najpierw dodaj wymagane importy
import { Http, Headers, Response, URLSearchParams } from '@angular/http';
Następnie dla funkcji API. To próbka logowania, którą można zmienić zgodnie ze swoimi potrzebami.
login(username: string, password: string) { var headers = new Headers(); headers.append('Content-Type', 'application/x-www-form-urlencoded'); let urlSearchParams = new URLSearchParams(); urlSearchParams.append('email', username); urlSearchParams.append('password', password); let body = urlSearchParams.toString() return this.http.post('http://localhost:3000/api/v1/login', body, {headers: headers}) .map((response: Response) => { // login successful if user.status = success in the response let user = response.json(); console.log(user.status) if (user && "success" == user.status) { // store user details and jwt token in local storage to keep user logged in between page refreshes localStorage.setItem('currentUser', JSON.stringify(user.data)); } }); }
źródło
angular: MethodName(stringValue: any): Observable<any> { let params = new HttpParams(); params = params.append('categoryName', stringValue); return this.http.post('yoururl', '', { headers: new HttpHeaders({ 'Content-Type': 'application/json' }), params: params, responseType: "json" }) } api: [HttpPost("[action]")] public object Method(string categoryName)
źródło
Miałem problemy z każdym podejściem wykorzystującym wiele parametrów, ale działa to całkiem dobrze z jednym obiektem
api:
[HttpPut] [Route("addfeeratevalue")] public object AddFeeRateValue(MyValeObject val)
kątowy:
var o = {ID:rateId, AMOUNT_TO: amountTo, VALUE: value}; return this.http.put('/api/ctrl/mymethod', JSON.stringify(o), this.getPutHeaders()); private getPutHeaders(){ let headers = new Headers(); headers.append('Content-Type', 'application/json'); return new RequestOptions({ headers: headers , withCredentials: true // optional when using windows auth }); }
źródło
Wylądowałem tutaj, kiedy próbowałem zrobić podobną rzecz. W przypadku typu zawartości application / x-www-form-urlencoded możesz spróbować użyć tego dla treści:
var body = 'username' =myusername & 'password'=mypassword;
z tym, co próbowałeś zrobić, wartość przypisana do body będzie ciągiem.
źródło