iis服务器助手广告广告
返回顶部
首页 > 资讯 > 服务器 >node通过express搭建自己的服务器
  • 563
分享到

node通过express搭建自己的服务器

自己的服务器node 2022-06-04 17:06:18 563人浏览 泡泡鱼
摘要

前言 为了模拟项目上线,我们就需要一个服务器去提供api给我们调用数据。这次我采用express框架去写API接口。所有请求都是通过ajax请求去请求服务器来返回数据。第一次用node写后端,基本就是摸着石

前言

为了模拟项目上线,我们就需要一个服务器去提供api给我们调用数据。这次我采用express框架去写API接口。所有请求都是通过ajax请求去请求服务器来返回数据。第一次用node后端,基本就是摸着石头的过河,文中有什么不足不处欢迎指出。

安装express框架

传送门: express官方

然后介绍一下需要引入的中间件,node本身提供了一些库。我们可以直接通过require去引用,对于未提供的库,我们也可以通过手动npm去安装


var fs = require('fs'); 操作文件模块
var Http = require('http'); http模块
var url = require('url');  获取url信息模块
var qs = require('querystring'); 处理url参数模块
var path = require('path'); 文件路径模块
var bodyParser = require('body-parser'); 请求体对象化 (必须)否则后台无法解析前端发送的body内容

接下来直接启用模块


app.use(bodyParser.JSON());

// 访问静态资源文件 这里是访问所有dist目录下的静态资源文件
app.use(express.static(path.resolve(__dirname, '../dist')))
app.use(express.static('public'));

// 因为是单页应用 所有请求都走/dist/index.html
app.get('/', function(req, res) {
 const html = fs.readFile(path.resolve(__dirname, '../dist/index.html'), 'utf-8');
 res.send(html)
});

//处理请求跨域

app.all('*', function(req, res, next) {
 res.header("Access-Control-Allow-Origin", "*");
 res.header("Access-Control-Allow-Headers", "X-Requested-With");
 res.header("Content-Type", "application/json;charset=utf-8");
 res.header("Access-Control-Allow-Headers", "content-type");
 next();
});

准备工作做完可以开始动手写接口了。关于数据库可以模拟一个json,也可以真实模拟上线数据库

下面会划成3块说明——数据库的对接、请求的操作、文件请求的操作。

数据库连接

这里我假设你已经安装了mongoDB数据库并成功启用。仔细阅读express教程你会发现框架提供了对monGodb的支持,mongodb有非常多的扩展插件去使用该数据库 比如mongoose。这里我们使用express官方提供的mongoskin来链接数据库。


$ npm install mongoskin

#####官方实例

var db = require('mongoskin').db('localhost:27017/animals');

db.collection('mamals').find().toArray(function(err, result) {
 if (err) throw err;
 console.log(result);
});

安装成功后 ,我们就首先把使用的数据库引入,代码如下


var db = require('mongoskin').db('mongodb://localhost:27017/blog');
var ObjectId = require('mongodb').ObjectID;

以上代码表示我们成功连接了blog数据库并且启用了私有ID,objectID是mongodb生成数据自动添加的ID。可以直接拿来用。到这里数据库和服务器就已经对接完毕了。

对前端发送的请求进行处理

处理get请求



app.get('/article/info', function (req, res) {
 >>> 获取请求参数
 var arg = qs.parse(url.parse(req.url).query);
 var id = arg.id;
 >>> 链接数据库根据参数查找文档并返回
 db.collection('articleList').find({ "_id": ObjectId(id)}).toArray(function(err, result) {
  if (err) throw err;
  console.log(result)
  res.end(JSON.stringify(result))
 });
});

以上代码就实现了对一个get请求的处理,通过参数模块获取了url的参数,db也就是已经连接的数据库。根据ID对‘articleList'的数据表进行搜索,处理完毕后 通过res.end()返回数据结束响应。

处理post请求



app.post('/board/post', function (req, res) {
 >>>> 获取请求参数
 var data = {
  date: req.body.date,
  name: req.body.name,
  content: req.body.content,
  time: req.body.time,
  position: req.body.position
 };
 
 >>> 链接数据库并插入数据
 
 db.collection('board').insert(data, function(err, result) {
  if(err) {
   res.end('Error:'+ err)
  }
  res.end('提交成功')
 });
});

post请求的参数获取和get不同 可以直接通过req.body去获取前端传输的请求体。通过js对象的方式去获取参数。然后根据参数执行数据库操作。到此,基本的请求也就介绍完毕了。下面说下怎么处理图片的上传此类常见的文件操作需求。

对前端的文件请求进行处理

为了简化操作,我们可以引入multer模块来处理文件,代码如下


