↖  Java開發手冊-阿里巴巴-嵩山版-16:安全规约及MySQL數據庫..


-loading- -loading- -loading-

2020-12-26 , 1529 , 104 , 151

听音频 🔊 . 看视频 🎦

四、安全规约

 

 1. 【强制】隶属于用户个人的页面或者功能必须进行权限控制校验。 

说明:防止没有做水平权限校验就可随意访问、修改、删除别人的数据,比如查看他人的私信内容。

2. 【强制】用户敏感数据禁止直接展示,必须对展示数据进行脱敏。 

说明:中国大陆个人手机号码显示:139****1219,隐藏中间4位,防止隐私泄露。


3. 【强制】用户输入的SQL参数严格使用参数绑定或者METADATA字段值限定,防止SQL注入,禁止字符串拼接SQL访问数据库。

反例:

某系统签名大量被恶意修改,即是因为对于危险字符 # --没有进行转义,导致数据库更新时,where后边的信息被注释掉,对全库进行更新。


4. 【强制】用户请求传入的任何参数必须做有效性验证。 

说明:忽略参数校验可能导致:

⚫ page size过大导致内存溢出

⚫ 恶意order by导致数据库慢查询

⚫ 缓存击穿

⚫ SSRF

⚫ 任意重定向

⚫ SQL注入,Shell注入,反序列化注入

⚫ 正则输入源串拒绝服务ReDoS

Java代码用正则来验证客户端的输入,有些正则写法验证普通用户输入没有问题,但是如果攻击人员使用的是特殊构造的字符串来验证,有可能导致死循环的结果。


5. 【强制】禁止向HTML页面输出未经安全过滤或未正确转义的用户数据。

6. 【强制】表单、AJAX提交必须执行CSRF安全验证。 

说明:CSRF(Cross-site request forgery)跨站请求伪造是一类常见编程漏洞。对于存在CSRF漏洞的应用/网站,攻击者可以事先构造好URL,只要受害者用户一访问,后台便在用户不知情的情况下对数据库中用户参数进行相应修改。


7. 【强制】URL外部重定向传入的目标地址必须执行白名单过滤。

-loading- -loading--loading-


8. 【强制】在使用平台资源,譬如短信、邮件、电话、下单、支付,必须实现正确的防重放的机制,如数量限制、疲劳度控制、验证码校验,避免被滥刷而导致资损。 

UfqiLong

说明:如注册时发送验证码到手机,如果没有限制次数和频率,那么可以利用此功能骚扰到其它用户,并造成短信平台资源浪费。

9. 【推荐】发贴、评论、发送即时消息等用户生成内容的场景必须实现防刷、文本内容违禁词过滤等风控策略。


----


五、MySQL數據庫


(一)建表規約


 1. 【强制】表达是与否概念的字段,必须使用is_xxx的方式命名,数据类型是unsigned tinyint(1表示是,0表示否)。 

说明:任何字段如果为非负数,必须是unsigned。 

注意:POJO类中的任何布尔类型的变量,都不要加is前缀,所以,需要在<resultMap>设置从is_xxx到Xxx的映射关系。数据库表示是与否的值,使用tinyint类型,坚持is_xxx的命名方式是为了明确其取值含义与取值范围。 

正例:

表达逻辑删除的字段名is_deleted,1表示删除,0表示未删除。


2. 【强制】表名、字段名必须使用小写字母或数字,禁止出现数字开头,禁止两个下划线中间只出现数字。数据库字段名的修改代价很大,因为无法进行预发布,所以字段名称需要慎重考虑。 

说明:MySQL在Windows下不区分大小写,但在Linux下默认是区分大小写。因此,数据库名、表名、字段名,都不允许出现任何大写字母,避免节外生枝。 

正例:

aliyun_admin,rdc_config,level3_name 

反例:

AliyunAdmin,rdcConfig,level_3_name


3. 【强制】表名不使用复数名词。 

说明:表名应该仅仅表示表里面的实体内容,不应该表示实体数量,对应于DO类名也是单数形式,符合表达习惯。


4. 【强制】禁用保留字,如desc、range、match、delayed等,请参考MySQL官方保留字。

5. 【强制】主键索引名为pk_字段名;唯一索引名为uk_字段名;普通索引名则为idx_字段名。 

说明:pk_ 即primary key;uk_ 即 unique key;idx_ 即index的简称。


6. 【强制】小数类型为decimal,禁止使用float和double。 

-loading- -loading--loading-


UfqiLong

说明:在存储的时候,float 和 double 都存在精度损失的问题,很可能在比较值的时候,得到不正确的结果。如果存储的数据范围超过 decimal 的范围,建议将数据拆成整数和小数并分开存储。



7. 【强制】如果存储的字符串长度几乎相等,使用char定长字符串类型。

8. 【强制】varchar是可变长字符串,不预先分配存储空间,长度不要超过5000,如果存储长度大于此值,定义字段类型为text,独立出来一张表,用主键来对应,避免影响其它字段索引效率。

9. 【强制】表必备三字段:id, create_time, update_time。 

说明:其中id必为主键,类型为bigint unsigned、单表时自增、步长为1。create_time, update_time的类型均为datetime类型,前者现在时表示主动式创建,后者过去分词表示被动式更新。



10. 【推荐】表的命名最好是遵循“业务名称_表的作用”。 正例:alipay_task / force_project / trade_config

11. 【推荐】库名与应用名称尽量一致。

12. 【推荐】如果修改字段含义或对字段表示的状态追加时,需要及时更新字段注释。

13. 【推荐】字段允许适当冗余,以提高查询性能,但必须考虑数据一致。冗余字段应遵循: 

1) 不是频繁修改的字段。 

2) 不是唯一索引的字段。

3) 不是varchar超长字段,更不能是text字段。 

正例:

各业务线经常冗余存储商品名称,避免查询时需要调用IC服务获取。


14. 【推荐】单表行数超过500万行或者单表容量超过2GB,才推荐进行分库分表。 

说明:如果预计三年后的数据量根本达不到这个级别,请不要在创建表时就分库分表。

15. 【参考】合适的字符存储长度,不但节约数据库表空间、节约索引存储,更重要的是提升检索速度。 

正例:

无符号值unsigned可以避免误存负数,且扩大了表示范围。

美女写真性感女神大尺度人体艺术美丽脸庞曼妙体态绝色美人是天使也是尤物-20-9

+數據 +手冊 +规约 +嵩山 +安全

本页Url

↖回首页 +当前续 +尾续 +修订 +评论✍️


👍33 仁智互见 👎1
  • 还没有评论. → +评论
  • -loading- -loading- -loading-


    🔗 连载目录

    🤖 智能推荐

    + 大群 大群
    AddToFav   
    新闻 经典 官宣