Web安全开发注意事项

2024-06-17 06:59:07

1.sql注入:这个很常规了,不要拼字符串以及过滤关键字都可以防住,需要注意的是,Cookie提交的参数也是可以导致注入漏洞的。
2.旁注:就是说在保证自己的程序没问题的同时,也要保证同台服务器的其他站点没问题。至少要设置好系统权限,即使别人的站点出问题也不能影响自己的站点。
3.上传:尽量不要有上传功能,如果必须有上传功能。也要做到以下方面:不能让用户定义路径、文件名,限制好可上传的文件类型。同时要限制好权限,基本规则:执行和可写是互斥权限,不应同时存在。
4.口令强度:在设置密码之类的功能上应加入密码强度要求。服务器上线部署的时候,应该立即把默认密码修改掉。
5.防穷举机制:适当的加入验证码,防止别人用程序穷举账户密码。
6.第三方控件:使用第三方控件,应经过严格的审核(很多第三方控件上作者故意留有缺陷),并且剔除不必要的功能再使用。
7.权限最小化:能给只读就给只读,尽量具体到每一个子目录。
8.目录非常规化:得到管理员账户密码,但是找不到后台登录地址也是很难***的。后台路径不要动不动就是 http://xxxxx/admin、manager、gl之类的,很容易猜解。
10.XSS:俗称跨站脚本***。用户把HTML、JS之类的标签输入到编辑框,入库之后,再显示的时候可以导致版面错误、JS能解析执行之类的都属于XSS的范畴。如果***者插个Iframe连的是个***网页,那查看这个内容的人就悲剧了。解决方法:过滤大于小于号即可
11.CSRF URL跳转未验证漏洞:类似于XSS,只是把代码写在URL里,如
http://xxxx/logout.aspx?preURL=aaaa.html
即经常出现在登录退出的页面,通过参数的preURL决定完成动作的时候跳向哪个页面,如果照样
http://xxxx/logout.aspx?preURL=javascript:alert('test')
就可以弹框,说明我们的js代码已经被执行起来了。

总之一句话,开发过程中,不要相信用户提交的任何数据,规划好目录,做到权限最小化,关闭、删除不必要的东西,就相对会安全很多了。

cert 安全编码建议:
1、验证输入:从不可信任的数据源中进行的输入需要验证。合适的输入验证能减少大量软件的弱点。必须对大部分的数据源持怀疑的态度,包括命令行参数,网络接口,环境变量及用户文件。
2、留言编译器警告:编译代码时使用编译器的最高警告级别,通过修改代码来减少警告。
3、针对安全策略的架构和设计:构建软件架构和设计软件时采用安全策略。例如:如果系统在不同的时间需要不同的权限,则考虑将系统分成不同的互相通信的子系统,每个系统拥有合适的权限。
4、保持简单性:设计越简单越好,复杂的设计提高了实现时错误的可能性。
5、默认拒绝:默认的访问策略建立在允许的基础上。也就是说,默认的访问是拒绝的,除非标明是允许的。
6、最小权限原则:每个进程拥有完成工作所需的最小权限。任何权限的拥有时间要尽可能的短。这一方法能阻止***者利用权限提升执行任意代码的机会。
7、清洁发送给其他系统的数据:清洁所有发送给复杂子系统的数据,例如:命令外壳(shells),关系数据库,商用组件。***者可能通过SQL命令或者注入进行***。这不是靠子系统通过输入验证来避免的问题,因为子系统不清楚调用的上下文,而调用过程指导上下文,所以有责任在调用子系统时清洁数据。
8、纵深防御:这是一个通用的安全原则,从多个防御策略中规避风险,如果一层防御失效,则另一层防御还在发挥作用。
9、使用有效的安全质量保证技术:好的质量保证技术能有效的发现和消除弱点。***测试、Fuzz测试,以及源代码审计都能作为一种有效的质量保证措施。独立的安全审查能够建立更安全的系统。
10、采用安全编码标准:为开发语言和平台指定安全编码标准,并采用这些标准。

转载于:https://blog.51cto.com/infosec/801492

