一、说明

Source Insight是什么:Source Insight是一款代码编缉、浏览、分析工具。

Source Insight与文本编缉器有什么区别:Notepad++等文本编缉器也可以编缉、浏览代码,但分析能力就比较弱;如跳转函数定义处、跳转函数调用处等都无能为力。

Source Insight与集成开发环境有什么区别:IDE除了代码编缉、浏览、分析外还能编译、调试、运行;Source Insight还能存在主要是在分析方面做得更好:一是多了一个调用函数上下文窗口、二是项目全局查找功能比较好、三是前进后退比较好。

总而言之,一方面Source Insight是代码分析较好的工具。另一方面也不用太极端凡代码风析必Source Insight,你想用IDE想用Notepad都是可以的。

另外,我们这里一直说代码分析而不说代审计,是因为Source Insight和Wireshark一样并不只是为安全人员设计的,一般的程序员也会用。分析侧重于弄懂整个代码流程,审计侧重于在理解代码基础上找出漏洞。

二、安装

Source Insight是收费软件而我们喜欢使用学习版,加上安装也就是双击安装就可以了,就不多说了。

可参考链接:http://www.zdfans.com/html/18590.html

三、使用

3.1 创建项目

启动Source Insight界面如下图,依次点击Project----New Project创建项目

New project name----这里的project name是Source Insight中起的项目名,而不是待审计的项目的项目名,也就是说不管后边要审计什么项目这里想起什么名字都可以。但为了方便起见还是建议填的项目名与后续要审计的项目名一致。比如我这里后续要审计一个叫BankSystem的项目,这里的New project name也就填BankSystem。

Where do you want to store the project data files?----这个目录是用于存放记录代码审计过程中的操作步骤、配置的文件,而不是待审计项目、代码的位置,这点要搞清楚。

Project Source Directory----这里选择待审计项目的目录,下一步会从这里向项目导入代码文件(这里只是导入位置而不是真把代码复制一份进去)。

选择要添加的文件,最简单的直接点击“Add Tree”

3.2 代码审计

项目创建完成后界面如下。

右侧窗口----导入的待审查文件展现在该位置,双击即可查看文件内容。还有另外以目录形式展现等形式,自己实践时多在那点几下就懂了。

中间窗口----在左侧窗口双击文件后文件内容的展示窗口。该窗口是Source Insight的主窗口。

左侧窗口----展示当前在中间窗口打开的文件导入的库、存在的类、类的属性及方法。

底部窗口----展示当前光标指向的属性、方法的定义处的上下文。

在“代码审计思路”一文中我们说,代码审计有正向跟踪数据流和逆向追踪数据流两个思路,前者要搜索输入函数看数据是否流向漏洞签名函数,后者搜索漏洞签名函数看数据是否源于输入函数。

不管哪种思路首先需要的都是函数搜索。我们以全局搜索sql语句执行函数executeUpdate为例。

使用“Crtl+F”打开查找对话框

如果直接点击Search只会在当前主窗口打开的文件内搜索,项目全局搜索我们需要点击“Files”,勾选“Project Wide”再点击Search。

当然也可以通过主菜单----Search----Search Project唤出与下图类似的查找对话框。

查找完成后,即会出现如下图的搜索结果窗口,其中列出了当前审计项目中所有使用executeUpdate方法的位置。

点击各位置前方的红色按钮即可跳转到该位置的具体代码,使用左上角的前进后退按钮可将主窗口切换到自己前一步或后一步主窗口展示的窗口。

