DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
factory.setExpandEntityReferences(false);
(3) 过滤用户提交的 XML 数据:
比如 !DOCTYPE、<!ENTITY、SYSTEM、PUBLIC 等。
XML 注入防范
严重性中,可能性低。
(1) 教研用户输入(推荐白名单):
OutputFormat format = OutputFormat.createPrettyPrint();
(2) 使用安全的 XML 库(比如 dom4j)。
URL 重定向防范
严重性中,可能性低。
(1) 设置严格白名单及网络边界:
String url = request.getParameter(“url”);
String host = getHostFromUrl(url);
if(!validateHost(host)) {
return;
}
(2) 加入有效性验证的 Token;
(3) referer 适用于检测监控 URL 重定向、CSRF 等,多数场景下也可用作防范措施。
异常处理
====
编码原则:不要泄露详细异常信息。
敏感信息泄露防范
严重性低,可能性中。
屏蔽敏感信息示例:
catch(IOException e) {
System.out.println(“Invalid file”);
// System.out.println(“Error code: 0001”);
return;
}
保持对象一致性
严重性中,可能性低。
(1) 重排逻辑,使得产生异常的代码在改变对象状态的代码之前执行;
catch(Exception e) {
// revert
money -= PADDING;
return -1;
}
(2) 在出现异常导致操作失败的情况下,使用事务回滚机制;
(3) 在对象的临时拷贝上执行操作,成功后再提交给正式的对象;
(4) 回避修改对象的需求,尽量不去修改对象。
I/O 操作
=======
编码规则:可写的文件不可执行,可执行的文件不可写。
资源释放
严重性低,可能性高。
Java 垃圾回收器回自动释放内存资源,非内存资源需要开发人员手动释放,比如 DataBase,Files,Sockets,Streams,Synchronization 等资源的释放。
try {
Connection conn = getConnection();
Statement statement = conn.createStatement();
ResultSet resultSet = statement.executeQuery(sqlQuery);
processResults(resultSet);
} catch(SQLException e) {
// forward to handler
} finally {
if (null != conn) {
conn.close();
}
}
清除临时文件
严重性中,可能性中。
(1) 自动清除:
File tempFile = Files.createTempFile(“tempname”, “.tmp”);
try {
BufferedWriter writer = Files.newBufferedWriter(tempFile.toPath(),
StandardCharsets.UTF_8, StandardOpenOption.DELETE_ON_CLOSE)
// operate the file
writer.newLine();
} catch (IOException e) {
e.printStackTrace();
}
(2) 手动清除。
避免将 bufer 暴露给不可信代码
严重性中,可能性中。
wrap、duplicate 创建的 buffer 应该以只读或拷贝的方式返回:
Charbuffer buffer;
public Duplicator() {
buffer = CharBuffer.allocate(10);
}
/** 获取只读的 Buffer */
public CharBuffer getBufferCopy() {
return buffer.asReadOnlyBuffer();
}
任意文件下载/路径遍历防范
严重性中,可能性高。
(1) 校验用户可控的参数(推荐白名单);
(2) 文件路径保存到数据库,让用户提交文件对应的 ID 去下载文件:
<%
String filePath = getFilePath(request.getParameter(“id”));
download(filePath);
%>
(3) 判断目录和文件名:
if(!“/somedir/”.equals(filePath) || !“jpg”.equals(fileType)) {
…
return -1;
}
(4) 下载文件前做权限判断。
补充:禁止将敏感文件(如日志文件、配置文件、数据库文件等)存放在 web 内容目录下。
非法文件上传防范
严重性高,可能性中。
在服务器端用白名单方式过滤文件类型,使用随机数改写文件名和文件路径。
if(!ESAPI.validator().isValidFileName(
“upload”, filename, allowedExtensions, false)) {
throw new ValidationUploadException(“upload error”);
}
补充:如果使用第三方编辑器,请及时更新版本。
序列化/反序列化操作
==========
编码原则:不信任原则。
敏感数据禁止序列化
严重性高,可能性低。
使用 transient、serialPersistentFields 标注敏感数据:
private static final ObjectStreamField[] serialPersistentFields = {
new ObjectStreamField(“name”, String.class),
new ObjectStreamField(“age”, Integer.TYPE)
}
当然,正确加密的敏感数据可以序列化。
正确使用安全管理器
严重性高,可能性低。
如果一个类的构造方法中含有各种安全管理器的检查,在反序列化时也要进行检查:
private void writeObject(ObjectOutputStream out) throws IOException {
performSecurityManagerChek();
out.writeObject(xxx);
}
补充:第三方组件造成的反序列化漏洞可通过更新升级组件解决;
禁止 JVM 执行外部命令,可减小序列化漏洞造成的危害。
运行环境
====
编码原则:攻击面最小化原则。
不要禁用字节码验证
严重性中,可能性低。
启用 Java 字节码验证:Java -Xverify:all ApplicationName
不要远程调试/监控生产环境的应用
严重性高,可能性低。
(1) 生产环境中安装默认的安全管理器,并且不要使用 -agentlib,-Xrunjdwp 和 -Xdebug 命令行参数:
${JAVA_HOME}/bin/java -Djava.security.manager ApplicationName
(2) iptables 中关闭相应 jdwp 对外访问的端口。
生产应用只能有一个入口
严重性中,可能性中。
移除项目中多余的 main 方法。
本人从事网路安全工作12年,曾在2个大厂工作过,安全服务、售后服务、售前、攻防比赛、安全讲师、销售经理等职位都做过,对这个行业了解比较全面。
最近遍览了各种网络安全类的文章,内容参差不齐,其中不伐有大佬倾力教学,也有各种不良机构浑水摸鱼,在收到几条私信,发现大家对一套完整的系统的网络安全从学习路线到学习资料,甚至是工具有着不小的需求。
最后,我将这部分内容融会贯通成了一套282G的网络安全资料包,所有类目条理清晰,知识点层层递进,需要的小伙伴可以点击下方小卡片领取哦!下面就开始进入正题,如何从一个萌新一步一步进入网络安全行业。
学习路线图
其中最为瞩目也是最为基础的就是网络安全学习路线图,这里我给大家分享一份打磨了3个月,已经更新到4.0版本的网络安全学习路线图。
相比起繁琐的文字,还是生动的视频教程更加适合零基础的同学们学习,这里也是整理了一份与上述学习路线一一对应的网络安全视频教程。
网络安全工具箱
当然,当你入门之后,仅仅是视频教程已经不能满足你的需求了,你肯定需要学习各种工具的使用以及大量的实战项目,这里也分享一份我自己整理的网络安全入门工具以及使用教程和实战。
项目实战
最后就是项目实战,这里带来的是SRC资料&HW资料,毕竟实战是检验真理的唯一标准嘛~
面试题
归根结底,我们的最终目的都是为了就业,所以这份结合了多位朋友的亲身经验打磨的面试题合集你绝对不能错过!
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!