服务器是个牙婆,做功德不留名?!

打印 上一主题 下一主题

主题 807|帖子 807|积分 2421

 刚开始觉得服务器才是大boss,掌管着各种数据的“生死大权”,但如今不这么觉得了,倒觉得它像个“牙婆”,哈哈哈,这位“牙婆”到底牵了谁与谁的线?探究一下这位“小牙婆”。
【1.0前情相识】
我们浏览网页时,想从网页上获取的信息就是向服务器发请求,服务器再从数据库中查找到结果反馈给我们,实质上就是:对存在数据库中的数据举行的增、删、改、查

增:【如:网页中出现的一些注册页面】---通过post方式,提交表单信息到服务器,通过服务器与数据库的连接,使用sql语句的添加语句,将数据添加到数据库,保存起来
删:【如:删除个人用户的一些数据】---通过get方式,向服务器发送请求,服务器与数据库连接,根据数据唯一标识使用sql语句的删除语句,将数据库中数据删除,再将删除成功信息返回
改:【如:对个人信息表的修改】---分两步举行,
第一步:通过get方式,向服务器发送请求,服务器与数据库连接,执行sql查询语句,根据唯一标识获得要修改的页面的信息,并把服务器从数据库中查到的数据表现到页面上
第二步:再次通过post方式,向服务器发送提交数据的请求,与  的过程相似,通过服务器与数据库的连接执行sql更新语句,将更改的信息在数据库更新
查:【如:获取网页的整页信息】---通过get方式,向服务器发送请求,服务器与数据库建立连接,根据数据的唯一标识,执行sql语句的查询语句,从数据库中查询到我们需要的数据,并将查询的结果返回给服务器,服务器在返回给浏览器,末了表现给我们
【2.0揭示庐山真面貌】:“牙婆的工作原理”
【准备工作】加载第三方模块(全部):    npm  i   express   mysql   multer   body-parser
【配置服务器】完成app.js   /   db.js(数据库)文件
app.js文件:
编写有点乱,可以优化一下,如下:
db.js文件:
【正式工作流程】
“牙婆”(服务器)连接着浏览器和数据库,从浏览器发送请求开始,浏览器向服务器发送请求的方式有两种:GET或者POST,“牙婆”(服务器)也会对应“招待”这两种请求,是GET请求,就用GET方式招待,POST请求,就用POST方式招待。
【2.1GET方式】
浏览器发送GET方式请求:
在html页面使用jq发get请求,用于获取页面信息
$.get('请求url/接口地点',{ },function(res) {
        //代码体,可能会使用模板引擎
},'json')
第1个参数:后台编写的接口地点或要请求的地点
第2个参数:请求时传递的参数,无参数可以不写,也可以直接写在第一个参数反面
第3个参数:一个回调函数,内里是从服务器相应返回的结果,偶尔可以共同模板引擎将数据表如今页面中,偶尔也可以直接使用res这个结果,将数据直接出如今页面上
第4个参数:是返回数据的表现格式,是个json格式的数据,易于阅读
服务器吸取GET方式请求,并且处理惩罚请求后作出相应:
在app.js中使用express接受get请求:浏览器发起get请求,服务器就要接受get请求
  1. app.get('接口名', (req, res) => {
  2.         //req:包含浏览器所有的请求信息
  3.         //res:保存着服务器响应给浏览器的所有信息
  4.      
  5.        //sql:为查询语句,let sql = '语句 ?';
  6.        //values:为sql中占位符?的确切的值
  7.       db(sql, values,  (err, data) =>{ //调用db函数
  8.               if(err) {
  9.                  throw err;
  10.                  res.send({code:201});
  11.               }  else {
  12.                  res.send(data);//将查询到的数据返回给浏览器
  13.                   //或不需要返回的数据,只需一个提示时写:
  14.                  res.send('响应成功的信息提示')
  15.               }
  16.        });
  17. })
复制代码
【2.1POST方式】
浏览器发送POST方式请求:
表单有文件上传提交(注册信息或修改信息提交时)浏览器发起post方式的请求
步骤:
(1)收集表单信息,使用FormData收集后保存到fd,
(2)单独处理惩罚上传文件时的图片预览(使用暂时url)
(3)在html页面使用jq发起ajax(post)请求
  1. $.ajax({
  2.         contentType: false,
  3.         processData: false,
  4.         type: ’post‘,
  5.         url: '要请求的url或接口地址',
  6.         data: {},//请求时传的参数,即收集的表单数据的name值
  7.         dataType: 'json',
  8.         error: function() {
  9.              //可以捕获异常或错误信息
  10.          },
  11.         success: function(res) {
  12.             //请求成功后,实现页面跳转
  13.         }
  14. })
