JavaWeb项目-超市订单管理系统【Day02】

news2024/11/26 20:50:38

 

密码修改

1、编写接口方法和mybatis的SQL映射文件

Mybatis配置多参数SQL语句

当我们的SQL语句中有多个参数的时候,需要设置每个参数名对应的接口参数,不然会报错: Parameter ‘id’ not found. Available parameters are [argl, argg, paraml, param2)

在接口中使用注解

import org.apache.ibatis.annotations.Param;

//...
    //修改用户密码
    int updatePassword(@Param("password") String password, @Param("id") int id);

一定要注意标签的名字!!!修改语句是update 别上来就select

    <update id="updatePassword">
        update smbms.smbms_user set userPassword = #{password} where id = #{id}
    </update>

2、UserDao层实现修改方法与数据库交互

在UserDao添加如下方法,这里实现了调用了UserMapper的方法,使得业务代码在这里完成。

注意:mybatis执行增删改这三种语句一定要记得提交事务,否则不生效!!!

//修改当前用户密码
    public boolean modifyPassword(int id,String password){

        boolean flag = false;

        SqlSession sqlSession = MybatisUtils.getSqlSession();

        UserMapper mapper = sqlSession.getMapper(UserMapper.class);

        int res = mapper.updatePassword(password, id);

        //修改语句必须提交事务
        sqlSession.commit();

        if (res > 0){
            flag = true;
        }
        sqlSession.close();

        return flag;
    }

3、编写可复用的Servlet

我们这里要做的修改密码,后期还会有用户的增加删除,显然一个Servlet只实现一个功能太臃肿了。

这里还需要注意,method是我们修改密码是提交的表单form的一个属性,我们获取到method属性后需要先判断是否为空再去判断它的值是修改还是增加或删除。

import com.lyh.dao.UserDao;
import com.lyh.pojo.User;
import com.lyh.utils.Constant;
import com.mysql.cj.util.StringUtils;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

public class UserServlet extends HttpServlet {

    //这个Servlet会处用户的增删改 所以需要在这里定义三个方法
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

