nginx

关注公众号 jb51net

关闭
首页 > 网站技巧 > 服务器 > nginx > nginx搭建前后端分离架构

nginx如何搭建前后端分离架构

作者:赵忠洋

本文介绍了如何使用Vue-cli搭建前端开发环境,并详细讲解了nginx、webpack-devserver和Postman的使用方法,此外,还介绍了API基本设计规范,包括HTTP状态码、数据格式和接口设计

本人用的是vue-cli 自动构建vue+webpack 项目,这里不对webpack、nginx进行讲解。

本文主要解决前端开发环境搭建、测试环境搭建、生产环境搭建以及接口调试

需要工具

nginx的环境搭建

nginx.conf 文件配置

开发环境

http{
    server {
	    #配置端口号
        listen 9999;
        #配置server_name
        server_name 127.0.0.1;
        #设置默认页面 地址为webpack-devserver地址
        location = / {
            proxy_pass http://127.0.0.1:8888/#/home;
        }
        #这里因为我的的vue-router 所以将带#号的请求转发到本地服务器
        location ~ .*#.*$ {
            proxy_pass http://127.0.0.1:8888;
        }
        #请求网页 图片 icon 等都会转发到本地服务器上
        location ~ .*\.(js|css|htm|html|gif|jpg|jpeg|png|bmp|swf|ico|rar|zip|txt|flv|mid|doc|ppt|pdf|xls|mp3|wma|eot|woff|ttf|svg)$ {
            proxy_pass http://127.0.0.1:8888;
        }
        #请求后端接口的服务器地址
        location ~ .*$ {
            proxy_pass http://10.10.1.135:8080;
        }
    }
}

测试环境

http{
    server {
	    #配置端口号
        listen 9999;
        #配置server_name
        server_name 127.0.0.1;
        #设置默认页面 root 为静态文件目录
        location = / {
            index  index.html;
            root /html;
        }
        #请求网页 图片 icon 等都会转发到nginx静态目录下
        location ~ .*\.(js|css|htm|html|gif|jpg|jpeg|png|bmp|swf|ico|rar|zip|txt|flv|mid|doc|ppt|pdf|xls|mp3|wma|eot|woff|ttf|svg)$ {
            root /html;
        }
        #请求后端接口的服务器地址
        location ~ .*$ {
            proxy_pass http://10.10.1.135:8080;
        }
    }
}

生产环境搭建

http{
    server {
	    #配置端口号
        listen 80;
        #配置server_name
        server_name www.xxx.com;
        #设置默认页面 root 为静态文件目录
        location = / {
            index  index.html;
            root /html;
        }
        #请求网页 图片 icon 等都会转发到nginx静态目录下
        location ~ .*\.(js|css|htm|html|gif|jpg|jpeg|png|bmp|swf|ico|rar|zip|txt|flv|mid|doc|ppt|pdf|xls|mp3|wma|eot|woff|ttf|svg)$ {
	        proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header REMOTE-HOST $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            root /html;
        }
        #请求后端接口的服务器地址
        location ~ .*$ {
            proxy_pass http://api.xxx.com;
        }
    }
}

POSTman 接口调试

get方式

ps:get请求参数可以写在url里边 也可以写在 下方的key value 里

post方式

ps:get请求参数可以写在url里边 

为什么使用postman

api基本设计规范

接口说明

返回状态码说明

通过HTTP Status Code来说明 API 请求是否成功 下面的表格中展示了可能的HTTP Status Code以及其含义

状态码含义说明
200ok请求成功
201CREATED创建成功
202ACCEPTED更新成功
401UNAUTHORIZED未授权/未登录
403FORBIDDEN被禁止访问
404NOT FOUND请求资源不存在
500INTERNAL SERVER ERROR服务器内部错误

通用错误代码(具体使用要api文档中给出)

状态码含义说明
999unknow_v2_error未知错误
1000need_permission需要权限
1001uri_not_found资源不存在
1002missing_args参数不全
1003image_too_large上传的图片太大
1004input_too_short输入为空,或者输入字数不够
1005target_not_fount相关的对象不存在
1006need_captcha需要验证码,验证码有误
1007image_wrong_format照片格式有误(仅支持JPG,JPEG,GIF,PNG或BMP)

返回json数据格式

{
//描述
 "msg":"image_too_large,
//状态码
 "code":1003,
 //数据
 "data":[]
}

url地址解释

/v1/m/login

参数说明
v1版本号
m手机端
Login登录接口

版本说明

暂定大版本更替时更改

例如:

常规接口规范

列表及分页接口设计

#假定请求数据列表
/v1/m/list

请求参数

名称请求方式类型说明默认值是否必填
pageGET页码/第几页1
limitGET条数10
/v1/lawyer?page=1&limit=10

返回参数

名称类型说明
msgstring描述
codenum状态码
dataobject数据

data数据格式

名称类型说明
pageSizenum总页数
pagenum当前页
limitnum每页条数
countnum总条数
rowsjson数据列表
    #示例
    {
        msg:ok,
        code:200,
        data:{
          count:70,
          pageSize:7,
          limit:10,
          page:2,
          #此数据只是示例,展现数据格式
          rows:[
            {
                id:001,
                name:zzz
                phone:111111
            },{
                id:002,
                name:zzz
                phone:111111
            },{
                id:003,
                name:zzz
                phone:111111
            }
          ]
        }
    }

详情页接口设计

请求参数

名称请求方式类型说明默认值是否必填
idGETstring产品id
#假定产品详情
/v1/m/product/details?id=001

返回参数

名称类型说明
msgstring描述
codenum状态码
dataobject数据

data数据格式(并不是真实字段,仅能代表数据格式)

名称类型说明
idnum产品id
namestring产品姓名
phonenum电话
imgstring产品头像
    #示例
    {
        msg:ok,
        code:200,
        data:{
          id:001,
          name:zzz,
          phone:111111,
          img:"img src 路径"
        }
    }

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文