当前位置: 首页 > news >正文

中国做外国网购的网站爱站seo综合查询

中国做外国网购的网站,爱站seo综合查询,网站怎么做访问日志,网站建设起来还需要花钱吗最近在学习CodeQL,对于CodeQL就不介绍了,目前网上一搜一大把。本系列是学习CodeQL的个人学习笔记,根据个人知识库笔记修改整理而来的,分享出来共同学习。个人觉得QL的语法比较反人类,至少与目前主流的这些OOP语言相比&…

最近在学习CodeQL,对于CodeQL就不介绍了,目前网上一搜一大把。本系列是学习CodeQL的个人学习笔记,根据个人知识库笔记修改整理而来的,分享出来共同学习。个人觉得QL的语法比较反人类,至少与目前主流的这些OOP语言相比,还是有一定难度的。与现在网上的大多数所谓CodeQL教程不同,本系列基于官方文档和情景实例,包含大量的个人理解、思考和延伸,直入主题,只切要害,几乎没有废话,并且坚持用从每一个实例中学习总结归纳,再到实例中验证。希望能给各位一点不一样的见解和思路。当然,也正是如此必定会包含一定的错误,希望各位大佬能在评论区留言指正。


为了更好的阅读体验,请访问个人博客

CodeQL学习笔记(1)

CodeQL学习笔记(2)

CodeQL学习笔记(3)

CodeQL学习笔记(4)


2. AST节点

AST中节点的成分,主要两类:

  • Stmt:语句(Statement)
  • Expr:表达式(Expression)

这两个类中也提供了一些成员谓词:

  • Expr.getAChildExpr 返回一个当前表达式的子表达式
  • Stmt.getAChild 返回直接嵌套在给定语句中的语句或者表达式
  • Expr.getParent and Stmt.getParent 返回一个AST节点的父节点

返回return stmt中的表达式:

import java
from Expr e
where e.getParent() instanceof ReturnStmt
select e

返回If stmt中的表达式:

import javafrom Stmt s
where s.getParent() instanceof IfStmt
select s

这样会将if语句的then和else都找到。

返回所有方法体中的语句:

import java
from Stmt s
where s.getParent() instanceof Method
select s

Method-Stmt-Expr

CodeQL提供了两个类:ExprParent 和 StmtExpr

来表示Expr和Stmt的父节点

3. 元数据

这里主要介绍针对Java中的Annotion注释

包、引用类型、字段、方法、构造函数和局部变量声明 具有超类 Annotatable,因此他们都具有getAnAnnotation方法

import javafrom Constructor c
select c.getAnAnnotation()

以上例子能够找到所有结构体的注释(抑制警告或将代码标记为已弃用的示例)

例如下面这个例子,能找到所有注释为@Deprecated的构造函数

import java
from Constructor cs, Annotation at, AnnotationType attp
where cs.getAnAnnotation() = at andat.getType() = attp andattp.hasQualifiedName("java.lang", "Deprecated")
select at

4. 指标

在前期学习中不涉及

5. 调用图

用来表示函数或构造函数的调用关系。

Callable表示可以被调用的代码单元,包括方法(函数)和构造函数。

Call表示一次调用的表达式。比如一次方法调用a.foo()、new 表达式new MyClass(),以及通过 this 或 super 的显式构造函数调用。

通过Call.getCallee()谓词找到某个调用表达式所调用的方法或构造函数。如果我们想找出所有对方法 println 的调用,可以编写如下查询:

import javafrom Call c, Method m
where m = c.getCallee() andm.hasName("println")
select c
  • Call c 表示一个调用表达式,Method m 表示一个方法。
  • c.getCallee() 获取调用表达式 c 所调用的方法或构造函数,这里我们用 m = c.getCallee() 来确保该调用表达式的目标是方法
  • m.hasName(“println”) 用于过滤出名字为 println 的方法。

这个查询的输出结果就是程序中所有调用 println 方法的地方。

此外,还可以通过Callable.getAReference()谓词来反向查找所有引用了某个可调用对象的调用表达式,如果找不到,则说明这个Callable的东西从未被调用过。如下ql查询就能找到所有未被调用的方法或构造函数

import javafrom Callable c
where not exists(c.getAReference())
select c
http://www.hrbkazy.com/news/26249.html

相关文章:

  • 上海网站设计流程常用搜索引擎有哪些
  • 口碑营销论文网站内部seo优化包括
  • 北京网站制作设计公司排名阿里指数在哪里看
  • 平台网站建设公司哪家好百度搜索引擎盘搜搜
  • 网站改成自适应360推广登录平台
  • wordpress 金融主题seo排名优化是什么
  • 熊猫头表情包制作网站关键词搜索
  • cms网站建设系统软文发稿
  • 搬瓦工vps做网站速度怎么样营销方案怎么写
  • 做设计网站模块的网站万能bt搜索引擎
  • wap网站建设站内seo和站外seo区别
  • 网站建设 合同互动营销策略
  • 网站开发毕业设计代做有什么好的网站吗
  • 帮传销组织做网站seo推广薪资
  • 群辉docker安装wordpressseo教程之关键词是什么
  • 湖州网站制作报价湖北seo推广
  • 河南省建设招投标网站郑州网站seo公司
  • 建设银行成都市第九支行 网站手机优化大师下载
  • 网页怎么写google seo是什么意思
  • 怎么做网站转让机制 银行账户对接seo企业培训班
  • seo整站优化方法外贸建站服务推广公司
  • 网站关键字排名怎么做国外网站搭建
  • 网站制作 徐州国家免费技能培训有哪些
  • 信息分类网站建设爱网站查询挖掘工具
  • 360的网站排名怎么做九江seo优化
  • 茂名企业建站模板企业网络营销案例分析
  • 手机可怎么样做网站针对大学生推广引流
  • 企业网站怎么做推广打广告在哪里打最有效
  • 做类似电影天堂的网站违法吗企业网站优化哪家好
  • 山西网站群建设投放广告找什么平台