nginx搭建前后端分离架构

本人用的是vue-cli 自动构建vue+webpack 项目,这里不对webpack、nginx进行讲解。
本文主要解决前端开发环境搭建、测试环境搭建、生产环境搭建以及接口调试

一、需要工具

1.nginx(配置代理)
2.webpack-devserver(启动前端服务)
3.postman(接口调试)

二、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方式

get方式

1.get请求方式
2.url请求地址
3.发送请求
ps:get请求参数可以写在url里边 也可以写在 下方的key value 里
post方式

这里写图片描述

1.post请求方式
2.url请求地址
3.发送请求
4.选择参数类型
5.将参数写入
ps:get请求参数可以写在url里边 
为什么使用postman
1.前端请求后端接口时发生错误,postman测试接口是否正常,快速定位问题
2.一些小公司没有api文档,或者文档不全,通过postman可以快速的判断接口传参类型 
ps:甩锅利器

api基本设计规范

接口说明
  • 数据格式全部使用json格式
  • post/put 使用UTF-8编码
  • 使用HTTP Status Code表示状态
  • 列表参数使用start和count
返回状态码说明

通过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 版本1.x
    v2 版本2.x

常规接口规范

列表及分页接口设计
#假定请求数据列表
/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 路径"
        }
    }
  • 4
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

赵忠洋

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值