26基于java的电影院售票管理系统设计

项目背景

随着互联网和电子商务的快速发展,开发一个电影院订票系统来帮助电影院对电影信息,售票信息进行统一化的信息管理;

项目简短介绍

项目首先分为俩个用户端,一个是管理员后台,手机APP端,管理后端负责对系统功能上面的管理;app端负责查询影片,然后评论,购买影片等等;

项目环境

前端:html, css, js, vue, jquery,h5等;
后端:java, spring,maven等
开发工具:mysql,
支持eclipse或idea
更多内容可查看:项目帮

部分核心代码

import org.springframework.stereotype.Service;
import xyz.shiguangliang.mybatis.dao.UserMapper;

import xyz.shiguangliang.mybatis.domain.User;
import xyz.shiguangliang.service.UserService;
import xyz.shiguangliang.util.query.QueryInfo;

import javax.annotation.Resource;
import java.util.Date;
import java.util.List;
import java.util.Objects;

@Service
public class UserServiceImpl implements UserService {
    @Resource
    private UserMapper userMapper;

    //登录
    @Override
    public User login(String username, String password) {
        User user = userMapper.selectLogin(username,password);
        if (user != null) {
            //登录次数加一
            if (user.getIntimes() !=  null) {
                user.setIntimes(user.getIntimes() + 1);
            }else {
                user.setIntimes(1);
            }
            //更新登录时间
            user.setLastlogin(new Date());
            return user;
        }
        return null;
    }

    //注册
    @Override
    public boolean register(User user) {
        int i = 0;
        //检测用户是否存在
        User user1 = userMapper.selectUsername(user.getUsername());
        if (user1 == null) {
            i = userMapper.insert(user);
        }
        return i > 0;
    }

    //用户列表
    @Override
    public QueryInfo getUserList(String query, Integer pagenum,Integer pagesize) {
        QueryInfo queryInfo = new QueryInfo();
        int start;
        int end;
        if (pagenum == null||pagesize == null){
            pagenum =0;
            pagesize = 3;
        }
        start = (pagenum-1)*pagesize;
        end = pagesize;
        int userSize = userMapper.selectUserListLimitSize(query,start,end);
        List<User> users = userMapper.selectUserListLimit(query,start,end);
        queryInfo.setList(users);
        queryInfo.setTotal(userSize);
        return queryInfo;
    }

    //删除用户
    @Override
    public int deleteUser(Integer tid) {
        return userMapper.deleteByPrimaryKey(tid);
    }

    //通过id查找用户
    @Override
    public User findById(Integer tid) {
        return userMapper.selectByPrimaryKey(tid);
    }



    //更新用户
    @Override
    public int updateUser(User user) {
        if (user.getPassword()==null|| Objects.equals(user.getPassword(), "")){
            user.setPassword(userMapper.selectByPrimaryKey(user.getTid()).getPassword());
        }
        return userMapper.updateByPrimaryKey(user);
    }

    //通过用户名查找用户
    @Override
    public User findByUsername(String username) {
        return userMapper.selectUsername(username);
    }

    //获取用户权限
    @Override
    public int getPower(String username) {
        return userMapper.selectUsername(username).getPower();
    }
}

