我正在尝试将表单值从Ionic2(Angular2 typescript)项目发送到我将发送联系邮件的PHP服务器.
我无法得到我应该得到的价值……
这是我的form.service.ts:
import {Injectable} from 'angular2/core'; import {Http,Response} from 'angular2/http'; import {Headers,RequestOptions} from 'angular2/http'; import {Observable} from 'rxjs/Observable'; @Injectable() export class FormService { constructor (private _http: Http) {} private _contactUrl = 'http://localhost:8888/Server/email.PHP'; // private _contactUrl = '/email'; sendMail(value: Object): Observable<any> { const body = JSON.stringify(value); let headers = new Headers(); headers.append('Content-Type','application/x-www-urlencoded'); return this._http.post(this._contactUrl,body,{ headers : headers }).map(res => res.json()); } }
我的form.ts中的onSubmit函数使用了哪个:
import { Page,NavController } from 'ionic-angular'; import { Component } from 'angular2/core'; import { FORM_DIRECTIVES,FormBuilder,ControlGroup,Validators,AbstractControl } from 'angular2/common'; import { Http,Response,Headers } from 'angular2/http'; import { Observable } from 'rxjs/Observable'; import 'rxjs/Rx'; import { FormService} from './form.service'; @Page({ templateUrl: 'build/pages/form/form.html',directives: [FORM_DIRECTIVES],providers: [FormService] }) export class Form { contactForm: ControlGroup; company: AbstractControl; name: AbstractControl; prenom: AbstractControl; phone: AbstractControl; email: AbstractControl; website: AbstractControl; message: AbstractControl; arrivee: AbstractControl; projet: AbstractControl; projets = [ { id: 1,label: 'Site Internet' },{ id: 2,label: 'Site Intranet/Extranet' },{ id: 3,label: 'Développement PHP' },{ id: 4,label: 'Développement C#' },{ id: 5,label: 'Conception Base de Données' },{ id: 6,label: 'Tiers Maintenance Applicative' },{ id: 7,label: "Recrutement d'un collaborateur Handicapé" } ]; arrivees = [ { id: 1,label: 'Internet' },label: 'Recommandation' },label: 'Evênement' } ]; response: string; value: any; constructor(public nav: NavController,fb: FormBuilder,private _http: Http,private _formService: FormService) { this.nav = nav; // New controlGroup instance this.contactForm = fb.group({ // Validators Rules for each field // Champ XXX: ['',...] correspondants au [ngFormControl]="XXX" de la vue HTML (inpput) name: ['',Validators.compose([Validators.required,Validators.minLength(3),this.checkFirstCharacterValidator])],prenom: ['',Validators.compose([Validators.minLength(3),company: ['',projet: ['',Validators.required],arrivee: ['',phone: ['',Validators.minLength(10)])],email: ['',website: ['',Validators.minLength(3)],message: ['',Validators.minLength(20)])] }); this.name = this.contactForm.controls['name']; this.prenom = this.contactForm.controls['prenom']; this.company = this.contactForm.controls['company']; this.projet = this.contactForm.controls['projet']; this.arrivee = this.contactForm.controls['arrivee'],this.phone = this.contactForm.controls['phone'],this.email = this.contactForm.controls['email'],this.website = this.contactForm.controls['website'],this.message = this.contactForm.controls['message'] } // Check if firt character is a number checkFirstCharacterValidator(control: Control): { [s: string]: boolean } { if (control.value.match(/^\d/)) { return { checkFirstCharacterValidator: true }; } } onSubmit(value) { this._formService.sendMail({value}) .subscribe( response => this.response = response,error => console.log(error) ); } }
<?PHP header('Content-type: application/json'); if ($_SERVER['REQUEST_METHOD'] == 'OPTIONS') { if (isset($_SERVER['HTTP_ACCESS_CONTROL_REQUEST_METHOD'])) header("Access-Control-Allow-Methods: GET,POST,OPTIONS"); if (isset($_SERVER['HTTP_ACCESS_CONTROL_REQUEST_HEADERS'])) header("Access-Control-Allow-Headers: {$_SERVER['HTTP_ACCESS_CONTROL_REQUEST_HEADERS']}"); exit(0); } $value = json_decode(file_get_contents('PHP://input')); // for test echo $value->name; ?>
我检查了chrome的控制台,我得到了一些东西:
Screenshot from console
我怎样才能将angular2的帖子发送到我的PHP中?我错过了什么吗?
我可以在你的代码中看到两个问题:
>使用JSON.stringify创建JSON内容但是对于表单,您需要使用URLSearchParams类或手动创建字符串内容.
>您的内容类型值不正确.它是application / x-www-form-urlencoded而不是application / x-www-urlencoded.
以下是您应该使用的内容:
sendMail(value: Object): Observable<any> { const body = new URLSearchParams(); Object.keys(value).forEach(key => { body.set(key,value[key]); } let headers = new Headers(); headers.append('Content-Type','application/x-www-form-urlencoded'); return this._http.post(this._contactUrl,body.toString(),{ headers : headers }).map(res => res.json()); }