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


-loading- -loading- -loading-

2020-12-26 03:27 , 104 , 6

四、安全规约

 

 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外部重定向传入的目标地址必须执行白名单过滤。

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

UfqiLong

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

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


----


五、MySQL數據庫


(一)建表規約


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

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

注意:POJO类中的任何布尔类型的变量,都不要加is前缀,所以,需要在

正例:

表达逻辑删除的字段名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。 

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可以避免误存负数,且扩大了表示范围。

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

本页地址

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


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


    🔗 连载目录

    🤖 智能推荐

    Java開發手冊-阿里巴巴-嵩山版

     


    + 老教 老教
    AddToFav   
    新闻 经典 官宣