var multer = require('multer');
var storage = multer.diskStorage({
 //设置上传后文件路径,uploads文件夹会自动创建。
 destination: function (req, file, cb) {
  cb(null, './public/uploads')
 },
 //给上传文件重命名,获取添加后缀名
 filename: function (req, file, cb) {
  var fileFORMat = (file.originalname).split(".");
  cb(null, file.fieldname + '-' + Date.now() + "." + fileFormat[fileFormat.length - 1]);
 }
});
//生成上传模块,让API调用
var upload = multer({
 storage: storage
}).single('file');

以上代码就成功引入了文件上传模块,通过该模块我们可以快速生成相应内容,具体使用方法可以查看官方文档。准备工作完成后,在项目中使用:



app.post('/upload', function (req, res) {
 upload(req, res, function (err) {
  if (err) {
   console.log(err)
   return
  }
  console.log(req.file)
  res.end(JSON.stringify(req.file))
 })
});

//图片上传到服务器 ,向客户端返回文件信息
  比如文件的存储位置,之后就可以通过地址访问服务器的图片


app.post('/image/delete', function (req, res) {
 fs.unlink(req.body.path, function(err) {
  if (err) {
   return console.error(err);
  }
  res.end("文件删除成功!");
 });
});

这里上传图片我们就直接使用了直接之前已经写好的upload模块,当该接口请求成功时 ,文件就已经上传成功了,如果你需要一个预览过程,那不应该直接调用上传接口 。通过原生node fs模块 我们也能对添加的文件进行删除,修改操作。

上线以及上线后遇到的history模式的刷新问题

上线过程我们可以当作就是换一台电脑跑程序,这里我用的是阿里云的服务器。在云服务器安装好环境好,把项目克隆进去 ,再装个forever之类的永久运行库,start ~ok 这样你的项目就永远在运行了。如果需要www访问 ,还需要买个dns解析 和域名,指向你的服务器。

以上我们如果在本地跑项目基本已经可以没问题。但项目上线后一刷新。啊啦??404什么鬼?打开百度一查。那炉火多~~当前端启用hisory模式,后台也必须开启对history的支持。express 环境如下:


var history = require('connect-history-api-fallback');
var connect = require('connect');
///////
app.use(history());

更新代码刷新~OK 完美!

总结

想学好一样东西,需要长久的积累。作为一个前端,一些服务器数据库的知识除了可以帮助我们更好的跟兄弟(后端)交流,对前端来说也是如鱼得水一般的存在。

下一篇文章准备写electron入门,electron是通过js构建桌面应用的框架,。共勉~~~~~

GitHubhttps://github.com/xu455255849/myBlog

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

--结束END--

本文标题: node通过express搭建自己的服务器