复制代码
服务器吸取POST方式请求,处理惩罚请求后作出相应:
在app.js使用multer处理惩罚有上传文件的post请求:浏览器发起post请求,服务器就要接受post请求
  1. app.post('接口名', upload.single('表单上传文件控件的name值'),function(req, res) {
  2.        //req:包含浏览器所有的请求信息
  3.         //res:保存着服务器响应给浏览器的所有信息
  4.      
  5.       //sql:为查询语句    //values:为sql中占位符?的确切的值
  6.        let sql = '语句 ?';
  7.        let values = {
  8.             //数据库字段名:服务器接受的表单的各项name名
  9.                   name : req.body.heroName;  
  10.                       file : req.file.path
  11.         }
  12.        db(sql, values,  (err, data) =>{ //调用db函数
  13.               if(err) {
  14.                  throw err;
  15.                  res.send({code:201});
  16.                }  else {
  17.                  res.send(data);//将查询到的数据返回给浏览器
  18.                   //或不需要返回的数据,只需一个提示时写:
  19.                  res.send('响应成功的信息提示')
  20.               }
  21.        });
  22. })
复制代码
【2.3与数据库接洽】
不管浏览器发送get请求,服务器对应吸取get请求,还是浏览器发送post请求,服务器吸取post请求,都要与数据库产生接洽,都要经服务器执行sql语句,到数据库中查询数据,并返回查询的结果。
sql语句查询数据:
增:insert into  表名  set  字段名=’值‘
删:delete from 表名  where  id = ?
改:update 表名  set  字段名=’值‘  where  id =?
查:select *  from  where 要查询的条件
注意:删和改都要加条件,且是数据的唯一标识,不写条件会全部删除或全部修改!!!
三者关系大致如图
【3.0小知识点】
【1】服务器吸取请求时的参数
为什么?因为在做修改页面时,
第一步是根据请求地点的id(唯一标识)获取页面信息,此时用到吸取get请求的参数,
作用:根据这个id,去数据库中查询数据详情;
第二步是在做了修改信息之后,点击按钮修改,依旧用的是multer模块处理惩罚上传文件的post请求,此时用到吸取post请求时的参数,
作用:将收集到的信息(即表单的name值)和数据库中的字段名对应
吸取get请求时的参数:使用req.query吸取,是个对象
吸取post请求时的参数:使用req.body吸取参数(吸取的是表单文本的参数,如,text/email/textarea),是个对象
吸取post请求时的参数:使用req.file吸取参数(吸取的是表单上传文件的参数),是个对象
【2】收集表单数据,并用post提交
方法一:要求使用FormData方式收集表单信息,有上传文件(注意收集的数据是个dom对象)
var  fd = new FormData($('form')[0]);
将fd作为post请求时传的参数即可
方法二:未要求用FormData收集数据(如登录页面仅需收集表单信息即可,无文件上传)
使用jq提供方法:var data = $(form').serialize;
将data作为post请求时传的参数即可
【3】文件上传及预览结果
找到文件jq对象,当上传文件发生改变时,发生change事件:
获取到当前文件对象(dom对象):
var objFile =  this.files[0];
将当前文件对象保存到一个暂时url中: 
var url = URL.createObjectURL(objFile);
改变src的属性:$('选择器').attr('src',  url);

【4】获取自界说属性方法
方法一:如在事件委托中,获取自界说的属性data-id的值
var   id = $(this).attr('data-id');

方法二:使用h5新增属性:dataset收集全部自界说属性
var id = this.dataset.id;

【5】几个id值
(1) 编辑按钮连接跳转处设id值:
编辑按钮连接跳转处设id,是要保存数据的唯一标识,保证跳转时,会跳转到对应的唯一页面
(2) 删除按钮处设自界说属性id(data-id):
data-id内里保存着此条数据的唯一标识,在执行删除操作时,可以删除对应的唯一数据
(3) 编辑页面表单域中设一个隐藏的表单控件,在表单控件中设id:
<input type="hidden" name="id" />
这里的id是name的属性值(name='id'),修改操作时接口要求传一个id参数,
收集表单数据时会将这个name的值(即id)作为参数传到对应的要修改的数据上,偶尔也会在隐藏域设一个value值,内里保存数据的id。

【以上均是自己整理,也可能不太全,如喜欢,请关注哦,不定时分享生活见闻及总结所习得的技术,哈哈~】
微信扫一扫
关注该公众号



免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

民工心事

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表