码迷,mamicode.com
首页 > 其他好文 > 详细

服务器

时间:2018-03-22 22:31:35      阅读:192      评论:0      收藏:0      [点我收藏+]

标签:效率   引擎   direct   解耦   paginati   127.0.0.1   res   http协议   oca   

#服务器
web引用:浏览器向服务器发送一个请求,服务器再响应给浏览器。
#####2台计算机之间交互要遵守的条约(协议):
 1. TCP/IP协议有4层  简化版       //OSi是它的前身,协议有七层
 2. 
  协议组(每一组都是协议):
   第一层:引用层:http协议;
   第二层:传输层 又分:①TCP协议:安全协议,会经过三次握手和另一台计算机传送。②VDP协议:不安全协议,传输效率高(例直播)
   第三层:网络层   IP协议:把当前的地址做一个IP的封装。
   第四层:链路层   负责把数据的每一届传递到另外一台计算机上。
    另外一台计算机首先接触到的是链路层-网络层-传输层-引用层
   ??TCP协议:每一台电脑都支持,最为广泛。
#####引用层http协议:全名:超文本传输语言
######特性:
1. 基本请求响应模型  
 (浏览器向服务器发送一个请求,服务器再响应给浏览器。如果没有请求,就不会响应)    客户端与服务器,如果安装了软件,只要安装了;客户端的内部自己有协议,我们自己不用点,它会主动发过来,例QQ。。。        