Web安全开发注意事项相关推荐

  1. 学好web前端开发要注意哪些问题

    web前端学起来是比较困难的,当然想要学好web前端技术,那么有一些注意事项一定是要看的,下面小编就为大家详细的介绍一下学好web前端开发要注意哪些问题? ​ 学好web前端开发要注意哪些问题? 基础 ...

  2. 用 Go 语言,做 Web 编程开发

    人民邮电出版社和实验楼合作的第 15 本书来了! Web 介绍 Web 应用在我们的生活中无处不在.看看我们日常使用的各个应用程序,它们要么是 Web 应用,要么是移动 App 这类 Web 应用的变 ...

  3. 分布式系统开发注意点_分布式系统开发注意事项

    分布式系统开发注意点 开发分布式软件系统时,要考虑许多因素. 如果您甚至不知道第一句话中我在说什么,那么让我为您提供一些见解,示例以及有关分布式系统的实例. 总览 分布式系统是指多个物理硬件设备与单独 ...

  4. 分布式系统开发注意事项

    开发分布式软件系统时,要考虑许多因素. 如果您甚至不知道第一句话中我在说什么,那么让我为您提供一些见解,示例以及有关分布式系统的实例. 总览 分布式系统是指多个物理硬件设备与单独的离散用户交互并通过这 ...

  5. web项目开发人员配比_我如何找到Web开发人员的第一份工作

    web项目开发人员配比 I have always had an interest in coding for the web. I built my first site almost 15 yea ...

  6. 8年web前端开发老程序员告诉你如何零基础学习web前端

    随着web前端的飞速发展,学习web前端的人员也是越来越多,在移动 互联网 时代,相信我们每个人的手机上都装有数十个APP,这些APP的开发其实也和当下热门的 Web 前端开发息息相关. 事实上,如今 ...

  7. web应用开发入门_Web应用程序监视入门

    web应用开发入门 This article was sponsored by Monitis. Thank you for supporting the sponsors who make Site ...

  8. iPhone和Android的WEB应用开发详解

    iPhone和Android的WEB应用开发详解 在我们现在的生活中,移动设备的作用日益重要.我们使用它们进行交流.我们使用它们进行导航.我们甚至可以将它们用作方便的手电筒.面向 iPhone 和 A ...

  9. 2021-04-08 使用Eclipse进行Web前端开发

    使用Eclipse进行Web前端开发 前言 本机为微软Surface pro4,为64位,所用操作系统为Windos 10.使用的Java版本为1.8.0_151,使用的JDK版本为JDK8. 注意事 ...

最新文章

  1. Redis持久化 - RDB和AOF
  2. Java项目:医院管理系统(java+Springboot+Maven+Mybatis+Vue+Mysql)
  3. Sublime Text3 使用
  4. 萝卜家园win11 32位官方旗舰版iso文件v2021.08
  5. mac scp工具_Mac远程ssh连接乌班图并实现爬虫操作
  6. elementui 单独修改一个label的样式
  7. Word两端对齐问题
  8. Qt5.12下载和安装教程(图文详解,简单易上手)
  9. MPLS virtual private network Spoken-Hub网络实验(华为设备)
  10. WindowsServer2003 MSSQL安全
  11. Windows上将linux目录映射网络驱动器
  12. java面试题--java基础--迈达斯篇
  13. 通过代码提高编程能力
  14. linux 命令 aft,AFT整理出来的NPC检测命令大全
  15. 基于QQ空间热修复原理实践
  16. 走进小作坊(十三)----并购之战
  17. winhttp 与wininet的区别(一)
  18. 将文本转为语音文件的各种TTS
  19. 解决java.io.IOException: Cannot run program cygpath: CreateProcess error=2, 系统找不到指定的文件 的错误...
  20. 解压rar/zip工具类

热门文章

  1. Linux中screen的用法
  2. linux线程学习初步02
  3. c++中利用STL实现公司员工分组问题
  4. 函数指针指向类的静态成员函数
  5. 运行bat批处理文件不出现黑框
  6. 1091 N-自守数 (15 分)
  7. 【信号】信号集、sigprocmask、sigpending
  8. 安卓开发面试技能介绍,来一份全面的面试宝典练练手,不吃透都对不起自己
  9. java中的几种泛型类——HashSet、HashMap、TreeSet、TreeMap,遍历map,排序,HashTable比较
  10. [BZOJ3626] [LNOI2014] LCA 离线 树链剖分