当前位置: 首页 > news >正文

wordpress静态文件放到cdn保定百度seo排名

wordpress静态文件放到cdn,保定百度seo排名,官方网站链接如何做,湖南省建设局官方网站本项目旨在学习如何快速使用 nodejs 开发后端api,并为以后开展其他项目的开启提供简易的后端模版。(非后端工程师) 由于文档是代码写完之后,为了记录项目中需要注意的技术点,因此文档的叙述方式并非开发顺序&#xff0…

本项目旨在学习如何快速使用 nodejs 开发后端api,并为以后开展其他项目的开启提供简易的后端模版。(非后端工程师)
由于文档是代码写完之后,为了记录项目中需要注意的技术点,因此文档的叙述方式并非开发顺序(并非循序渐进的教学文档)。建议配合项目源码node-mongodb-template 。

【NodeJS】NodeJS+mongoDB在线版开发简单RestfulAPI (一):项目简介及安装依赖

【NodeJS】NodeJS+mongoDB在线版开发简单RestfulAPI (二):项目文件夹架构及路由的设置

【NodeJS】NodeJS+mongoDB在线版开发简单RestfulAPI (三):Cors的设置及.env文件的设置

【NodeJS】NodeJS+mongoDB在线版开发简单RestfulAPI (四):状态码的使用

【NodeJS】NodeJS+mongoDB在线版开发简单RestfulAPI (五):POST上传文件的设置

【NodeJS】NodeJS+mongoDB在线版开发简单RestfulAPI (六):token的设置

【NodeJS】NodeJS+mongoDB在线版开发简单RestfulAPI (七):MongoDB的设置

【NodeJS】NodeJS+mongoDB在线版开发简单RestfulAPI (八):API说明(暂时完结,后续考虑将在线版mongoDB变为本地版)

状态码的使用

http请求的响应结果会通过状态码来反应和归类。

分类

响应状态码通常分为5类:

100-199:信息响应

200-299:成功响应

  • 200: 请求成功,通常用在Get、Delete等请求;

  • 201: 创建成功,通常用在Post请求;

300-399:重定向

400-499:客户端错误

  • 400: 客户端错误,如语法错误、无效信息等,服务端不会处理请求;

  • 401: 身份权限错误;

  • 403: 客户端未经授权;

  • 404: 服务器无法找到请求内容;

  • 409: 请求与当前服务器状态冲突;

500-599:服务端错误

​ 500: 服务器遇到未知错误;

定义状态码的code

res.status(200).json({...}});

//GET 200
//catch err 500
const get_orders_all =(req,res,next) => {Order.find().select('product quantity _id').populate('product','name price').exec().then(docs=>{const response = {...};res.status(200).json(response);        }).catch(err=>{res.status(500).json({error:err});});
};
//POST
//创建订单
//创建前先查找是否存在对应产品
//没有返回 404
//创建成功 返回 201
//catch err 500
const create_order = (req,res,next) => {Product.findById(req.body.productId).then(product=>{if(!product){return product;}const order = new Order(...);return order.save()       }).then(result=>{if(!result){res.status(404).json({message: 'Product not found'});}else{const response = {...};res.status(201).json(response); }}) .catch(err=>{res.status(500).json({error:err});});
};
//注册账号 POST
//注册之前查找是否存在邮箱
//存在 409
//不存在,允许创建
//密码加密,加密失败 500
//成功注册 201
//catch err 500
const user_signup = (req,res,next) => {User.findOne({email: req.body.email}).exec().then(user=>{if(user){res.status(409).json({message:"Mail exists"});}else{bcrypt.hash(req.body.password,10,(err,hash) => {if(err){return res.status(500).json({err:err})}else{const user = new User(...);user.save().then(result=>{                       res.status(201).json(...);}).catch(err=>{res.status(500).json({error:err});});}})}}).catch(err=>{res.status(500).json({error:err});});
};
//用户登录 GET
//查找账户是否存在
//不存在 401
//校验密码,密码不对 401
//匹配 200
const user_login = (req,res,next) => {User.find({email: req.body.email}).exec().then(user=>{if(user.length<1){res.status(401).json({message:"Auth Failed"});}else{bcrypt.compare(req.body.password,user[0].password,(err,result) => {if(err){res.status(401).json({message:"Auth Failed"});}if(result){const token = jwt.sign({email:user[0].email,userId:user[0]._id},process.env.JWT_KEY,{expiresIn:"1h",});res.status(200).json({message:"Auth successfully",token:token,request:{type: 'POST',url: 'http://localhost:3000/user/signup',body:{email:"string",password:"string"}}});}else{res.status(401).json({message:"Auth Failed"});}})}}).catch(err=>{res.status(500).json({error:err});});
};

