提到服务端不得不说客户端。客户端(Client)是指与服务端相对的,提供用户操作界面,实现业务管理的桌面应用程序、Web页面、小程序或手机App,旨在收集用户意图、为用户展现服务结果、在用户本地服务的程序。

服务端和客户端

纯服务端是什么架构 服务端包括什么_客户端

网络服务的软件分B/S(浏览器Browser/服务器Server)和C/S(客户端Client/服务器Server)两种模式。基于B/S模式的软件又叫Web应用。Web应用可分为前端(在浏览器中执行的部分)和后端(在服务器中执行的部分),后端又叫服务端。

随着大前端技术的兴起,目前这两种技术划分方法,已经没有了严格的界限,例如:非原生App和小程序其本质都是Web。

无论什么形式的客户端都需要服务端提供必要的服务——数据库服务,Web Server、接口等。

服务端开发,就是开发运行在服务器端的程序,为客户端提供API接口服务。软件客户端和服务端的协作,分为B/S(浏览器/服务器)和C/S(客户端/服务器)两种模式,浏览器就是一种通用的客户端,现在流行的APP就相当于个性化的客户端,无论B/S还是C/S都要有相应的服务器端程序提供服务。对于绝大部分应用,服务端的核心就是数据库,服务器端的程序就是根据应用需求来管理和操作服务端的数据库,通过对数据库的操作,返回满足用户需求的数据。服务端开发主要就是根据业务逻辑要求实现业务功能和性能要求。

纯服务端是什么架构 服务端包括什么_html5_02

服务端开发

今天要讲的服务端特指可以为客户端提供数据、业务处理功能的接口API。

一般开发模式下,开发服务端需要用到至少一门基础开发语言和数据库。每种开发语言理论上是通用的,可以实现任何业务场景,几乎任何一种开发语言都能作为服务端程序语言。但是,术业有专攻,不同的开发语言在某个场景应用的适用度、难易度不同,所以选用什么语言、什么数据库,取决于是否便于解决实际问题和需求。

使用基础开发语言实现服务端开发,需要解决客户端请求接口,数据库访问、操作,业务逻辑的实现算法。而在有效云开发平台依然只使用SQL、JS就可实现服务端的开发。

纯服务端是什么架构 服务端包括什么_html5_03

仅使用SQL和JS实现服务端开发

开发服务端需要实现以下三部分功能:客户端接口、业务逻辑处理、后台数据库操作。

1、服务接口定义

客户端接口一般情况下通过http协议get或post发起请求,根据应用场景的需求提交请求参数数据,服务端获取参数。

进入“有效云开发集成环境”,进入【接口管理】,新建接口:

软件程序服务端开发,简单到难以想象
接口定义

接口可以定义接口

● 模块(便于管理)

● 代号(接口的详细访问地址)数据库绑定系统设置的链接。

● 模板:模板通过系统脚本的形式返回Json格式的数据,开发者可以根据业务 需求自己定义,其中可以访问客户端的请求参数、接口返回参数等等。

返回接口定义:

{{if .r}}
{
 "code": 100, 
 "goods_id":"{{.r.goods_id}}",
 "goods_count":"{{.r.goods_count}}",
  "msg": "ok",  "extra": "", 
 "result": []
 }
{{else}}
{
 "code": 104, 
 "msg": "查询失败",  
 "extra": "系统异常,未能获得库存数量", 
 "result": []
 }
{{end}}

2、接口参数

这里的参数是广义上的,即可以是客户端提交的参数,也可以是服务端计算得到的参数。

在“有效云集成开发环境”中选中某接口,点击操作栏的【参数】按钮

软件程序服务端开发,简单到难以想象
接口参数

参数r为计算参数,通过SQL直接查询得到客户端传递的商品ID(goods_id)对应商品的库存数量。

软件程序服务端开发,简单到难以想象
计算参数

SQL:

select goods_id,goods_count from tb_store where goods_id={{.goods_id}} and shop_id={{ME.deptid}} limit 1;

在“有效云开发平台”开发接口,只需要编写极少量的代码。

客户端的调用,与采用直接通过基础开发语言开发的接口是相同的。

here = this;
if(here.form["goods_id"]!="" && here.form["goods_count"]!=""){    
    var data=new FormData();
    data.append("goods_id",here.form["goods_id"]);
    axios.post('/api/{{APPID}}/storeapp/getstorecount',data).then(function (res) {
        if(res.data.code==100){
            var out_count=parseInt(here.form["goods_count"]);
            var store_count=parseInt(res.data.goods_count);
            if( out_count > store_count ){
                here.form["goods_count"] = "";
                window.top.vm.$message.error('当前库存不足,请重新输入出库数量!');
            }            
        }else{
           window.top.vm.$message.error('商品库存校验失败,请人工核验当前库存!');
        }
    }).catch(function (error) {});
}

该代码设置在了,出库操作出库数量组件的 blur 时间中。

软件程序服务端开发,简单到难以想象
实际运行情况