Node Koa Cors не работает - PullRequest
       13

Node Koa Cors не работает

0 голосов
/ 08 мая 2018

использовать коа + реакция server.js

руководство от npm koa

const Koa = require("koa");
const KoaRouter = require("koa-router");
const static = require("koa-static");
const cors = require('koa2-cors');
const fs = require("fs");
const path = require("path");
const Promise = require("bluebird");
const cheerio = require("cheerio");
const readFileAsync = Promise.promisify(fs.readFile);

// koa & koa router 
var app = new Koa();
var router = new KoaRouter();

app.use(cors());

async function loadHtml(path) {
    try {
        let content = await readFileAsync(path);
        return cheerio.load(content);
    } catch (e) {
        return false;
    }
}

router.get("/", async (ctx, next) => {
    console.log("index page");
    const $html = await loadHtml(path.resolve(__dirname, "/index.html"));
    if (!$html) {
        ctx.body = "Interal Server Error...";
    }else {
        // console.log($html);
        ctx.body = $html.html();
    }
});

app.use(static(path.join(__dirname, "./dist")))

app.use(router.routes()).use(router.allowedMethods());

app.listen(3001, () => {
    console.log("server start at 3001.");
});

и тестовый компонент UserList

class UserList extends React.Component {
    constructor() {
        super();
        this.state = {}
    }

    handleOnClick() {
        // let div = $("#user-list-div");
        let url = "http://localhost:9001/koa/users";
        $.get(url, function(data, status){
            alert("data: " + data + "\nstatus: " + status);
        });
    }

    render() {
        return <div id="user-list-div" onClick={this.handleOnClick}> user list div. </div>;
    }
}

в методе: handleOnClick, попробуйте запросить информацию из API отдыха (spring-boot), но все равно получена ошибка:

No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://127.0.0.1:3001' is therefore not allowed access. почему?

1 Ответ

0 голосов
/ 08 мая 2018

На основании примера, показанного на https://github.com/evert0n/koa-cors/blob/master/examples/custom-options.js,, я бы попытался добавить следующую опцию CORS в ваш код server.js, чтобы разрешить запросы, поступающие из всех источников.

var options = {
    origin: '*'
};

app.use(cors(options));

Параметр origin контролирует заголовок Access-Control-Allow-Origin, который упоминается в вашем сообщении об ошибке.

...