Git Product home page Git Product logo

printf-like-checker's Introduction

printf-like-checker

c/c++类printf,fprintf,scanf等字符串拼接安全性检查工具

1:c/c++的这些字符串操作,经常因为传入类型不合法导致各种崩溃,都是血泪教训

2:无需改变大部分人的编程习惯,无需引入其他库或自己扫描拼接等代码,例如FMT

3:基本无需修改项目代码,开发人员还是按照教科书上教大家的方式编写代码(普通字符串拼接,日志拼接,MYSQL Statment模式拼接SQL语句等)

4:仅借助GCC编译的警告等信息,通过编写大量的SHELL过滤代码即可实现;该方式完全可以放置在自动化编译的最后一步

接入步骤

1:修改项目编译脚本,编译时支持以下参数:-Werror=format-contains-nul -Werror=format-extra-args -Werror=format-zero-length -Werror=format-nonliteral -Wall
2:假定项目通过CMAKE编译,目标文件名Server,参考./linux_compiler.sh中的扫描一,二,三(尤其是三,还可以继续扩展规则),一旦发现编译输出文件中有不合法警告,则编译失败,开发人员查看all_printf_like_error.txt文件

printf-like-checker's People

Contributors

guanzhongdaoke avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.