javascript奇妙的变量类型安全问题

变量类型污染问题

js数据类型

值类型(基本类型):

字符串,数字,布尔,对空,未定义,symbol(es6引入一种新的原始数据类型,表示独一无二的值)

引用数据类型:

对象(object),数组(array),函数(function)

对象
花括号分割,在括号内部,对象的属性以名称和值对的形式(name : value)来定义
属性由逗号分割:

eg:
var person={firstname:"John",lastname:"Doe"}
此时对象person有三个属性,firstname,lastname

对象属性寻址方式

name=person.lastname;
name=person["lastname"];

json可以发送的数据

JSON 值可以是:

  • 数字(整数或浮点数)

    发送
    1 #typeof number
  • 字符串(在双引号中)

    发送
    "a"#typeof string
  • 逻辑值(true 或 false)

    发送
    true#typeof boolean
  • 数组(在中括号中)

    发送
    ["a","b"]#typeof object
  • 对象(在大括号中)

    发送
    {"name": "Tom","Grade":1, "age":11, "gender": "M"} #typeof object
  • null

    发送
    null#typeof object

加运算

字符串+字符串依然得到字符串
字符串+数组也是,其他都是
但如果不是字符串相加,则为
true+true=2#因为true为1
基本上除了Number+Number=Number,Bool+Bool=Number

js各种小trick

一个正数的负大数次方为0,负数的则为-0
NaN和NaN不相等
e++<e--肯定满足;做比较时true为1,false为0
任何非空字符串都为真,js中两个等号为弱类型判断
string(大数)返回Infinity;json.parse()可以处理数字
in对数组来说是判断数组的key
括号json.parse()基本一样效果;json.parse()可以解析__proto__
对null变量进行数组寻址会报错,并且null变量为object

javascript原型链污染

三种属性

1.__proto__和constructor属性是对象所独有的:
2.prototype属性是函数所独有

但是由于JS中函数也是一种对象,所以函数也拥有__proto__和constructor属性

__proto__

proto属性是对象所独有的

作用:当访问一个对象的属性时,如果该对象内部不存在这个属性,那么他就会去它的proto属性所指向的那个对象(理解为父对象),如果父对象也没有,则在往上找,如果一直到原型链顶端都没有该属性,就会报错

这种通过__proto__属性来连接对象直到null的一条链即为我们所谓的原型链。其实我们平时调用的字符串方法、数组方法、对象方法、函数方法等都是靠__proto__继承而来的。

prototype属性

它是函数所独有的,是从函数指向对象,并且是函数的原型对象,也就是这个函数(其实所有函数都可以作为构造函数)所创建的实例的原型对象,由此可知

f1.__proto__==Foo.prototype

**作用:**包含可以由特定类型的所有实例所共享的属性和方法,也就是让该函数所实例化的对象们都可以找到公用的属性和方法,任何函数在创建的时候,其实会默认同时创建该函数的prototype对象

constructor属性

它是对象才拥有的,他是从一个对象指向一个函数,含义就是指向该对象的构造函数,每个对象都有构造函数

原型链

eg:
img

var a = {};
console.log(a.__proto__); //Object {}
console.log(a.__proto__ === a.constructor.prototype); //true

小结

1.我们需要牢记两点:①__proto__和constructor属性是对象所独有的;②prototype属性是函数所独有的,因为函数也是一种对象,所以函数也拥有__proto__和constructor属性。

2.__proto__属性的作用就是当访问一个对象的属性时,如果该对象内部不存在这个属性,那么就会去它的__proto__属性所指向的那个对象(父对象)里找,一直找,直到__proto__属性的终点null,再往上找就相当于在null上取值,会报错。通过__proto__属性将对象连接起来的这条链路即我们所谓的原型链。

3.prototype属性的作用就是让该函数所实例化的对象们都可以找到公用的属性和方法,即f1.proto === Foo.prototype。(意思是让f1可以找到公用的属性方法,即向上找有prototype给他)

4.constructor属性的含义就是指向该对象的构造函数,所有函数(此时看成对象了)最终的构造函数都指向Function。

javascript基础语法

传输数据

1.req.params/req.query/req.body

req.params

eg:/modify/:file
/modify/index
那么req.params.file=index

req.query

eg:
?id=2
那么req.query.id那么就可以得到2

req.body(针对post请求)

eg:
post:username=adbc
req.body.username=adbc

定义变量

const: 用于定义不可变变量
**var 声明语句声明一个变量,并可选地将其初始化为一个值
**process.env
:返回包含用户环境的对象

Author

vague huang

Posted on

2021-10-02

Updated on

2021-10-05

Licensed under

Comments