商标注册在哪个网_简历制作网站咋免费_网站创意分为哪几个阶段_动图在线制作 4 二手动漫周边交易网站详细设计与实现

二手动漫周边交易网站的详细设计与实现主要是根据前面的二手动漫周边交易网站的需求分析和二手动漫周边交易网站的总体设计来设计页面并实现业务逻辑。主要从二手动漫周边交易网站界面实现、业务逻辑实现这两部分进行介绍。

4.1用户功能模块

4.1.1 前台首页界面

当进入二手动漫周边交易网站的时候,首先映入眼帘的是系统的导航栏,下面是轮播图以及系统内容,其主界面展示如下图4-1所示。

图4-1 前台首页界面图

4.1.2注册界面

不是二手动漫周边交易网站中正式用户的是可以在线进行注册的,如果你没有本二手动漫周边交易网站的账号的话,添加“注册”,当填写上自己的账号+密码+确认密码+昵称+邮箱+手机号等后再点击“注册”按钮后将会先验证输入的有没有空数据,再次验证密码和确认密码是否是一样的,最后验证输入的账户名和数据库表中已经注册的账户名是否重复,只有都验证没问题后即可用户注册成功。其用用户注册界面展示如下图4-2所示。

图4-2 前台注册界面图

注册逻辑代码如下:

  /**

     * 注册

     * @param user

     * @return

     */

    @PostMapping("register")

    public Map<String, Object> signUp(@RequestBody User user) {

        // 查询用户

        Map<String, String> query = new HashMap<>();

        Map<String,Object> map = JSON.parseObject(JSON.toJSONString(user));

        query.put("username",user.getUsername());

        List list = service.selectBaseList(service.select(query, new HashMap<>()));

        if (list.size()>0){

            return error(30000, "用户已存在");

        }

        map.put("password",service.encryption(String.valueOf(map.get("password"))));

        service.insert(map);

        return success(1);

}     

4.1.3 登录界面

二手动漫周边交易网站中的前台上注册后的用户是可以通过自己的账户名和密码进行登录的,当用户输入完整的自己的账户名和密码信息并点击“登录”按钮后,将会首先验证输入的有没有空数据,再次验证输入的账户名+密码和数据库中当前保存的用户信息是否一致,只有在一致后将会登录成功并自动跳转到二手动漫周边交易网站的首页中;否则将会提示相应错误信息,用户登录界面如下图4-3所示。

图4-3登录界面图

登录的逻辑代码如下所示:

/**

     * 登录

     * @param data

     * @param httpServletRequest

     * @return

     */

    @PostMapping("login")

    public Map<String, Object> login(@RequestBody Map<String, String> data, HttpServletRequest httpServletRequest) {

        log.info("[执行登录接口]");

        String username = data.get("username");

        String email = data.get("email");

        String phone = data.get("phone");

        String password = data.get("password");

        List resultList = null;

        Map<String, String> map = new HashMap<>();

        if(username != null && "".equals(username) == false){

            map.put("username", username);

            resultList = service.selectBaseList(service.select(map, new HashMap<>()));

        }

        else if(email != null && "".equals(email) == false){

            map.put("email", email);

            resultList = service.selectBaseList(service.select(map, new HashMap<>()));

        }

        else if(phone != null && "".equals(phone) == false){

            map.put("phone", phone);

            resultList = service.selectBaseList(service.select(map, new HashMap<>()));

        }else{

            return error(30000, "账号或密码不能为空");

        }

        if (resultList == null || password == null) {

            return error(30000, "账号或密码不能为空");

        }

        //判断是否有这个用户

        if (resultList.size()<=0){

            return error(30000,"用户不存在");

        }

        User byUsername = (User) resultList.get(0);

        Map<String, String> groupMap = new HashMap<>();

        groupMap.put("name",byUsername.getUserGroup());

        List groupList = userGroupService.selectBaseList(userGroupService.select(groupMap, new HashMap<>()));

        if (groupList.size()<1){

            return error(30000,"用户组不存在");

        }

        UserGroup userGroup = (UserGroup) groupList.get(0);

        //查询用户审核状态

        if (!StringUtils.isEmpty(userGroup.getSourceTable())){

            String res = service.selectExamineState(userGroup.getSourceTable(),byUsername.getUserId());

            if (res==null){

                return error(30000,"用户不存在");

            }

            if (!res.equals("已通过")){

                return error(30000,"该用户审核未通过");

            }

        }

        //查询用户状态

        if (byUsername.getState()!=1){

            return error(30000,"用户非可用状态,不能登录");

        }

        String md5password = service.encryption(password);

        if (byUsername.getPassword().equals(md5password)) {

            // 存储Token到数据库

            AccessToken accessToken = new AccessToken();

            accessToken.setToken(UUID.randomUUID().toString().replaceAll("-", ""));

            accessToken.setUser_id(byUsername.getUserId());

            Duration duration = Duration.ofSeconds(7200L);

            redisTemplate.opsForValue().set(accessToken.getToken(), accessToken,duration);

            // 返回用户信息

            JSONObject user = JSONObject.parseObject(JSONObject.toJSONString(byUsername));

            user.put("token", accessToken.getToken());

            JSONObject ret = new JSONObject();

            ret.put("obj",user);

            return success(ret);

        } else {

            return error(30000, "账号或密码不正确");

        }

    }

