美文网首页
从零搭建koa服务并允许跨域

从零搭建koa服务并允许跨域

作者: minusplus | 来源:发表于2019-08-25 21:08 被阅读0次
  1. 创建一个空文件夹,打开命令窗口,cd进入文件夹
  2. 运行npm init -y,初始化npm项目
  3. 运行 npm i -S koa 安装koa模块
  4. 创建 app.js 文件,内容如下
const Koa = require("koa");

const app = new Koa();

// port host
const port = process.env.PORT || 9000;
const host = process.env.host || 'localhost';

app.listen(port,host,()=>console.log("The service is running on http://"+host+":"+port));

到此一个简单的koa服务已经搭建好了,在命令窗口输入 node app.js 就可以启动服务了,下面配置路由

  1. 运行 npm i -S koa-router 安装路由模块,并配置路由
const Koa = require("koa");
const Router = require("koa-router");//导入路由模块
const app = new Koa();
const router = new Router();//创建路由实例
// port host
const port = process.env.PORT || 8080;
const host = process.env.host || 'localhost';
// router
router.get("/",async ctx => {
    ctx.body = 'hello world!';
})
router.get("/hello",async ctx=>{
    ctx.body = {name:"hello"}
})
app.use(router.routes());
app.use(router.allowedMethods());

app.listen(port,host,()=>console.log("The service is running on http://"+host+":"+port));

到此路由配置结束,启动服务,在浏览器输入 http://localhost:8080 就可以看到熟悉的 hello world 了。

  1. 配置跨域,安装 koa2-cors 模块,修改 app.js 如下:

const Koa = require("koa");//导入koa模块
const Router = require("koa-router");//导入路由模块
const cors = require("koa2-cors");//导入跨域模块

const app = new Koa();//创建koa实例
const router = new Router();//创建路由实例

// 定义允许跨域的origin
const allowOrigins = [
    "http://192.168.0.1:8082",
    "http://192.168.0.1:8083"
];
app.use(cors({
    origin: function(ctx) {
      if (allowOrigins.includes(ctx.header.origin)) {
        return ctx.header.origin;
      }
      return false;
    },
    exposeHeaders: ['WWW-Authenticate', 'Server-Authorization'],
    maxAge: 5,
    credentials: true,
    withCredentials:true,
    allowMethods: ['GET', 'POST', 'DELETE'],
    allowHeaders: ['Content-Type', 'Authorization', 'Accept'],
}));

// port host
const port = process.env.PORT || 9000;
const host = process.env.host || 'localhost';

// router
router.get("/",async ctx => {
    console.log(111)
    ctx.body = '{msg:"hello"}';
})
router.get("/list",async ctx=>{
    ctx.body = "helloa "
})
app.use(router.routes());
app.use(router.allowedMethods());

app.listen(port,host,()=>console.log("The service is running on http://"+host+":"+port));

至此跨域就已经配置完成了。

  1. 最后配置应用程序自动重启,运行 npm i -D nodemon 安装 nodemon 模块,并且修改 package.json 文件如下:
"scripts": {
    "dev": "nodemon ./app.js"
}

直接运行 npm run dev 就可以了,每一次修改文件内容 应用程序都会自动重启。ok,结束。

相关文章

  • 从零搭建koa服务并允许跨域

    创建一个空文件夹,打开命令窗口,cd进入文件夹 运行npm init -y,初始化npm项目 运行 npm i ...

  • Koa代理Http请求

    Koa 代理http请求,解决跨域问题 1、为什么用Koa做跨域代理? "最初为了解决跨域问题,我把站点部署到了n...

  • koa设置跨域访问以及跨域验证cookie

    环境 后端框架: koa2 前端请求框架: axios 解决跨域访问 koa加上如下代码: 解决跨域验证cooki...

  • koa2 允许跨域

    参考文章: https://www.cnblogs.com/fangshidaima/p/10495890.htm...

  • Vue——代理服务器、Bootstrap

    Vue开发模式跨域解决与代理服务器配置我们从服务器拿数据,跨域的拿不到,于是搭建个代理服务器,中转一下,就可以解决...

  • 前端跨域

    CORS跨域 1.CORS跨域-服务端设置,前端直接调用说明:后台允许前端某个站点进行访问 2.JSONP跨域-前...

  • PM2+KOA2+ES6 :pm2运行编译es6的方法

    近期,公司的官网要添加与后台的交互请求,考虑到跨域等问题,我用了koa2搭建的node服务。后来头儿甩给了我一份关...

  • Nodejs 设置跨域

    设置允许所有域名跨域: 设置允许指定域名“http://www.tefang.cn”跨域: 设置允许多个域名跨域:...

  • Asp.Net Core CORS

    前言 CORS(跨域资源共享)是一种W3C标准,允许服务器放宽同源策略。使用CORS,服务器可以在显式允许某些跨域...

  • 如何解决跨域问题?

    理解跨域的概念:协议、域名、端口都相同才同域,否则都是跨域 出于安全考虑,服务器不允许ajax跨域获取数据,但是可...

网友评论

      本文标题:从零搭建koa服务并允许跨域

      本文链接:https://www.haomeiwen.com/subject/stikectx.html