博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
实验四
阅读量:5869 次
发布时间:2019-06-19

本文共 1756 字,大约阅读时间需要 5 分钟。

一、找出函数中存在的问题。以下题目均在Lab04项目中完成。

 

1、 某站点通过用户输入的用户名和密码(在login.jsp登录页中输入)来判断出现什么样的界面,如果是管理员(即用户名为admin或administrator)跳转到管理员页面(welcome_admin.jsp),非管理用户跳转到普通用户界面(welcome.jsp)。游客访问站点是,无需输入用户名和密码,直接进入普通用户界面(welcome.jsp)。

 

要求:找出UserOperation.java文件中的getUserRole ()方法存在的问题,说明问题产生的原因,并修改它

 

说明:不要求编写Junit单元测试用例,可以自己设想测试数据,通过静态分析,配合动态运行调试找出问题所在。

                   

解答:

问题:判断方式不安全,当普通用户或游客输入的userName为admin或者administrator将直接进入管理员页面

 

原因:只判断用户名,没有判断密码

 

修改:

    public String getUserRole(String username, String password){

       String userRole="guest";

If(null != password && !“”.equals(password)){

               If(null != username && !“”.equals(username)){

if(userName.equals("admin")||userName.equals("administrator"){

                       userRole="admin";

                     }  

              return userRole;

}

else{

                      return userRole;

}

}

else{

                  return userRole;

}

 

 

 

2、 用户注册(register.jsp)时要输入年龄字段,用户输入的参数由UserOperation.java文件中的validateUserAge()方法,转换为数值型,判断年龄是否在18~26之间(包括18和26),如果年龄在此区间内,则返回true,跳转到login.jsp页,否则弹出提示框,提示“用户年龄输入不正确”。

 

要求:找出UserOperation.java文件中的validateUserAge()方法存在的问题,说明问题产生的原因,并修改它

 

 

解答:

问题没有判断用户输入的类型:是否未输入,输入的是否符合要求,是否输入包含其他无关字符串?判断错误。

 

修改:

 

1.Jsp页面修改:

年龄:<input type="text" name="userAge" οnkeyup="value=value.replace(/[^1234567890]+/g,'')"  maxlength=”3”>

说明:加上以上限制即可限制用户只能输入最多3位数字

 

2.修改validateUserAge()方法:

 

public boolean validateUserAge(String userAge){

If(null != userAge && !“”.equals(userAge)){

            

if(Integer.parseInt(userAge)>=18 && Integer.parseInt(userAge)<=26){

                                return true;

                           }

else{

              return false;

}

               }                

else{

                return false;

}

}

 

 

 

 

 

 

 

 

二、利用黑盒测试中的等价类划分完成以下题目

 

3、某程序规定:"输入三个非0正整数 a 、 b 、 c 分别作为三边的边长构成三角形(暂不考虑特殊三角形的情况)。请根据给出的说明,用等价类划分法进行划分,并给每个等价类规定唯一的编号。

 解答:

 

所需判断

有效

无效

三位非0正整数abc

不输入0

输入0

输入

空白

输3位

缺几位或者多几位

输入正整数

输入其他字符串

构成三角形

输入的数不构成三角形

实例

所需判断

有效

无效

三位非0正整数abc

 

3    4   5

 

 0   4    0

 

3    4

A    b   5

1    1    1

转载于:https://www.cnblogs.com/linjing/p/5516732.html

你可能感兴趣的文章
高效使用微软Azure服务总线的消息功能
查看>>
试水区块链出版?纽约时报在招人了
查看>>
Google 和 Facebook 披露全球范围宕机原因
查看>>
中台之上(六):如何为一个商业银行设计业务架构?
查看>>
Facebook开源图像处理库Spectrum,优化移动端图像生成
查看>>
前端工程师必读的10篇精选技术文章
查看>>
C#特性: 只读本地变量
查看>>
克服敏捷商业智能的挑战
查看>>
从后端到前端的转变:如何选择框架?
查看>>
如何在windows下搭建Nginx+MySQL+PHP环境
查看>>
IBM核心软件如何应对“互联网+”的技术挑战
查看>>
基于Kafka实现分布式事件驱动
查看>>
24周年,“常青树”Delphi发布新版本10.3.1
查看>>
百度云首次公布具体营收,2018年Q4营收破11亿
查看>>
SciPy达到1.0版本,有了新的治理结构
查看>>
用AI种的一手好黄瓜!独家揭秘腾讯AI+农业技术实力
查看>>
PHP设计模式之注册树模式
查看>>
Laravel学习笔记之Session源码解析(下)
查看>>
ubuntu中安装oracle 11g
查看>>
使用Vagrant创建多节点虚拟机集群
查看>>