• Joern安装与使用


    环境准备

    Joern需要在Linux环境中运行,所以在Windows系统中需要借助WSL或虚拟机安装。

    JDK安装

    Joern的运行需要JAVA环境的支持,本次采用的是JDK17,其他版本建议看一下Joern官方文档

    apt install openjdk-17-jre-headless

    配置JAVA环境变量

    安装Vim
    sudo apt-get install vim
    添加环境变量
    sudo vim /etc/environment
    在文件最后添加
    JAVA_HOME=“/usr/lib/jvm/java-17-openjdk-amd64/bin/java”
    重新加载环境
    source /etc/environment

    安装Joern(用时较久)

    sudo snap install curl
    mkdir joern && cd joern
    curl -L “https://github.com/joernio/joern/releases/latest/download/joern-install.sh” -o joern-install.sh
    chmod u+x joern-install.sh
    ./joern-install.sh --interactive

    启动Joern

    在这里插入图片描述

    可视化

    Joern的可视化依赖于对应工具

    sudo apt-get install graphviz
    sudo apt-get install graphviz graphviz-doc
    sudo apt-get install xdot

    在启动的控制台中,需要先导入项目

    importCode(inputPath=“./planning”, projectName=“planning”)
    下次可以使用以下命令打开
    open(“planning”)
    注:导入JAVA文件时目标是jar,C文件时目标是文件夹

    利用不同命令可以绘制对应图形
    Abstract Syntax Trees (抽象语法树)
    Control Flow Graphs (控制流图)
    Control Dependence Graphs (控制依赖图)
    Data Dependence Graphs (数据依赖图)
    Program Dependence graphs (程序依赖图)

    cpg.method($name).plotDotAst…
    输出文本形式

    cpg.method($name).dotAst.l…

    在这里插入图片描述

    常用命令

    在这里插入图片描述列出分析结果
    在这里插入图片描述一些方法统计可能存在错误,测试的时候虽然传入了完整的Planning模块代码,但对照函数似乎只解析了Common中的文件(可能支持拓展)

  • 相关阅读:
    T8161B T8403 T8448 ICS TRIPLEX 具有支持物联网边缘的计算机视觉
    基于JavaWeb的学生成绩管理系统
    jvm类加载机制,双亲委派机制,juc
    TypeScript学习 + 贪吃蛇项目
    Java 的异常体系
    MyBatis的各种查询功能
    MindSpore:对image作normalize的目的是什么?
    【LeetCode刷题笔记】栈和队列
    【网络工程】计算机网络专业术语概述全面整理
    Stable Diffusion 参数介绍及用法
  • 原文地址:https://blog.csdn.net/WTMDNM_/article/details/134492512