        //实现Servlet复用
        String method = req.getParameter("method");
        if (method!=null && method.equals("savepwd")){//保证method不为空很重要
            this.updatePwd(req,resp);
        }

    }

    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        doGet(req, resp);
    }

    public void updatePwd(HttpServletRequest req, HttpServletResponse resp){
        //获取Session
        Object user = req.getSession().getAttribute(Constant.USER_SESSION);

        String newpassword = req.getParameter("newpassword");

        boolean flag = false;

        if (user != null && !StringUtils.isNullOrEmpty(newpassword)){
            UserDao dao = new UserDao();
            flag = dao.modifyPassword(((User) user).getId(), newpassword);
            if (flag){
                req.setAttribute("message","修改密码成功,请退出重新登录");
                //移除session 重新登录
                req.getSession().removeAttribute(Constant.USER_SESSION);
            }else {//修改失败
                req.setAttribute("message","密码修改失败");

            }
        }else {
            req.setAttribute("message","新密码有问题");
        }

        try {
            req.getRequestDispatcher("pwdmodify.jsp").forward(req,resp);
        } catch (ServletException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

配置Servlet映射

    <servlet>
        <servlet-name>UserServlet</servlet-name>
        <servlet-class>com.lyh.servlet.user.UserServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>UserServlet</servlet-name>
        <url-pattern>/jsp/user.do</url-pattern>
    </servlet-mapping>

添加修改界面

将pwdmodify.jsp复制到webapp/jsp/下

用户管理

1、用户数量统计

1、在接口定义三种统计不同身份用户数量的方法:

//根据用户名或者用户角色查询用户总数
    int getUserCount();

    //根据姓名模糊查询
    int getUserCountByName(String name);

    //根据身份编号查询用户 1-管理员 2-经理 3-员工
    int getUserCountByRole(int role);

2、在UserMapper.xml中实现SQL:

<select id="getUserCount" resultType="int">
        select count(1) as count from smbms.smbms_user u,smbms.smbms_role r where u.userRole = r.id
    </select>

    <select id="getUserCountByRole" parameterType="int" resultType="int">
        select count(1) as count from smbms.smbms_user u,smbms.smbms_role r where u.userRole = r.id and u.userRole = #{role}
    </select>

    <select id="getUserCountByName" parameterType="String" resultType="int">
        select count(1) as count from smbms.smbms_user u,smbms.smbms_role r where u.userRole = r.id and u.userName like #{name}
    </select>

3、在UserDao中实现SQL参数传递:

//查询总用户数量
    public int getUserCount(){

        SqlSession sqlSession = MybatisUtils.getSqlSession();

        UserMapper mapper = sqlSession.getMapper(UserMapper.class);


        int count = mapper.getUserCount();

        sqlSession.close();

        return count;
    }

    //根据用户身份查询数量 1-管理员 2-经理 3-员工
    public int getUserCountByRole(int role){
        int count = 0;
        SqlSession sqlSession = MybatisUtils.getSqlSession();

        UserMapper mapper = sqlSession.getMapper(UserMapper.class);

        if (role==0){//如果是0就查询全部
            count = mapper.getUserCount();
        }else {
            count = mapper.getUserCountByRole(role);
        }
        sqlSession.close();

        return count;
    }

    public int getUserCountByName(String name){

        name = "%"+name+"%";

        SqlSession sqlSession = MybatisUtils.getSqlSession();

        UserMapper mapper = sqlSession.getMapper(UserMapper.class);

        int count = mapper.getUserCountByName(name);

        sqlSession.close();

        return count;
    }

2、用户列表 

1、在接口定义三种统计不同身份用户列表的方法:

//分页展示所有用户列表
    List<User> getUserList(@Param("currentPage") int currentPage,@Param("pageSize") int pageSize);

    //根据姓名模糊查询并返回用户列表
    List<User> getUserListByName(@Param("name") String name,@Param("currentPage") int currentPage,@Param("pageSize") int pageSize);
  
    //根据身份编号查询用户列表 1-管理员 2-经理 3-员工
    List<User> getUserListByRole(@Param("role") int role,@Param("currentPage") int currentPage,@Param("pageSize") int pageSize);

2、在UserMapper.xml中实现SQL:

    <select id="getUserList" resultType="User">
        select * from smbms_user su join smbms_role sr on su.userRole = sr.id
        order by su.id DESC limit #{currentPage},#{pageSize}
    </select>

    <select id="getUserListByName" resultType="User">
        select * from smbms_user su join smbms_role sr on su.userRole = sr.id
            and su.userName like #{name}
        order by su.id DESC limit #{currentPage},#{pageSize}
    </select>

    <select id="getUserListByRole" resultType="User">
        select * from smbms_user su join smbms_role sr on su.userRole = sr.id
            and su.userRole = #{role}
        order by su.id DESC limit #{currentPage},#{pageSize}
    </select>

3、在UserDao中实现SQL参数传递:

    public List<User> getUserList(int currentPage,int pageSize){
        SqlSession sqlSession = MybatisUtils.getSqlSession();

        UserMapper mapper = sqlSession.getMapper(UserMapper.class);

        currentPage = (currentPage-1)*pageSize;

        List<User> userList = mapper.getUserList(0, 5);

        return userList;
    }

    public List<User> getUserListByName(String name,int currentPage,int pageSize){
        name = "%"+name+"%";

        SqlSession sqlSession = MybatisUtils.getSqlSession();

        UserMapper mapper = sqlSession.getMapper(UserMapper.class);

        List<User> userList = mapper.getUserListByName(name, currentPage, pageSize);

        sqlSession.close();

        return userList;
    }
    public List<User> getUserListByRole(int role,int currentPage,int pageSize){
        List<User> userList = new ArrayList<User>();

        SqlSession sqlSession = MybatisUtils.getSqlSession();

        UserMapper mapper = sqlSession.getMapper(UserMapper.class);

        if (role==0){//如果是0就查询全部
           userList = mapper.getUserList(currentPage, pageSize);
        }else {
            userList = mapper.getUserListByRole(role,currentPage,pageSize);
        }
        sqlSession.close();

        return userList;
    }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/722390.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【设计模式】第十二章:观察者模式详解及应用案例

系列文章 【设计模式】七大设计原则 【设计模式】第一章&#xff1a;单例模式 【设计模式】第二章&#xff1a;工厂模式 【设计模式】第三章&#xff1a;建造者模式 【设计模式】第四章&#xff1a;原型模式 【设计模式】第五章&#xff1a;适配器模式 【设计模式】第六章&…

chatGPT如何开启 Browsing 功能,实现即时联网查询?

Openai 为每一个 chatGPT Plus 用户都开放了 Browsing 和 plugins 功能。 前者可以在 ChatGPT 觉得有必要的时候&#xff08;比如你问它今天的新闻&#xff09;&#xff0c;自动联网查询&#xff0c;后者是第三方开发者开发的插件&#xff0c;数量繁多&#xff0c;可以解决各种…

Git 常用操作总结

版本控制系统&#xff08;VCS&#xff09;是管理文件和目录所做的更改的工具&#xff0c;每一次提交便记录下目录及其文件的内容&#xff0c;以及较上一版本的更改。通过这样去跟踪项目的更改过程&#xff0c;方便与他人进行协作&#xff0c;或者撤销不想要的更改以回退到此前的…

DR模式部署LVS负载均衡集群

目录 一、配置负载调度器 1.配置虚拟 IP 地址&#xff08;VIP&#xff1a;192.168.146.180&#xff09; 2.调整 proc 响应参数 3. 配置负载分配策略 ​编辑二、部署共享存储&#xff08;NFS服务器&#xff1a;192.168.146.20&#xff09; 三、配置节点服务器 1.配置虚拟…

解决vue中mapbox地图显示一半的问题

解决vue中mapbox地图显示一半的问题 问题描述&#xff1a; 在vue中创建mapbox地图&#xff0c;地图只显示一般&#xff0c;查看浏览器开发者工具。发现将canvas.mapboxgl-canvas 的position:absolute去掉就解决了 。 代码修改&#xff1a;获取到canvas.mapboxgl-canvas,并修改…

zookeeper第一课-Zookeeper特性与节点数据类型详解

1、Zookeeper特性与节点数据类型详解 ZooKeeper 是一个开源的分布式协调框架&#xff0c;是Apache Hadoop 的一个子项目&#xff0c;主要用来解决分布式集群中应用系统的一致性问题。 Zookeeper 的设计目标是将那些复杂且容易出错的分布式一致性服务封装起来&#xff0c;构成一…

在Linux中部署ELK架构

ELK&#xff08;ElasticSearch分布式搜索引擎、Logstash数据收集处理引擎和Kibana可视化化平台&#xff09;是在大型后端架构中&#xff0c;一个标准的数据采集方案。 在公网IP为x.x.x.x的服务器上部署Elasticsearch LogstashfilebeatredisKibana架构。这种架构先通过Logstash…

高并发场景:redis+lua防重校验

大家平时在做有并发量下单的项目时&#xff0c;代码层面基本上就分为这么几个步骤&#xff1a;参数校验--->防重校验--->库存校验扣减--->下单成功--->支付。 最近公司有个商城项目说要30分钟达到1亿的并发量。当时听到突然猛了一下。真是牛逼克拉斯呀。 不过该说…

apache php mysql python 环境部署与离线安装deb包

文章目录 1.背景介绍2. 主要涉及操作2.1 安装系统&#xff1a;2.2 apache mysql php安装2.3 配置2.4 python相关库安装 3. 操作记录3.1 软件安装3.2 读取文件内容后进行文件内容抽取3.3 执行以上的sh脚本3.4 所学3.5 打包发送 4. 参考文献 1.背景介绍 使用的系统为ubuntu18.04…

密码学学习笔记(四):Authenticated Encryption - 认证加密

加密数据的最新方法是使用一种称为一体式结构的认证加密算法&#xff0c;该算法也称为有附加数据的认证加密。从之前的博客中&#xff0c;我们看到在特定的操作模式中使用的分组密码&#xff0c;如CBC、OFB、CFB、CTR&#xff0c;提供了IND-CPA安全性。 但是IND-CCA安全性呢&a…

电脑卡顿甚至崩溃?那重置系统吧

我们平时用电脑&#xff0c;最怕遇到蓝屏、死机、报错&#xff0c;等等问题。有时还会碰到些奇奇怪怪的系统问题 文章目录 问题场景&#xff1a;解决方案&#xff1a;一、重启电脑二、移除外接设备三、系统还原1、设置系统还原2、如何进行系统还原3、系统还原失败怎么办 四、卸…

有源差分探头的电压限定和检查步骤

为了使传统示波器能够显示和测试高共模电压的电路波形&#xff0c;有源差分探头对示波器测量性能延伸到了电子功率变换器、 逆变器、 电机的速度控制、 开关电源和许多应用程序的测试。 差分探头外观构成&#xff1a; A-输出线&#xff1a;连接示波器的 BNC 输出连接头和辅助性…

【操作系统】c语言--进程调度算法(FCFS和SPN)

创作不易&#xff0c;本篇文章如果帮助到了你&#xff0c;还请点赞 关注支持一下♡>&#x16966;<)!! 主页专栏有更多知识&#xff0c;如有疑问欢迎大家指正讨论&#xff0c;共同进步&#xff01; &#x1f525;c系列专栏&#xff1a;C/C零基础到精通 &#x1f525; 给大…

Docker轻量级可视化工具Portainer

掌握Portainer的部署和使用。 Portainer 是一款轻量级的应用&#xff0c;它提供了图形化界面&#xff0c;用于方便地管理Docker环境&#xff0c;包括单机环境和集群环境。 Portainer&#xff08;https://www.portainer.io/&#xff09;是一个流行的开源Docker管理工具&#xff…

【设计模式】第八章:桥接模式详解及应用案例

系列文章 【设计模式】七大设计原则 【设计模式】第一章&#xff1a;单例模式 【设计模式】第二章&#xff1a;工厂模式 【设计模式】第三章&#xff1a;建造者模式 【设计模式】第四章&#xff1a;原型模式 【设计模式】第五章&#xff1a;适配器模式 【设计模式】第六章&…

前端为什么使用svg图片

参考链接&#xff1a; 1.http://www.youngzi.cn/5392.html 2.https://baijiahao.baidu.com/s?id1728784571128338709&wfrspider&forpc SVG是什么&#xff1f;SVG有什么用&#xff1f;为什么要使用SVG&#xff1f;本篇文章就给大家介绍一下SVG的相关知识&#xff0c;让…

【Unity】HyBridCLR初探

完成目标: 创建热更新程序集加载热更新程序集,并执行其中热更新代码,打印 Hello, HybridCLR修改热更新代码,打印 Hello, World准备环境​ 安装Unity HybridCLR也支持2019.4.x,但新手请先按照下面要求跑通流程后,再根据安装HybridCLR文档尝试2019.4.x。 安装 2020.3.26+…

如何部署LVS负载均衡集群(DR模式)

目录 一、集群概念与NAT模式LVS集群 二、部署LVS集群&#xff08;DR模式&#xff09; 第一步 关闭防火墙和安全机制 第二步 手动配置ip_vs 第三步 安装ipvsadm工具 第四步 创建虚拟网卡 第五步 修改虚拟网卡配置内容 第六步 开启虚拟网卡并加入路由 第七步 调整proc相…

linux学习(韩顺平 一周学会linux)

b站链接&#xff1a;b站 共27个小时 P3-P85 linux基础篇 P86-P90 java定制篇 P91-P107 大数据shell篇 P108-P115 python定制篇 P117-P141 linux高级篇 P142-P153 面试题 四个阶段&#xff1a; 一、基本操作 二、配置 三、搭建开发环境 四、写一些基本的shell脚本 五、安全设置…

list容器语法

文章目录 listlist基本概念list的优点&#xff1a;list的缺点&#xff1a;重要性质 list 的使用方法list构造函数list 赋值和交换list 长度/大小操作list 插入元素和删除元素访问list 反转和排序sort链表排序案例forward_list&#xff08;C11&#xff09;forward_list 的使用方…