当前位置: 代码网 > 科技>操作系统>Windows > nginx如何搭建前后端分离架构

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

2025年01月24日 Windows 我要评论
本人用的是vue-cli 自动构建vue+webpack 项目,这里不对webpack、nginx进行讲解。本文主要解决前端开发环境搭建、测试环境搭建、生产环境搭建以及接口调试需要工具1.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方式

  • 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 路径"
        }
    }

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com