我们本节需要进行后端代码的编写,打开zhengjiao.html:
我们上节已经成功提取了数据,接下来去写一个请求:
请求中,我们传递的这个参数,变成字符串格式即可。
然后去urls.py中架构好映射:
最后去views_tools.py中写好这个 函数:
我们先写成这样。接收参数后看一下,它长什么样:
数据如下:
后台显示如下:
可以看到 是一个列表。
接下来就是正交的算法了,我尽量讲的明白一些,大家能听懂就听,听不懂也没事。
首先正交算法是又一个第三方库的:
代码语言:javascript复制allpairspy
通过pip 即可安装。这个引入要这么写:
这里我们要注意一下,实际上,我们前面html中得到这个end_keys,是没有什么意义的,简单来说,就是没用。正交并不关心这个输入叫什么。
所以在我们的正交算法中,用到的只有 end_values
这个AllPairs方法呢,需要的是一个二维列表,每个元素就是一个输入条件,这个元素本身也是列表,这个子列表的每个元素就是这个输入条件的子状态。
所以我们要把目前的这个end_values,再进行改造:
重启服务后,我们再次打印如下:
这时候,就可以直接使用这个正交库方法了:
我们做了一个循环,打印一下,看看里面的是什么?
结果如下:
没错,这就是正交生成的最终用例,每个i就是一个用例,每个元素就是对应输入条件此刻应该生效的子状态。
我们现在要做的就是把这个二维数组,返回给前端页面,为了保证原始构造,我们仍然放到一个字典中返回:
代码语言:javascript复制# 正交工具运行
def zhengjiao_play(request):
end_values = request.GET['end_values'].split(',')
new_values = [ i.split('/') for i in end_values ]
res = []
for i in AllPairs(new_values):
res.append(i)
d = { "res" : res}
return HttpResponse(json.dumps(d),content_type="application/json")
我们返回前端js中,接收下:
打印了一下,看看前端收到的对不对:
可以在console中看到,一切正常!
到这,我们的后端就算实现成功了。很简答对不对。
下一节,就是把这个结果,显示到页面给使用者看喽~