4.1.4商城资讯界面

用当访客点击二手动漫周边交易网站 中导航栏上的“商城资讯”后将会进入到该“商城资讯”列表的界面,然后选择想要看的商城资讯,点击进入到详细界面,同时可以进行点赞、收藏、评论操作,商城资讯界面如下图4.4 所示。

图4-4商城资讯界面图

4.1.5 购物车界面

当用户点击导航栏上的“购物车”菜单后,会出现自己加入购物车的商品列表,在购物车页面可以对商品删除、修改商品的数量,选择部分或者全选进行购买,购物车界面如下图4-5所示。

图4-5购物车界面图

4.1.6 商品详情界面

当访客点击了任意商品后将会进入该款商品的详情界面,可以了解到该商品的图片信息、商品信息、价钱信息等,同时可以对该商品进行立即购买+收藏+点赞+评论,商品详情展示页面如图4-6所示。

                          

图4-6 商品详情界面图

4.1.7我的订单界面

当用户点击“我的订单”链接后就进入自己购买的订单的界面展示,界面如下图4-7所示。

图4-7 我的订单界面图

4.2管理员功能模块

4.2.1系统用户管理界面

管理员点击“系统用户”这一菜单会显示管理员、卖家和普通用户这三个子菜单,管理员可以对这三个角色的信息进行增删改查操作。界面如下图4-8所示。

图4-8系统用户管理界面图

系统用户管理关键代码如下:

@PostMapping("/set")

@Transactional

    public Map<String, Object> set(HttpServletRequest request) throws IOException {

        service.update(service.readQuery(request), service.readConfig(request), service.readBody(request.getReader()));

        return success(1);

    }

4.2.2取消通知公告管理界面

管理员点击“取消订单”会显示出所有的取消订单信息,支持通过订单编号或者取消时间对取消订单信息进行查询,如果想要添加新的取消订单信息,点击“添加”按钮,输入相关信息,点击“提交”按钮就可以添加了,同时可以选择某一条取消订单信息,点击“删除”进行删除,界面如下图4-9所示。

图4-9取消通知公告管理界面图

取消订单管理关键代码如下:

 @PostMapping("/add")

    @Transactional

    public Map<String, Object> add(HttpServletRequest request) throws IOException {

        service.insert(service.readBody(request.getReader()));

        return success(1);

    }

public Map<String, Object> addMap(Map<String,Object> map){

    service.insert(map);

     return success(1);

 }

4.2.3通知公告管理界面

管理员点击“通知公告管理”菜单可以查看到系统中的所有通知公告信息,对已经存在的通知公告,管理员可以修改,也可以添加新的通知公告或者删除通知公告,界面如下图4-10所示。

图4-10通知公告管理界面图

通知公告管理关键代码如下:

  @RequestMapping(value = "/del")

    @Transactional

    public Map<String, Object> del(HttpServletRequest request) {

        service.delete(service.readQuery(request), service.readConfig(request));

        return success(1);

    }

    public void delete(Map<String,String> query,Map<String,String> config){

        QueryWrapper wrapper = new QueryWrapper<E>();

        toWhereWrapper(query, "0".equals(config.get(FindConfig.GROUP_BY)),wrapper);

        baseMapper.delete(wrapper);

        log.info("[{}] - 删除操作:{}",wrapper.getSqlSelect());

    }

4.2.4 商城管理界面

