网站首页 > 开源技术 正文
提到服务端不得不说客户端。客户端(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都要有相应的服务器端程序提供服务。对于绝大部分应用,服务端的核心就是数据库,服务器端的程序就是根据应用需求来管理和操作服务端的数据库,通过对数据库的操作,返回满足用户需求的数据。服务端开发主要就是根据业务逻辑要求实现业务功能和性能要求。
服务端开发
今天要讲的服务端特指可以为客户端提供数据、业务处理功能的接口API。
一般开发模式下,开发服务端需要用到至少一门基础开发语言和数据库。每种开发语言理论上是通用的,可以实现任何业务场景,几乎任何一种开发语言都能作为服务端程序语言。但是,术业有专攻,不同的开发语言在某个场景应用的适用度、难易度不同,所以选用什么语言、什么数据库,取决于是否便于解决实际问题和需求。
使用基础开发语言实现服务端开发,需要解决客户端请求接口,数据库访问、操作,业务逻辑的实现算法。而在有效云开发平台依然只使用SQL、JS就可实现服务端的开发。
仅使用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 时间中。
感谢阅读,我是在软件开发平台研究中不停前行的草根开发者,感谢关注支持。
猜你喜欢
- 2024-12-31 干货推荐|Web、PC客户端和移动端APP设计自检表
- 2024-12-31 看了海外的app设计稿,总是能给我们一些启发。
- 2024-12-31 Google Physical Web—物联网要有自己的Web标准,用户不需下载app就能实现交互
- 2024-12-31 国外app界面,从布局、配色、风格上看十分出位
- 2024-12-31 HTML5技术的Web APP能否匹敌Native APP?
- 2024-12-31 Web前端学习6个有效果软件!看看哪些你用的上
- 2024-12-31 这炫酷的ui设计放到app里那还不是直接起飞了
- 2024-12-31 如何专业系统的做好app渗透、web渗透、小程序渗透
- 2024-12-31 开发一个社交APP,外包价格多少钱?
- 2024-12-31 Mozilla正开发Webmaker app,想让大家在移动端便可创建web app
你 发表评论:
欢迎- 05-16东契奇:DFS训练时喷了我很多垃圾话 我不懂他为什么比赛不这么干
- 05-16这两球很伤!詹姆斯空篮拉杆不中 DFS接里夫斯传球空接也没放进
- 05-16湖人自媒体调查:89%球迷希望DFS回归79%希望詹姆斯回归
- 05-16Shams:湖人得到全能球员DFS 节省了1500万奢侈税&薪金空间更灵活
- 05-16G5湖人胜率更高!詹姆斯不满判罚,DFS谈5人打满下半场:这很艰难
- 05-16DFS:当东契奇进入状态 所有防守者在他面前都像个圆锥桶
- 05-16上一场9中6!DFS:不能让纳兹-里德这样的球员那么轻松地投三分
- 05-16WIDER FACE评测结果出炉:滴滴人脸检测DFS算法获世界第一
- 最近发表
-
- 东契奇:DFS训练时喷了我很多垃圾话 我不懂他为什么比赛不这么干
- 这两球很伤!詹姆斯空篮拉杆不中 DFS接里夫斯传球空接也没放进
- 湖人自媒体调查:89%球迷希望DFS回归79%希望詹姆斯回归
- Shams:湖人得到全能球员DFS 节省了1500万奢侈税&薪金空间更灵活
- G5湖人胜率更高!詹姆斯不满判罚,DFS谈5人打满下半场:这很艰难
- DFS:当东契奇进入状态 所有防守者在他面前都像个圆锥桶
- 上一场9中6!DFS:不能让纳兹-里德这样的球员那么轻松地投三分
- WIDER FACE评测结果出炉:滴滴人脸检测DFS算法获世界第一
- 湖人自媒体调查:89%球迷希望DFS回归 79%希望詹姆斯回归
- 一觉醒来湖人苦盼的纯3D终于到位 DFS能带给紫金军多少帮助
- 标签列表
-
- jdk (81)
- putty (66)
- rufus (78)
- 内网穿透 (89)
- okhttp (70)
- powertoys (74)
- windowsterminal (81)
- netcat (65)
- ghostscript (65)
- veracrypt (65)
- asp.netcore (70)
- wrk (67)
- aspose.words (80)
- itk (80)
- ajaxfileupload.js (66)
- sqlhelper (67)
- express.js (67)
- phpmailer (67)
- xjar (70)
- redisclient (78)
- wakeonlan (66)
- tinygo (85)
- startbbs (72)
- webftp (82)
- vsvim (79)
本文暂时没有评论,来添加一个吧(●'◡'●)