GO语言(十六):模糊测试入门(上)本教程介绍了 Go 中模糊测试的基础知识 。通过模糊测试,随机数据会针对您的测试运行,以尝试找出漏洞或导致崩溃的输入 。可以通过模糊测试发现的一些漏洞示例包括 SQL 注入、缓冲区溢出、拒绝服务和跨站点脚本攻击 。
在本教程中,您将为一个简单的函数编写一个模糊测试,运行 go 命令 , 并调试和修复代码中的问题 。
首先,为您要编写的代码创建一个文件夹 。
1、打开命令提示符并切换到您的主目录 。
在 Linux 或 Mac 上:
在 Windows 上:
2、在命令提示符下,为您的代码创建一个名为 fuzz 的目录 。
3、创建一个模块来保存您的代码 。
运行go mod init命令,为其提供新代码的模块路径 。
接下来,您将添加一些简单的代码来反转字符串,稍后我们将对其进行模糊测试 。
在此步骤中,您将添加一个函数来反转字符串 。
a.使用您的文本编辑器,在 fuzz 目录中创建一个名为 main.go 的文件 。
独立程序(与库相反)始终位于 package 中main 。
此函数将接受string,使用byte进行循环 , 并在最后返回反转的字符串 。
此函数将运行一些Reverse操作 , 然后将输出打印到命令行 。这有助于查看运行中的代码,并可能有助于调试 。
e.该main函数使用 fmt 包,因此您需要导入它 。
第一行代码应如下所示:
从包含 main.go 的目录中的命令行,运行代码 。
可以看到原来的字符串,反转它的结果,然后再反转它的结果,就相当于原来的了 。
现在代码正在运行,是时候测试它了 。
在这一步中,您将为Reverse函数编写一个基本的单元测试 。
a.使用您的文本编辑器,在 fuzz 目录中创建一个名为 reverse_test.go 的文件 。
b.将以下代码粘贴到 reverse_test.go 中 。
这个简单的测试将断言列出的输入字符串将被正确反转 。
使用运行单元测试go test
接下来,您将单元测试更改为模糊测试 。
单元测试有局限性 , 即每个输入都必须由开发人员添加到测试中 。模糊测试的一个好处是它可以为您的代码提供输入,并且可以识别您提出的测试用例没有达到的边缘用例 。
在本节中,您将单元测试转换为模糊测试 , 这样您就可以用更少的工作生成更多的输入!
请注意,您可以将单元测试、基准测试和模糊测试保存在同一个 *_test.go 文件中,但对于本示例,您将单元测试转换为模糊测试 。
在您的文本编辑器中,将 reverse_test.go 中的单元测试替换为以下模糊测试 。
Fuzzing 也有一些限制 。在您的单元测试中,您可以预测Reverse函数的预期输出 , 并验证实际输出是否满足这些预期 。
例如,在测试用例Reverse("Hello, world")中,单元测试将返回指定为"dlrow ,olleH".
模糊测试时 , 您无法预测预期输出,因为您无法控制输入 。
但是,Reverse您可以在模糊测试中验证函数的一些属性 。在这个模糊测试中检查的两个属性是:
(1)将字符串反转两次保留原始值
(2)反转的字符串将其状态保留为有效的 UTF-8 。
注意单元测试和模糊测试之间的语法差异:
(3)确保新包unicode/utf8已导入 。
随着单元测试转换为模糊测试,是时候再次运行测试了 。
a.在不进行模糊测试的情况下运行模糊测试 , 以确保种子输入通过 。
如果您在该文件中有其他测试,您也可以运行go test -run=FuzzReverse,并且您只想运行模糊测试 。
b.运行FuzzReverse模糊测试 , 查看是否有任何随机生成的字符串输入会导致失败 。这是使用go test新标志-fuzz执行的 。
模糊测试时发生故障,导致问题的输入被写入将在下次运行的种子语料库文件中go test,即使没有-fuzz标志也是如此 。要查看导致失败的输入,请在文本编辑器中打开写入 testdata/fuzz/FuzzReverse 目录的语料库文件 。您的种子语料库文件可能包含不同的字符串,但格式相同 。
语料库文件的第一行表示编码版本 。以下每一行代表构成语料库条目的每种类型的值 。由于 fuzz target 只需要 1 个输入 , 因此版本之后只有 1 个值 。
c.运行没有-fuzz标志的go test; 新的失败种子语料库条目将被使用:
由于我们的测试失败,是时候调试了 。
请推荐一个永久免费的云服务器?国外的一些免费服务器限制流量,国内免费的服务器额度又很低 , 毕竟免费的午餐不好吃 。
如果你有技术,就去磐石云参加“你搞技术,我出资源”活动 。
这是磐石云推出的扶持计划,通过视频/教程内容可置换服务器,最久可长达一年 。
给的云服务器上海区的:
2HCPU4G内存5M带宽50G系统盘、4HCPU8G内存10M带宽50G系统盘 。
如果你有更多需求 , 就凭技术去谈一谈 。
置换规则:
技术牛人准备已制作好的视频教程内容/脚本,磐石云客服取得联系.
符合条件的教程类型:
1、开源软件使用视频教程
2、服务器软件搭建环境教程
3、一键脚本
4、集成镜像
5、游戏服务器搭建教程
可参考产品教程类型:
1、网盘类(seafile、ownCloud、Cloudreve、kiftd、nextcloud等)
2、建站类(建站软件使用、论坛、博客、电商等)
3、服务类(域名、SSL、备案等)
4、游戏类(无论版权的各种游戏服务端)
5、系统工具(多平台的系统工具使用,例如linux远程、ftp传输等)
资源须同时符合以下标准:
1、使用开源软件 。
2、视频必须提供高清录屏素材(附带技术文档或说明文档) 。
3、提供对应内容所使用到的代码、脚本 。
搭建软件教程参考产品推荐:
1、Owncloud(网盘)
2、Monibuca流媒体服务器
3、OBS直播-推流服务器搭建使用
4、WordPress 博客软件
5、BIND(Berkeley Internet Name Domain Server)DNS服务器软件
6、MySQL数据
7、离线下载lxdl 离线下载文件到中转服务器,用户从中转服务器下载文件到本地
8、微商城小程序jpshop快速搭建属于自己的社区团购-微商城系统
9、邮件服务器Dovecot
10、音乐服务器Mopidy
11、go语言验证码服务器gocaptcha
有哪些免费的云服务器?推荐一款我正在使用的免费云服务器——阿贝云 。
在阿贝云上可以申请免费的虚拟主机和免费的云服务器 。具体步骤是:
1.打开阿贝云网站注册账号
2.实名认证(测试期间只要0.3元就可以)
3.开通免费云服务器
golang验证码怎么搞go语言验证码识别我用go语言验证码识别的是这个captcha包go语言验证码识别:
支持net/http 和 fasthttpgo语言验证码识别,不过目前仅支持数字验证码
【go语言验证码识别 golang验证码生成】关于go语言验证码识别和golang验证码生成的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息 , 记得收藏关注本站 。
推荐阅读
- 河南gis保温罩采购,河南省保温厚度最新标准
- thinkphp查询,thinkphp查询去除重复值
- 电商如何做大,怎样把电商做大
- Linux命令行添加文本 linux 添加命令
- 包含sqlserverpost的词条
- 直升机飞行员游戏手游攻略,直升机飞行员训练项目
- Linux基础命令的分类 linux基本命令总结
- 电商如何涨粉,电商怎么提升销量
- 铜山区如何大数据营销,大数据营销解决方案