21基于java的旅游信息管理系统

项目背景

根据旅游行业的这种现状,提出解决问题的一个可行性方法,实现了旅游管理的网络化。

项目总体介绍

旅游系统设计分为前后网站和后台管理系统,功能点包含旅游景点信息分类展示、景点详情(地理位置、特色景点概述等)、下单预订等功能;
角色分为管理员和普通用户。
用户可以对旅游线路及其详细信息进行查询、预定旅游线路等。详细如下:

  1. 用户注册,登录
  2. 查看和预订旅游路线 (未登录只能查看,下同)
  3. 查看和预订旅游景点
  4. 查看和预订餐饮住宿
  5. 查看和预订旅游车票
  6. 查看和预订旅游保险
  7. 查看和预订旅游攻略
  8. 留言评论
  9. .....

管理员可以修改旅游线路信息、删除和增加旅游线路、增加和修改公告信息、留言评论管理等等,详细如下;

  1. 系统用户登录
  2. 用户管理
  3. 内容管理(包含上面所有的信息发布,管理,增删改查...)
  4. 用户订单管理
  5. 数据统计(包括用户分析,路线分析,景点分析,酒店分析等等)
  6. ....

项目搭建环境

> java jdk版本:1.8及以上
> 后台框架:java spring springmvc mybatis springbotoot等
> 前端框架:html css javascript vue等
> 开发工具: idea或者eclipse都可
> 数据库: mysql 5.7及以上
> 服务器: tomcat
> 更多内容可查看:http://projecthelp.top

部分核心代码

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>

系统截图

下面仅展示部分主要功能

系统用户端

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

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

  • 旅游路线查看
    在这里插入图片描述

  • 查看旅游景点
    在这里插入图片描述
    在这里插入图片描述

  • 查看旅游车票和餐饮住宿
    在这里插入图片描述

  • 注意事项
    在这里插入图片描述

系统管理端

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

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

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

-系统用户管理
在这里插入图片描述

  • 内容管理
    包括旅游路线,旅游景点,酒店管理,留言管理等等(下面以旅游路线为例)
    在这里插入图片描述
    新增:
    在这里插入图片描述
    修改:
    在这里插入图片描述
  • 订单管理
    在这里插入图片描述
  • 用户分析
    在这里插入图片描述
  • 路线分析
    在这里插入图片描述
  • 景点分析
    在这里插入图片描述
  • 酒店分析
    在这里插入图片描述
  • 订单分析
    在这里插入图片描述
  • 攻略分析
    在这里插入图片描述
  • 车票分析
    在这里插入图片描述
  • 保险分析
    在这里插入图片描述

系统完整

在这里插入图片描述

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

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:21基于java的旅游信息管理系统 - Python技术站

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

相关文章

  • java实现异步导出数据

    为了让读者更加易懂,本文将采用三个部分讲解异步导出数据。 1. 后端实现异步导出 对于导出数据这种后端耗时较长的操作,我们一般采用异步导出的方式来解决。下面是后端实现异步导出的主要步骤: 1.1 前端发起导出请求,后端生成导出任务 前端发起导出请求时,后端会先生成一个唯一的任务id,将任务id返回给前端,并把导出任务存储到数据库中。 1.2 后端异步执行导出…

    Java 2023年5月26日
    00
  • Java大文件上传详解及实例代码

    Java大文件上传详解及实例代码 介绍 Java大文件上传是web开发中比较基础的功能,常用于图片、视频等大文件的上传。基于HTTP协议的限制,一般的文件上传有大小限制,一般为1M,甚至更小。本篇文章将介绍如何使用Java实现大文件上传,并提供示例代码。 实现方案 为了实现大文件上传功能,我们可以采用分片上传的策略,将大文件切分成多个片段进行上传。具体的实现…

    Java 2023年5月20日
    00
  • java实现单链表中的增删改

    让我们来讲解一下Java实现单链表中的增删改的完整攻略。 一、单链表概述 单链表是一种线性数据结构,它是由若干个节点组成,每个节点包含两部分,一部分是存储数据的元素,另一部分是指向下一个节点的指针。单链表的头节点没有前驱节点,尾节点没有后继节点。 单链表常用的操作有插入、删除、修改和查询,其中插入和删除操作是单链表的核心操作。 二、Java单链表实现 下面我…

    Java 2023年5月19日
    00
  • Java中Properties类的操作实例详解

    Java中Properties类的操作实例详解 Properties类是什么? Properties类是Java中常用的一个类,主要用于处理属性文件。属性文件是一种配置文件,其中包含了键值对,用于保存程序运行时需要动态设置的参数值,例如数据库连接参数、日志输出级别等等。 Properties类的基本用法 Properties类位于java.util包中,可以…

    Java 2023年6月15日
    00
  • java正则表达式实现提取需要的字符并放入数组【ArrayList数组去重复功能】

    针对这个问题,我将分成两个部分进行回答。 第一部分:Java正则表达式实现提取需要的字符并放入数组 基本概念 正则表达式是用于描述字符串模式的一个表达式。可以根据正则表达式来匹配、查找、替换符合特定模式的文本。在 Java 中,正则表达式需要使用java.util.regex包中的类来实现。 正则表达式语法 下面是常用的正则表达式语法: . 匹配任何一个字符…

    Java 2023年5月26日
    00
  • 从搭建Struts2 开发环境说起

    下面我将详细介绍“从搭建Struts2 开发环境说起”的完整攻略。 1. 安装Java环境 在使用 Struts2 开发前,首先需要安装 Java 开发环境。可以到官网下载并安装 JDK,这里我以 JDK 1.8 为例。 下载JDK 1.8安装包,并安装到你的电脑上。 配置JAVA_HOME环境变量,将JDK安装路径添加到PATH环境变量中,以便在命令行中可…

    Java 2023年5月20日
    00
  • YII2.0框架行为(Behavior)深入详解

    下面针对”YII2.0框架行为(Behavior)深入详解”进行详细讲解,并且提供两个示例说明。 什么是行为(Behavior) 行为是 Yii 2 中一个非常重要的概念,它常常被用来实现代码复用及属性的自定义处理。通俗点来说,行为可以看作是一种类的特殊封装。在 Yii 2 中,每个行为可以封装一个函数或者一组函数。 行为的分类 可以把行为分为两种:普通行为…

    Java 2023年6月15日
    00
  • Java对象的销毁过程是什么?

    Java对象的销毁过程即垃圾回收过程,在Java语言中由垃圾回收器自动处理。当对象不再被引用时,就会进入垃圾回收流程,最终被回收。下面是对Java对象销毁过程的详细讲解。 对象生命周期 Java对象从创建到销毁的过程称为对象的生命周期。在Java中,对象的生命周期有三个阶段:创建阶段、使用阶段和回收阶段。 在创建阶段,对象被分配在堆上,成为可达对象。 在使用…

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