Как подключить интерфейс Angular к серверу Java Servlet с помощью HTTP и REST? - PullRequest
0 голосов
/ 19 июня 2019

Я пытаюсь вызвать внутренний механизм, написанный на Java.Серверная часть - это сервлет, который принимает запросы REST.Механизм вызова - это угловой компонент, который отправляет HTTP-запросы.К сожалению, у меня нет возможности узнать, отправляются ли запросы или нет, только то, что сервлет не получает запросы.

Сервлет:

package services;

import javax.ws.rs.Consumes;
import javax.ws.rs.GET;
import javax.ws.rs.POST;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Response;

import objects.*;

@Path("/player")
public class PlayerService {

    @GET
    @Path("/get")
    @Produces(MediaType.APPLICATION_JSON)
    public String getTrackInJSON() {

        return "Get success";

    }

    @POST
    @Path("/post")
    @Consumes(MediaType.APPLICATION_JSON)
    public Response registerNewPlayer(PlayerRegisterRequest new_player) {

        String result = "Player saved : " + new_player;
        return Response.status(201).entity(result).build();

    }

}

Компонент:

import { Component, OnInit } from '@angular/core';
import { Injectable } from '@angular/core';
import { NgForm } from '@angular/forms';
import { HttpClient, HttpHeaders } from '@angular/common/http';
import { Observable, of } from 'rxjs';
import { catchError, map, tap } from 'rxjs/operators';
import { NewPlayer } from './new-player';


const httpOptions = {
  headers: new HttpHeaders({ 'Content-Type': 'application/json' })
};

@Component({
  selector: 'app-players-register',
  templateUrl: './players-register.component.html',
  styleUrls: ['./players-register.component.css']
})


export class PlayersRegisterComponent implements OnInit {

  private registrationUrl = 'http://localhost:8080/arenamaster-backend/api/player/post';
  private getUrl = 'http://localhost:8080/arenamaster-backend/api/player/get';

  constructor(private http: HttpClient) { 

  }

  ngOnInit() {
  }

  model = new NewPlayer( '', '', '');

  onSubmit(f: NgForm) { 
    console.log(this.model.username);
    console.log(this.model.password);
    console.log(this.model.email);
    this.sendForm(this.model);
  }

  sendForm(form: NewPlayer): Observable<string>{
    console.log('attempting to send form');
    console.log(this.http.get<string>(this.getUrl));
        return this.http.post<NewPlayer>(this.registrationUrl, form, httpOptions).pipe(
            tap((form: NewPlayer) => this.log(`added new player w/ user=${form.username}`)),
            catchError(this.handleError<NewPlayer>('sendForm'))
        );
  }

  private handleError<T> (operation = 'operation', result?: T) {
      return (error: any): Observable<T> => {

        // TODO: send the error to remote logging infrastructure
        console.error(error); // log to console instead

        // TODO: better job of transforming error for user consumption
        this.log(`${operation} failed: ${error.message}`);

        // Let the app keep running by returning an empty result.
        return of(result as T);
      };
   }
}

Как настроить один или оба параметра таким образом, чтобы сервлет Java печатал то, что я ввел в компонент Angular?

1 Ответ

0 голосов
/ 19 июня 2019

Вам необходимо подписаться на this.sendForm(this.model) Наблюдаемые

this.sendForm(this.model).subscribe();
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...