useMapper.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="xyz.shiguangliang.mybatis.dao.UserMapper">
  <resultMap id="BaseResultMap" type="xyz.shiguangliang.mybatis.domain.User">
    <id column="tid" jdbcType="INTEGER" property="tid" />
    <result column="username" jdbcType="VARCHAR" property="username" />
    <result column="password" jdbcType="VARCHAR" property="password" />
    <result column="teachername" jdbcType="VARCHAR" property="teachername" />
    <result column="dno" jdbcType="INTEGER" property="dno" />
    <result column="power" jdbcType="INTEGER" property="power" />
    <result column="intimes" jdbcType="INTEGER" property="intimes" />
    <result column="lastlogin" jdbcType="TIMESTAMP" property="lastlogin" />
  </resultMap>
  <delete id="deleteByPrimaryKey" parameterType="java.lang.Integer">
    delete from teacher
    where tid = #{tid,jdbcType=INTEGER}
  </delete>
  <insert id="insert" parameterType="xyz.shiguangliang.mybatis.domain.User">
    insert into teacher (tid, username, password, 
      teachername, dno, power, 
      intimes, lastlogin)
    values (#{tid,jdbcType=INTEGER}, #{username,jdbcType=VARCHAR}, #{password,jdbcType=VARCHAR}, 
      #{teachername,jdbcType=VARCHAR}, #{dno,jdbcType=INTEGER}, #{power,jdbcType=INTEGER}, 
      #{intimes,jdbcType=INTEGER}, #{lastlogin,jdbcType=TIMESTAMP})
  </insert>
  <update id="updateByPrimaryKey" parameterType="xyz.shiguangliang.mybatis.domain.User">
    update teacher
    set username = #{username,jdbcType=VARCHAR},
      password = #{password,jdbcType=VARCHAR},
      teachername = #{teachername,jdbcType=VARCHAR},
      dno = #{dno,jdbcType=INTEGER},
      power = #{power,jdbcType=INTEGER},
      intimes = #{intimes,jdbcType=INTEGER},
      lastlogin = #{lastlogin,jdbcType=TIMESTAMP}
    where tid = #{tid,jdbcType=INTEGER}
  </update>
  <select id="selectByPrimaryKey" parameterType="java.lang.Integer" resultMap="BaseResultMap">
    select tid, username, password, teachername, dno, power, intimes, lastlogin
    from teacher
    where tid = #{tid,jdbcType=INTEGER}
  </select>
  <select id="selectAll" resultMap="BaseResultMap">
    select tid, username, password, teachername, dno, power, intimes, lastlogin
    from teacher
  </select>
    <select id="selectLogin" resultType="xyz.shiguangliang.mybatis.domain.User">
        select tid, username, password, teachername, dno, power, intimes, lastlogin
        from teacher
        where username = #{username} and password = #{password}
    </select>
  <select id="selectUsername" resultType="xyz.shiguangliang.mybatis.domain.User">
    select tid, username, password, teachername, dno, power, intimes, lastlogin
        from teacher
        where username = #{username}
  </select>
  <select id="selectUserListLimit" resultType="xyz.shiguangliang.mybatis.domain.User">
    select tid, username, password, teachername, dno, power, intimes, lastlogin
    from teacher
    where
    /*条件判断*/
    <if test="#{query} != null and #{query} != ''">
      /*模糊查询*/
      <bind name="query2" value="'%' + query + '%'"/>
      username like #{query2}
    </if>
    LIMIT #{start},#{end}
  </select>
  <select id="selectUserListLimitSize" resultType="java.lang.Integer">
    select count(*)
    from teacher
    where
    /*条件判断*/
    <if test="#{query} != null and #{query} != ''">
      /*模糊查询*/
      <bind name="query2" value="'%' + query + '%'"/>
      username like #{query2}
    </if>
  </select>
</mapper>

项目展示

管理后台

  • 登录
    在这里插入图片描述

  • 数据显示
    在这里插入图片描述

  • 用户管理
    在这里插入图片描述

  • 电影管理
    在这里插入图片描述

  • 影院管理
    在这里插入图片描述

  • 影厅管理
    在这里插入图片描述

  • 电影排片
    在这里插入图片描述

  • 评论管理
    在这里插入图片描述

  • 订单管理
    在这里插入图片描述

APP端

  • 登录
    在这里插入图片描述

  • 个人详情页
    在这里插入图片描述

  • 修改信息
    在这里插入图片描述

  • 首页
    在这里插入图片描述

  • 电影详情页面
    在这里插入图片描述

  • 正在热映和即将上映
    在这里插入图片描述

  • 影院查看
    在这里插入图片描述

  • 我的订单
    在这里插入图片描述

系统完整

在这里插入图片描述

原文链接:https://www.cnblogs.com/projecthelp/p/17376512.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:26基于java的电影院售票管理系统设计 - Python技术站

(0)
上一篇 2023年5月6日
下一篇 2023年5月6日

相关文章

  • java时间戳转日期格式的实现代码

    下面是Java时间戳转日期格式的实现代码的完整攻略。 问题背景 时间戳是指从某个固定时间(如 1970年1月1日00:00:00 UTC)起经过的毫秒数,通常用于记录某个时间点的信息。在Java开发中,我们经常需要将时间戳转换为可读的日期格式,以便于显示、存储等操作。 实现步骤 Java提供了多种方式将时间戳转化为日期格式,最常用的方式是使用SimpleDa…

    Java 2023年5月20日
    00
  • Java的Struts框架中的if/else标签使用详解

    Java的Struts框架是一个经典的MVC框架,在Struts的JSP视图中,提供了强大的标签库。其中包括if / else标签,通过它可以实现条件判断,根据不同的条件进行不同的分支处理。接下来,我将详细讲解Java的Struts框架中if/else标签的使用方法。 1. 定义if/else标签 使用if/else标签之前,我们需要在JSP文件中定义这两个…

    Java 2023年5月20日
    00
  • springdata jpa使用Example快速实现动态查询功能

    下面是Spring Data JPA使用Example快速实现动态查询功能的完整攻略。 什么是Spring Data JPA Spring Data JPA 是Spring框架的一项子项目,它基于 Hibernate 实现了 JPA 规范,提供了一种简化 JPA 数据访问层的方法。 利用Spring Data JPA实现动态查询 使用Spring Data …

    Java 2023年5月20日
    00
  • SQL入侵恢复xp_cmdshell方法总结

    SQL入侵恢复xp_cmdshell方法总结 什么是SQL入侵及xp_cmdshell SQL入侵是指黑客通过SQL漏洞进入数据库系统,进行一系列的恶意攻击。其中,xp_cmdshell是SQL Server的一种特殊存储过程,允许在服务器上执行操作系统的命令。 恢复xp_cmdshell方法 如果xp_cmdshell在SQL入侵后被禁用,可以通过以下步骤…

    Java 2023年6月15日
    00
  • Java C++算法题解leetcode801使序列递增的最小交换次数

    让我来详细讲解一下“Java C++算法题解leetcode801使序列递增的最小交换次数”的完整攻略。 问题描述 题目名称:使序列递增的最小交换次数 题目描述:给定一个数组 nums,你需要将数组连续的子序列进行升序排列,使得最终得到的数组是递增的。请你计算并返回最少的交换次数,使得数组满足题意。 示例 1: 输入:nums = [1,3,5,4,2,6,…

    Java 2023年5月26日
    00
  • java实现网页爬虫的示例讲解

    下面就是Java实现网页爬虫的完整攻略,包括流程、注意事项和示例说明。 流程 网页爬虫的实现流程如下: 定义目标网页地址,并通过Java代码中的URL类创建URL对象。 通过URL对象打开连接并获取输入流,读取目标网页的HTML源代码。 利用正则表达式等方法,从源代码中提取想要的数据或链接。 如果需要,将提取的数据存储到数据库等地方。 如果有链接需要继续抓取…

    Java 2023年5月18日
    00
  • Spring学习笔记之bean生命周期

    Spring学习笔记之Bean生命周期 什么是Bean生命周期 在Spring容器中,当我们需要获取一个Bean实例时,会经历一系列的过程,包括BeanDefinition解析、Bean实例化、属性注入和初始化等操作,最终才能得到我们所需要的Bean实例。这整个过程就称之为Bean生命周期。 Bean生命周期可以分为以下几个阶段: 实例化:根据BeanDef…

    Java 2023年5月31日
    00
  • 详解Maven多模块打包遇到的问题解决方法

    当我们使用Maven进行多模块开发时,需要用到Maven的多模块打包功能来打包整个项目,但是在实际使用过程中,往往会遇到一些问题。本文将详解使用Maven多模块打包时可能会遇到的问题,并给出解决方法。 问题一:打包时找不到依赖 在使用Maven进行多模块开发时,我们将项目拆分成多个模块,每个模块都有自己的pom.xml文件来管理依赖。但是当我们使用Maven…

    Java 2023年5月19日
    00
合作推广
合作推广
分享本页
返回顶部