I have an application developed in ionci, and a server application spring where my services are deployed.
Call my services work in the browser, but not via the emulator.
CODE on the server
@SpringBootApplication
@EnableWebMvc
public class SpringBootWebApplication extends WebMvcConfigurerAdapter{
public static void main(String[] args) {
SpringApplication.run(SpringBootWebApplication.class, args);
}
@Override
public void addCorsMappings(CorsRegistry registry) {
registry.addMapping("/**")
.allowedMethods("GET", "POST");
}
}
My controller
@RestController
@CrossOrigin(origins = "*")
@RequestMapping("/api")
public class WordController {
private WordService wordService;
@Autowired
public void setWordService(WordService wordService) {
this.wordService = wordService;
}
@GetMapping("/list-words-by-letter")
@CrossOrigin(origins = "*")
public Iterable<Word> getWordsBytLetter(String letter) {
return wordService.listAllWordsByLetter(letter);
}
}
Front Code index.html
<!DOCTYPE html>
<html lang="en" dir="ltr">
<head>
<meta charset="UTF-8">
<title>Ionic App</title>
<meta name="viewport" content="viewport-fit=cover, width=device-width,
initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no">
<meta name="format-detection" content="telephone=no">
<meta name="msapplication-tap-highlight" content="no">
<meta http-equiv="Content-Security-Policy" content="default-src *; img-
src * 'self' data: https:; style-src 'self' 'unsafe-inline'; script-src
'self' 'unsafe-inline' 'unsafe-eval'">
My Service
import { Injectable } from '@angular/core';
import {HttpClient, HttpErrorResponse, HttpHeaders} from '
@angular/common/http';
import { Observable } from 'rxjs';
import { catchError } from 'rxjs/operators';
import { _throw } from 'rxjs/observable/throw';
@Injectable()
export class DictionnaryService {
public API = 'http://127.0.0.1:8080';
constructor(public http: HttpClient) {
}
getAllWordsByLetter(letter: string): Observable<any> {
console.log('in getAllWordsByLetter methode service ')
let url = this.API + '/api/list-words-by-letter?letter='+letter;
let headers = new HttpHeaders().set("X-CustomHeader", "custom header
value")
.append('Content-Type', 'application/fhir+json')
.append("'Access-Control-Allow-Origin", "*")
.append("Accept", "application/fhir+json");
return this.http.get(url, { headers }).pipe(
catchError(this.handleError));
}
private handleError(error: HttpErrorResponse) {
console.log(
`Backend returned code ${error.status}, ` +
`body was: ${error.error}, ` + `error message : ${error.message},
`);
return _throw(error.message);
};
}
The log display :
07-06 12:07:20.160 25882-25882/io.ionic.starter I/chromium: [INFO:CONSOLE(208)] ****"Backend returned code 0, body was: [object ProgressEvent], error message : Http failure response for (unknown url): 0 Unknown Error, "****, source: file:///android_asset/www/build/main.js (208) 07-06 12:07:20.454 25882-25882/io.ionic.starter W/art: Attempt to remove non-JNI local reference, dumping thread
I thought it was a cors problem. But I don't know anymore.
If someone have an idea?
Thanks in advance.