本文链接: https://www.lsjlt.com/news/12326.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • node如何通过express搭建自己的服务器
    这篇文章将为大家详细讲解有关node如何通过express搭建自己的服务器,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。安装express框架传送门: express官方...
    99+
    2024-04-02
  • Linux下怎么通过Gogs搭建自己的Github
    随着Github的逐渐普及,越来越多的人会选择在其中建立自己的项目,也就是在Github上发表自己的代码。然而,Github限制了单个账户上能建立的私人库的数量,所以一些高频使用者可能需要通过其他途径来建立自己的代码库。在这个时候,自己搭建...
    99+
    2023-10-22
  • 搭建自己的云服务器
    搭建自己的云服务器可以使用一些第三方服务,如: MySQL数据库:MySQL提供了强大的数据存储服务,可以用于管理数据,并存储文件。 Docker容器:Docker允许用户将数据和应用程序部署在不同的虚拟机中,以便可以更好地管理和协作。...
    99+
    2023-10-26
    自己的 服务器
  • 云服务器自己搭建
    云服务器是一种虚拟化平台,通常提供按需、弹性、高可用性等特点,适合在线数据中心、存储、网络、应用程序等方面运行。在自助云平台或云服务平台上搭建云服务器需要考虑以下几个关键点: 选择适当的云服务商:不同的云服务商提供的云服务器有不同的特点...
    99+
    2023-10-26
    服务器
  • 自己搭建mqtt服务器
            前言:网上资料大部分都是使用的云服务,我是采用自己搭建的服务器来进行试验的,接下来将记录过程。 一,服务器搭建         1.使用云服务器 云服务器有很多种网上也有很多教学在这里不进行过多的解释了,我实验的时候采用的阿...
    99+
    2023-09-02
    linux
  • 自己搭建云服务器
    如果您是初学者,那么创建云服务器可能有些困难。以下是一些步骤,您可以开始学习搭建云服务器: 1.选择云服务器提供商 在购买云服务器之前,您可以查看云服务器提供商的品牌和历史记录。您还可以通过查看云服务器提供商的客户反馈来确定您的需求是否适...
    99+
    2023-10-26
    服务器
  • 如何自己搭建服务器
    搭建服务器的操作步骤:打开控制面板找到Windows功能组件中的Internet信息服务进行安装更新。更新完成后,打开“Internet 信息服务管理器”创建Web网站,再打开浏览器,输入“http://localhost/”地址后按回车,...
    99+
    2024-04-02
  • 如何搭建自己的云服务器
    要搭建自己的云服务器,你可以按照以下步骤进行操作:1. 选择云服务提供商:有许多云服务提供商可供选择,你可以根据自己的需求和预算选择...
    99+
    2023-09-27
    云服务器
  • 搭建自己的云服务器教程
    搭建自己的云服务器是一个需要认真思考和实践的过程。以下是一些基本的步骤和建议: 选择云服务器提供商:首先,您应该考虑您的应用程序需要多少存储空间、带宽和其他资源来支撑它的运行。您可以通过查看云服务器提供商的官方网站来了解他们的技术支持和...
    99+
    2023-10-26
    自己的 服务器 教程
  • 怎么搭建自己的dns服务器
    要搭建自己的DNS服务器,您可以按照以下步骤进行操作:1. 选择操作系统:首先,您需要选择一个适合您的操作系统来搭建DNS服务器。常...
    99+
    2023-08-25
    dns服务器 服务器
  • 自己搭建服务器和云服务器
    如果您需要搭建服务器,可以按照以下步骤进行操作: 确定您的需求和预算,例如您需要多少台机器,您需要支付哪些服务的费用等。 选择合适的云计算供应商,包括服务器品牌、型号、服务类型和价格等。您可以参考不同云计算供应商的官方网站上的价格和性能...
    99+
    2023-10-26
    服务器
  • 怎样搭建自己的云服务器
    搭建自己的云服务器需要了解一些技术和相关的知识,以下是一些步骤和建议: 选择云服务提供商:需要选择一个可靠的、知名的云计算服务提供商,这将帮助您获得最好的服务和价格。可以通过搜索引擎或者其他可靠来源来查找相关的信息。 配置服务器环境:确...
    99+
    2023-10-26
    自己的 服务器
  • 如何搭建自己的git服务器
    要搭建自己的Git服务器,可以按照以下步骤进行操作:1. 选择操作系统:选择适合自己的操作系统作为服务器,如Linux、Window...
    99+
    2023-10-08
    git
  • 怎么搭建自己的云服务器
    搭建自己的云服务器需要注意以下几个方面: 选择合适的云服务提供商:选择能够提供可靠稳定的云服务,并确保其可以满足您的各种需求。 配置云服务器:为您的云服务器配置足够的硬件资源,包括服务器操作系统、数据库、存储空间等,以确保高性能、高可用...
    99+
    2023-10-26
    自己的 服务器
  • 自己如何搭建云服务器
    个人搭建云服务器的操作步骤:挑选云服务器供应商并进入官网。注册账户并登录。点击购买云服务器。选择云服务器配置,个人使用的话,选择”1核1G,带宽2M”配置足够。云服务器系统选择自己熟悉的即可。例如Windows和Linux系统。付款交易成功...
    99+
    2024-04-02
  • 如何自己搭建云服务器
    要自己搭建云服务器,需要按照以下步骤进行: 确定云服务器的类型:根据不同的云服务器供应商和服务平台,选择合适的服务器类型,例如Windows服务器、Linux服务器、MySQL服务器等。 规划服务器:根据所需的存储容量和计算能力,规划服...
    99+
    2023-10-26
    服务器
  • 自己怎么搭建nas服务器
    搭建 NAS 服务器需要以下步骤:1. 选择合适的硬件设备选择一台性能较好的计算机或者专门的 NAS 设备,建议配置至少 4GB 以...
    99+
    2023-06-08
    nas服务器 服务器
  • 自己搭建私有云服务器
    如果您已经拥有了私有云服务器,您可以考虑以下步骤来搭建自己的云服务器: 确定服务器的大小和需求:根据您的应用程序、数据需求,确定所需的容量和功能。 购买硬件:根据您的需求,选择合适的服务器硬件。一些常用的硬件包括CPU、内存、硬盘、带宽...
    99+
    2023-10-26
    服务器
  • 如何自己云服务器搭建
    以下是一个简单的步骤: 选择一台云服务器:您可以选择适合您需求的云计算平台,例如 Amazon Web Services (ECS)、Google Cloud Platform (GCP)。 安装所需的软件:在 GitHub 上下载云服...
    99+
    2023-10-26
    服务器
  • 自己搭建云服务器系统
    如果您需要搭建云服务器系统,可以考虑以下步骤: 确定您需要的云服务器类型、容量和价格:您需要使用多少台服务器来构建您的云平台这些服务器的需求是多少您需要多大的带宽或存储空间来存储您的数据您需要什么类型的软件和服务来支撑云平台 选择适合您...
    99+
    2023-10-26
    服务器 系统
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作