Source Insight 4.0安装使用教程的更多相关文章

  1. Source Insight 4.0安装后首次打开报错Unable to open or create

    错误提示大概如下: Unable to open or create ....我的文档/source insght4.0/xxx.sidb. 这个错误提示就是找不到这个文件,原因是应为有中文路径,那么 ...

  2. [转]三步完成Source Insight 4.0 破解安装

    下载地址有更新,之前有朋友因潜在的版权问题封禁没下到,现在更新后可正常使用了. 文末有完全清除上次安装残留的方法,需要的人可以参考. —— 更新于 2018.1.21 第一步:安装    安装sour ...

  3. source insight 4.0.86.0安装破解问题

    source insight 4.0.86.0安装过程中碰到导入lic文件一直不正确 解决办法: 需要将SourceInsight\SW_Install\SI4安装及破解文件 目录下的sourcein ...

  4. 三步完成Source Insight 4.0 破解安装(转)

    转自:https://blog.csdn.net/biubiuibiu/article/details/78044232 三步完成Source Insight 4.0 破解安装   下载地址有更新,之 ...

  5. source insight 4.0.086破解

     source insight 4.0.093 破解: 1. 安装原版软件:Source Insight Version 4.0.0093 - March 20, 2018 2. 替换原主程序:sou ...

  6. Source Insight 4.0 破解和使用

    参考出处: https://blog.csdn.net/u011604775/article/details/81698062 https://blog.csdn.net/user11223344ab ...

  7. source insight 4.0的基本使用方法(转)

    源:source insight 4.0的基本使用方法 source insight 4设置

  8. source insight 4.0常见问题及相关配置

    摘自:https://blog.csdn.net/liitdar/article/details/79891795     本文介绍source insight 4.0常见的问题以及相关的配置. 1. ...

  9. Source Insight 4.0配置格式化工具AStyle.exe

    Source Insight 4.0配置格式化工具AStyle.exe 摘自:https://blog.csdn.net/u012156133/article/details/81566871 1. ...

随机推荐

  1. 2018-2019-2 网络对抗技术 20165335 Exp4 恶意代码分析

    实验内容: 一.使用schtacks进行系统运行监控,使用sysmon工具监控系统的具体进程,使用各种工具进行监控,并针对软件的启动回连,安装到目标机,以及其他的控制行为的分析,同时,对主机的注册表, ...

  2. php 版本升高后 会出现 之Deprecated: Function ereg_replace() is deprecated的解决方法

    这个问题是因为php版本过高. 在php5.3中,正则函数ereg_replace已经废弃,而dedecms还继续用.有两个方案可以解决以上问题: 1.把php版本换到v5.3下. 2.继续使用v5. ...

  3. 对比剖析Swarm Kubernetes Marathon编排引擎

    Docker Native Orchestration 基本结构 Docker Engine 1.12 集成了原生的编排引擎,用以替换了之前独立的Docker Swarm项目.Docker原生集群(S ...

  4. 操作mongodb

    MongoDB数据库是以k-v形式存储在磁盘上的. import pymongoclient = pymongo.MongoClient(host='10.29.3.40',port=27017)db ...

  5. Win+E、D等快捷键失灵

    [摘要]:系统win+e等快捷键失效不能使用. [问题分析]:软件或其他操作更改了注册表信息导致. [解决方案]: 1.在开始运行输入regedit点击确定 2.在打开的注册表编辑器找到HKEY_CU ...

  6. P4859 已经没有什么好害怕的了(dp+二项式反演)

    P4859 已经没有什么好害怕的了 啥是二项式反演(转) 如果你看不太懂二项式反演(比如我) 那么只需要记住:对于某两个$g(i),f(i)$ ---------------------------- ...

  7. Apache Maven 3.6.1配置安装

    Apache Maven 3.6.1配置安装 一.下载 maven下载地址:http://maven.apache.org/download.cgi 二.安装 1,解压即可用 2,环境变量配置 MAV ...

  8. 终于有人把云计算、大数据和 AI 讲明白了

    最近学习hadoop以及生态,顺便看到了这篇文章,总结的很到位,转载下. 我今天要讲这三个话题,一个是云计算,一个大数据,一个人工智能,我为什么要讲这三个东西呢?因为这三个东西现在非常非常的火,它们之 ...

  9. PHP内核深入研究 - 数组及其遍历顺序

    事实上,广义上来讲,PHP就是C语言应用在Web上的一个模板,PHP中smarty模板用得比较多,就好比JSP是Java Servlet的模板一样(喔,对了,JSP中有个JSTL标签),复杂的模板语法 ...

  10. EntityFrameworkCore将数据库Timestamp类型在程序中转为long类型

    EntityFrameworkCore将数据库Timestamp类型在程序中转为long类型 EntityFrameworkCore Entity public class Entity { publ ...