angular http 客户端在本地调用节点后端时不起作用?

问题描述

尝试使用 angular http 客户端调用 nodejs 本地主机,但它没有命中后端我在 angular 应用程序的 proxy.config添加了 url,因为我在问题中添加了任何想法都不起作用?

角度服务.ts

import { Injectable } from '@angular/core';
import { HttpClient,HttpHeaders } from '@angular/common/http';
import { Observable } from 'rxjs';

@Injectable({providedIn: 'root'})
export class AdminService {

  constructor(private http: HttpClient) { }

  private  url = "http://localhost:9001/api/saveClients";

  saveClientJobs(data) {
        let options = this.createRequestOptions();
        console.log("Service",data);
        return this.http.post(this.url,data,{ headers: options });
    }

    private createRequestOptions() {
        let headers = new HttpHeaders({
            "Content-Type": "application/json"
        });
        return headers;
    }
}

角度代理.config.json

{
  "/api/*":{
      "target":"http://localhost:9001","secure":false,"logLevel":"debug","changeOrigin": true
  }
}

NodeJs 路由

"use strict";
Object.defineProperty(exports,"__esModule",{ value: true });
const admin_controller_1 = require("./api/admin/admin.controller");
class RegisterRouteClass {
    RegisterRoutes(app) {
        app.post('/api/saveClients',admin_controller_1.AdminController.save);
       
    }
}
exports.RegisterRouteClass = RegisterRouteClass;

解决方法

为了执行 post/get,您需要订阅它。如果您不订阅 post/get,它将永远不会执行,因此在开发者工具的网络选项卡中不会输出任何内容。

saveClientJobs(data).subscribe(result => /* do something with the result */)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...