其他响应信息的定义

通常返回状态码的同时,还要返回一些有用信息。

如请求所有产品的信息,那么就至少需要

  • 范围一个产品数组,每个元素中包括产品的必要信息;
  • 产品的个数;
  • (可选)单个产品查询请求的url帮助

这里给出模版公参考

//GET ALL请求
const response = {count:docs.length;products:docs.map(_=>{return {name:..,price:..,_id:id,request:{type:'GET',url: 'http://localhost:3000/products/'+_._id}};});
};
//GET ONE请求
const response = {result: doc,request:{type: 'GET',url: 'http://localhost:3000/orders/'}
}
//POST请求
const response = {message:'Create order successfully' ,createdOrder: {result: {product:result.product,quantity:result.quantity,_id:result._id},request:{type: 'GET',url: 'http://localhost:3000/orders/'+result._id}}
}
//DELETE ONE删除
const response = {message:"Order deleted successfully",request:{type: 'POST',url: 'http://localhost:3000/orders/',body:{productId:"string",quantity:"Number"}}
}
//PATCH ONE修改
const response = {message:"Product updated successfully",request:{type: 'GET',url: 'http://localhost:3000/products/'+id}
}
http://www.yayakq.cn/news/909763/

相关文章:

  • 网站平台建设工作汇报wordpress 软件公司模板
  • 免费绑定域名的建站wordpress文章发布区
  • 做网站建设需要做哪些工作室昆明昌盛网络技术有限公司
  • 食品网站的网页设计wordpress wiki
  • 徐州h5模板建站在线测评网站怎么做
  • 大型门户网站建设服务国外做农产品有名的网站有哪些
  • 基于asp.net的视频网站开发注册传媒公司需要的条件
  • 扁平风格网站 模板html制作个人网页案例
  • 网站建设的展望建设完网站如何信息更新
  • 高端交互式网站建设厦门网站建设方案开发
  • 怎么做网站一张图互联网电商
  • 苏州网站建设制作公司小程序开发服务器做网站配置
  • 广州专业建网站公司如何替换网站上的动画
  • 网站排版的优点网站建设加盟招商
  • 网站做新浪图床网站登录注册页面模板下载
  • 在线做c 题的网站wordpress怎样修改域名
  • seo和网站建设那个先学小型网站维护
  • 网站深圳资源库网站建设
  • 泰安微信网站建设如何制作简单网页
  • 佛山新网站建设市场如何选择网站制作公司
  • 深圳仿站定制模板建站有域名了怎么做网站
  • 网站建设及代运营合同免费域名注册二级域名
  • 河南建设网站公司微信营销推广公司
  • 深圳移动网站建设公微信公众平台怎么做微网站
  • 如何让网站收录公司名上海的建设网站制作
  • 中企高呈网站建设西安建设工程信息网招标公告
  • 那些网站可以做淘宝店铺推广没有网站怎样做搜索引擎推广
  • 新增备案网站负责人常用个人网站是什么
  • 如何用rp做网站加强官方网站建设
  • 旅行社建网站网络推广文案前景