2.      短(无)链接(链接一次就断开,链接太频繁了);
3.      无状态:每一次访问,都认为是新的,记忆短
#####http协议的访问流程:
1. 当我们先给浏览器发起请求。
2. 交给域名解析(浏览器会把我们输入的网址进行解析)。怎么解析:用域名服务器解析 。域名服务器解析挂了之后的现象:输入网址,进不了网站,但是可以QQ上网。
3. 经过三次握手建立链接。
4. 发送请求数据
5. 服务器响应数据
6. 浏览器接收数据后关闭链接。
#####http协议的内容: 1封装  2 解封装
    请求信息:封装(4部分)  浏览器安装http协议来封装,发送给服务器
    第一部分:请求行:包含了请求方法(get/post);包含了请求路径;包含了协议的版本;
    第二部分:请求头:以键值对的形式存在;包含了浏览器的版本和浏览器的相关信息;
    第三部分:空行
    第四部分:请求消息体(除了get)。
    
    相应信息:4个部分;
    第一部分:状态行(包含状态码;包含状态描述);
    第二部分:响应头:以键值对的形式寻在,服务器发给浏览器的设置信息。(响应头: 里面的东西,浏览器是不会显示出来的)
    第三部分:空行
    第四部分:响应消息体。
    (状态码:100-199 内部状态,少见 ; 200-299正确状态;300-399资源备已走,用缓存302代表已走,304资源缓存;400-499错误状态,客户端状态,404找不到页面;500-599错误状态,服务器出错,503服务器崩溃。
                
###Node.js    (2009年之前,前端只写html和css;2009年之后出现Node.js)
#####Node.js原理:
    Node.js是一个基于chromeV8引擎Javascript运行环境。
    Node.js使用了一个事件驱动,非阻塞式I10的模型,使其轻量又高效。(解释:一个线程负责接收所有的请求,然后放入事件队列中,让其他线程来处理;)
    Node.js的包管理器nmp,是全球最大的开源库生态系统

    引入Node.js模板:const require("模板")   fs 文件系统处理   path路径
    path.resolve()拼接得到绝对路经,从右往左处理。
    fs.statSync()返回一个文件信息,参数是路径
    fs.unlink 异步删除文件
    fs.unlinkSync 同步删除文件
    fs.rmdir删除文件
    变量名.isFile 是否是一个文件
    fs.isDirectory是否是一个目录
    变量名.readdirsync 返回一个数组

##### http搭建服务器

```js
    const http = require("http");//引入模块前面不加.\,但是引入自己的文件,必须写,并且是相对路径
    //创建服务器
    let server = http.creatServer(function(req,res){
        res.write("<h1>搭建服务器</h1>")
        res.end();
    });
    //启动服务器
    server.listen(3000,function(){
        console.log(12);
    })
```
查看本机:
1. 127.0.0.1.端口号(某个应用程序的窗口,并且保持其唯一性)    
2. localhost:端口号
 (多个应用程序不可用同一个端口,但是一个应用程序可有多个端口
  url网址)
    1. url.parse()将解析路径成一个对象
    
    ```js
    let urlObj = url.parse(req.url);
    urlObj.pathname//获取路径名
    urlObj.query//获取参数
    ```
    2. querystring.parse()该方法会把一个 URL 查询字符串 str 解析成一个键值对的集合
    
### express插件(可以运用到判定浏览器向服务器请求的是静态网页还是动态网页,然后做出相应的响应)
    1. 获取参数
        1. let phone = req.query.phone(form表单提交方式为get)
        2. let phone = req.body.phone(form表单提交方式为post)
    2. 重新定向一个新页面
        1. response的方法
            1. res.redirect("path")重定项
            2. res.send("")发送字符串
            3. res.location("path")作用同redirect
               res.sendStatus(302);


###    GET和POST区别
        1. GET请求参数放到?后面、POST请求参数放到请求消息体后面
        2. GET的请求参数是有限制的,它整个url不能超过255个字符,POST无限制
        3. GET请求可看见、POST请求数据不可见
        4. GET请求参数是缓存过的,POST提交的请求参数是不会被浏览器缓存的

#AJAx
作用:在不刷新页面的情况下可以与服务器进行交互(局部刷新)。
Jquery实现AJAX的方法:
(先引入jquery,js 放在public 里面)
    ```js
    方法1:
    window.onload = function (){
        phone.onblur = function (){
            $.get("/user/isPhoneExist",{phone:phone.value},function(data)
                $("#phoneInfo").html(data);

    });

    ```

    ```js
    方法2:
    window.onload = function (){
        $.ajax({
            type:"post"    //get/post
            url:"/users/isPhoneExist",
            data:{phone:phone.value},
            success:function(data){
                $("#phoneInfo").html(data);
        });
    });

    ```


###数据库:本身也是一个引用程序
1. 关系型数据库(不适合做大型数据的存放,做增删改查) 语言SQL:MYSQL SQLServer DB2  Oracle
2. 文档型数据库:
3. NoSQL:
4. mongoDB:JSON对象  1.先安装mangoDB ,启动;2 链接工具(命令行连接/可视化连接)
5. 
 #####mongoDB的包含关系:
mongoDB 包含数据库 ;(如果没有,写一个use f46,它自己就建立连接了)
数据库包含集合;
集合包含文档;
文档包含字段
 (插入,查看,查询,删,更新)
db.users.find()查看      
### mongoDB命令行连接:
db.users.find()查看
db.users.insert({})插入  例: db.ussers.insert({phone:"12345678912",pwd:"123"}
db.users.update({})修改   例:db.users.delete({根据它来修改},{$set{修改后的值}})  ==db.users.delete({phone:"123"},{$set{pwd:"456"}})    
db.users.remove({带条件删除 }) 删除  // db.users.remove({ })如果括号里不指定删除那个对象,它就会清空所有的对象
正则表达式:db.users.find({phone:/1/})     db.users.find({phone:{$regex:"2"}})

### mongoDB可视化连接:
1. 先下载npm i ykt-mongo --save-dev     //老师封装的
2. 在package.json里面加一条数据 :
```js
    "db":{
        "url":"mongodb://127.0.0.1:27017",
        "dbname":"f46"    //"f46"随便取的
     }
```

###Rest(资源状态表述转移) 
 
任何一个外部的都可以对资源进行增删改查。
rest所有的东西都可以想象成资源。
rest基于http协议访问

1. 获取 GET    users  复数
获取某一段(id ): GET    users/id    例:users/123
获取其他条件查询: GET   users/id ?name... 只有GET(获取)id才有?
2. 增加:Post          users   增加在消息体
3. 修改 :Put      users/id    修改的内容也在消息体
4. 删除  :delete     users/id  消息体

reload  与AJAX一样在不刷新页面的情况下,把数据库里面的数据渲染在页面上。


###分页
分页分两种:
1. 数据库分页:查找出来的时候就已经分好页了。 优点:对内存消耗小。坏处:   。一般情况下采用数据库分页。
2. 在程序代码上分页: 查出所有代码。优点:通用性。 缺点:通用性。

当前页:
每页显示数:显示出来的
总页数:总数/每页显数 (除不尽的,向上取整)
总数:
Limit与skip方法:
Limit 限制取几条  例:db.students.find({}).limit(3);   //limit(3)显示前3条
Limit的值算法:(当前页-1)X 每页显示的数
服务器分页代码:.findByPage(page,rows)          //有2个参数   page当前页 rows 每页显示的数
easyui的方法:html
pagination:true   //设置
显示分页
pageList:[5,10,12,20]      //设置每页显示的条数


skip跳过 ,默认为0  例:db.students.find({}).limit(3).skip(6);

###session :用来维持状态 
1. session是服务器当中的一个对象    //对象可以保存任何东西
2. session 又称会话   //会话的时间靠匹配来决定
3. 每个session 对象都有一个唯一的session ID值
4. session ID 作为服务器传给浏览器
5. session ID是经过cookie传递的

注:
1. 浏览器不同就会产生不同的session对象。浏览器不同,cookie不会共享,所有就会产生不同的seseeion ID ;2. 浏览器相同,产生一个新的标签页,session ID相同

let user = req.session.user || {};   //获取
res.send(user);  //返回
###上传图像

1. ajaxfileupload:jquery中用于上传及转码的插件
```js
$.ajaxFileUpload({
    fileElementId: "image",    //需要上传的文件域的ID。
    url: "/users/upImg", //后台方法的路径
    type: ‘post‘,   //当要提交自定义参数时,这个参数要设置成post
    dataType: ‘string‘, //服务器返回的数据类型。可以为xml,script,json,html。如果不填写,jQuery会自动判断。
    secureuri: false,   //是否启用安全提交,默认为false。
    async: true,   //是否是异步
    success: function (data) {   //提交成功后自动执行的处理函数,参数data就是服务器返回的数据。
        console.log(data);
    },
    error: function (data, status, e) {  //提交失败自动执行的处理函数。
        console.log(e);
    }
});    
```

2. multiparty:服务器端用于保存上传的文件并建立新的名字的插件
```js
  //生成multiparty对象,并配置上传目标路径
  var form = new multiparty.Form({ uploadDir: ‘./upImages‘ });
  //上传完成后处理
  form.parse(req, function (err, fields, files) {
    var inputFile = files.file;
    var uploadedPath = inputFile.path;
    var dstPath = ‘./upImages/‘ + inputFile.originalFilename;
    fs.rename(uploadedPath, dstPath, function (err) {
      if (err) {
        res.send(err);
      } else {
        res.send(dstPath);
      }
    });
```

###https:

HTTPS(全称:Hyper Text Transfer Protocol over Secure Socket Layer),是以安全为目标的HTTP通道,简单讲是HTTP的安全版。即HTTP下加入SSL层,HTTPS的安全基础是SSL,因此加密的详细内容就需要SSL。 它是一个URI scheme(抽象标识符体系),句法类同http:体系。用于安全的HTTP数据传输。https:URL表明它使用了HTTP,但HTTPS存在不同于HTTP的默认端口及一个加密/身份验证层(在HTTP与TCP之间)。

###前后端分离

#####为什么选择前后端分离
可以很好的解决前后端分工不均的问题,将更多的交互逻辑分配给前端来处理,而后端则可以专注于其本职工作,比如提供API接口,进行权限控制以及进行运算工作。而前端开发人员则可以利用nodejs来搭建自己的本地服务器,直接在本地开发,然后通过一些插件来将api请求转发到后台,这样就可以完全模拟线上的场景,并且与后台解耦。前端可以独立完成与用户交互的整一个过程,两者都可以同时开工,不互相依赖,开发效率更快,而且分工比较均衡。
###面试常问Amd 和 cmd 的区别 ;和require.js和sea.js的区别:
1. Amd 和 cmd 都是规范;(es6没有出现是都非常火爆, Amd 是国外的, cmd是国内的)
2. require.js和sea.js是实现规范


###require.js和sea.js的区别:
#####相同点:
1.都是模块加载器;
2. 都是采用define函数来定义模块;
3. 都是解决了前端模块化的时候全局命令空间污染和解析依赖问题。

#####不同点:
1.  两者定位上有差异,reqire.js专注于浏览器端,只有异步加载;sea.js既可以用在浏览器端也可以用在服务器端,支持异步也支持同步;
2.  两者遵循的标准不一样,require.js遵循的是Amd规范,而sea.js遵循的是cmd规范;
3.  两者对第三库的支持也有差异,require.js强势让第三方修改代码来遵循它;而sea.js不强推第三方库,采用一套成熟的封装机制。
4. require.js更加专注于国外的使用率高,而sea.js是由国人开发的,包容性强,语言上没有障碍,所有国内使用率高。
###模块化:
引入的方法:import   // 例 import 变量 from “相对路径”
导出的方法: export  
  //例 export {方法名 as default}  //导出一个
//例  export {A ,  B , C}  //导出多个
$("#main").load(路径,function(){});--远程加载

#####单页(应用)
1. 概念:整个页面只有一个系统。只有一个Web 页面的应用,是加载单个html页面并在用户与应用程序交互时动态更新该页面的web应用程序。
2. 好处:交互性比多页应用好
3. 缺点:开发难度提高了
#####多页(应用)
1. 概念:2个页面及以上组成的页面。

#####easyui的效果使用单页应用加载出来的办法:$.parser.parse() ;   //解析页面

服务器

标签:效率   引擎   direct   解耦   paginati   127.0.0.1   res   http协议   oca   

原文地址:https://www.cnblogs.com/hemei1212/p/8626871.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!