二手动漫周边交易网站中的管理人员是可以对二手动漫周边交易网站内卖家发布的商品进行维护和管理的,支持增删改查操作,商城管理界面如下图4-11所示。

图4-11商城管理界面图

5系统测试

5.1系统测试的目的

系统开发到了最后一个阶段那就是系统测试,系统测试对软件的开发其实是非常有必要的。因为没什么系统一经开发出来就可能会尽善尽美,再厉害的系统开发工程师也会在系统开发的时候出现纰漏,系统测试能够较好的改正一些bug,为后期系统的维护性提供很好的支持。通过系统测试,开发人员也可以建立自己对系统的信心,为后期的系统版本的跟新提供支持。

5.2 系统测试用例

系统测试包括:用户登录功能测试、商品展示功能测试、商品添加、商品搜索、密码修改功能测试,如表5-1、5-2、5-3、5-4、5-5所示:

用户登录功能测试:

表5-1 用户登录功能测试表

用例名称

用户登录系统

目的

测试用户通过正确的用户名和密码可否登录功能

前提

未登录的情况下

测试流程

1) 进入登录页面

2) 输入正确的用户名和密码

预期结果

用户名和密码正确的时候,跳转到登录成功界面,反之则显示错误信息,提示重新输入

实际结果

实际结果与预期结果一致

商品查看功能测试:

表5-2 商品查看功能测试表

用例名称

商品查看

目的

测试商品查看功能

前提

用户登录

测试流程

点击商品列表

预期结果

可以查看到所有商品信息

实际结果

实际结果与预期结果一致

管理员添加商品界面测试:

表5-3 管理员添加商品界面测试表

用例名称

商品发布测试用例

目的

测试商品发布功能

前提

用户正常登录情况下

测试流程

1)点击商品信息管理就,然后点击添加后并填写信息。

2)点击进行提交。

预期结果

提交以后,页面首页会显示新的商品信息 

实际结果

实际结果与预期结果一致

商品搜索功能测试:

表5-4商品搜索功能测试表

用例名称

商品搜索测试

目的

测试商品搜索功能

前提

测试流程

1)在搜索框填入搜索关键字。

2)点击搜索按钮。

预期结果

页面显示包含有搜索关键字的商品

实际结果

实际结果与预期结果一致

密码修改功能测试:

表5-5 密码修改功能测试表

用例名称

密码修改测试用例

目的

测试管理员密码修改功能

前提

管理员用户正常登录情况下

测试流程

1)管理员密码修改并完成填写。

2)点击进行提交。

预期结果

使用新的密码可以登录

实际结果

实际结果与预期结果一致

5.3 系统测试结果

通过编写二手动漫周边交易网站的测试用例,已经检测完毕用户登录模块、商品查看模块、商品添加模块、商品搜索模块、密码修改功能测试,通过这5大模块为二手动漫周边交易网站的后期推广运营提供了强力的技术支撑。

">

住建部标准合同模板

东莞最近有疫情吗、绥化网站设计、永久使用、不限域名、黄骅港海洋天气g

郑州电力高等专科学校校训?

商标注册在哪个网_简历制作网站咋免费_网站创意分为哪几个阶段_动图在线制作

  • 在IDE中创建一个新的Web项目,通常这包括指定项目的名称、位置以及使用的服务器(如Tomcat)。
  • IDE会自动生成一些基础目录结构,如src(存放Java代码)、WebContentwebapp(存放JSP、HTML、CSS、JavaScript等资源)。
网络编程语言或技术企业形象墙效果图大全总结网站推广策划书的共同点沈阳疫情最新消息通知低代码开发平台应用梧州市委网站最新足球比赛结果500诸城网站制作哪家服务好华秋电子商城官网网络工程师需要学多久上海景焯文化传媒有限公司重大疾病险一年保费多少钱秦皇岛旺淘科技有限公司官网微信短链接生成项目网格化工作职责网络app制作软件湖州人才网招聘网官方网天河城什么是电子商务的基础黄骅港盐百地址财务软件app网址搜索记录怎么删除东莞建网站的公司推荐河北燕郊最新消息精品网站设计课程版面设计五年级美术廊坊网络推广平台西安小寨附近的景点开发区行政服务中心电话上海设计公司注册方案建工网校怎么样 靠谱吗

猜你喜欢

  • 友情链接:
  • 精准营销助手 如何找到上海的免费网站推荐 企业做多个网站推广 兰州疫情最新消息通告 制作二维码打印网站 西安设计