基于Spring Boot的自驾游攻略查询系统

发布时间:2024-11-14 18:27

目录

前言

 一、技术栈

二、系统功能介绍

三、核心代码

1、登录模块

 2、文件上传模块

3、代码封装

前言

当今社会已经步入了科学技术进步和经济社会快速发展的新时期,国际信息和学术交流也不断加强,计算机技术对经济社会发展和人民生活改善的影响也日益突出,人类的生存和思考方式也产生了变化。传统自驾游攻略查询采取了人工的管理方法,但这种管理方法存在着许多弊端,比如效率低下、安全性低以及信息传输的不准确等,同时由于自驾游攻略查询中会形成众多的个人文档和信息系统数据,通过人工方法对旅游景点、旅游游记、旅游路线等进行集中管理会形成检索、更改和维护等较为麻烦的管理问题,同时由于广大用户对网络技术的需求也日益高涨,于是信息技术也需要继续开展全新的改革以满足时代的需求。根据此问题,研发一套自驾游攻略查询系统,既能够大大提高信息的检索、变更与维护的工作效率,也能够方便信息系统的管理运用,从而减少信息管理成本,提高效率。

该自驾游攻略查询系统采用B/S架构进行设计,并采用java语言以及springboot框架进行开发。该系统主要设计并完成了管理过程中的用户注册登录、个人信息修改、用户、景点类型、旅游景点、旅游游记、分类标签、旅游路线等功能。该系统操作简便,界面设计简洁,不但可以基本满足本行业的日常管理工作,同时又可以有效减少人员成本和时间成本,为自驾游攻略查询管理工作提供了方便。

 一、技术栈

末尾获取源码
Spring Boot+JS+ jQuery+Ajax...

二、系统功能介绍

当游客打开系统的网址后,首先看到的就是首页界面。在这里,游客能够看到自驾游攻略查询系统的导航条显示首页、旅游景点、旅游游记、旅游路线、综合资讯、后台管理等,如图5-1所示。

 当用户进入前台系统进行相关操作前必须先注册登录,在注册页面填写用户账号、密码、确认密码、用户姓名、性别、年龄、头像、用户手机、身份证、用户住址、邮箱等信息,然后点击注册,如图5-2所示。

 用户登录,用户在登录页面通过填写账号、密码,完成登录,如图5-3所示。

 用户点击旅游游记,在旅游游记页面的搜索栏输入游记标题,进行查询,然后可以查看游记标题、封面图片、旅游景点、用户账号、用户姓名、分类标签、发布时间等信息,还可以点击收藏或者评论等操作,如图5-4所示。 

 用户点击旅游路线,在旅游路线页面的搜索栏输入路线名称、景点名称,进行查询,然后可以查看路线名称、景点名称、景区分类、景点地址、线路图片、起点、途径路段、终点、行程天数、旅行社、联系方式、路线价格、点击次数等信息,还可以点击收藏或者评论等操作,如图5-5所示。 

 用户点击个人中心,在个人中心页面可以修改个人信息、密码修改,还可以对我的收藏进行详细操作,如图5-6所示。

 后台管理员登录,在登录页面选择需要登录的角色,在正确输入用户名和密码后,进入操作系统进行操作;如图5-7所示。    

 管理员进入系统主页面,主要功能包括对系统首页、个人中心、用户管理、景点类型管理、旅游景点管理、旅游游记管理、分类标签管理、旅游路线管理、系统管理等进行操作。如图5-8所示:

 管理员点击用户管理,在用户管理页面的输入用户账号、用户姓名、性别、年龄、头像、用户手机、身份证、用户住址、邮箱等信息,进行查询、新增或者删除用户信息等操作,如图5-9所示。

 管理员点击景点类型管理,在景点类型管理页面的输入景点类型等信息,进行查询、新增或者删除景点类型等操作,如图5-10所示。

 管理员点击旅游景点管理,在旅游景点管理页面的对景点名称、等级、景点类型、景点图片、门票价格、开放时间、服务电话、详细地址等信息,进行查询或者删除旅游景点等操作,如图5-11所示。

 管理员点击旅游游记管理,在旅游游记管理页面的对游记标题、封面图片、旅游景点、用户账号、用户姓名、分类标签、发布时间、审核回复、审核状态、审核等信息,进行查询或者删除旅游游记等操作,如图5-12所示。

 管理员点击分类标签管理,在分类标签管理页面的对分类标签等信息,进行查询或者删除分类标签等操作,如图5-13所示。

 管理员点击旅游路线管理,在旅游路线管理页面的对路线名称、景点名称、景区分类、景点地址、线路图片、起点、途径路段、终点、行程天数、旅行社、联系方式、路线价格、点击次数等信息,进行查询或者删除旅游路线等操作,如图5-14所示。

 用户点击后台管理,然后页面跳转到系统主页面后可以对系统首页、个人中心、旅游游记管理等功能进行操作。如图5-15所示:

 

三、核心代码

1、登录模块

package com.controller;

import java.util.Arrays;

import java.util.Calendar;

import java.util.Date;

import java.util.Map;

import javax.servlet.http.HttpServletRequest;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.stereotype.Controller;

import org.springframework.web.bind.annotation.GetMapping;

import org.springframework.web.bind.annotation.PathVariable;

import org.springframework.web.bind.annotation.PostMapping;

import org.springframework.web.bind.annotation.RequestBody;

import org.springframework.web.bind.annotation.RequestMapping;

import org.springframework.web.bind.annotation.RequestParam;

import org.springframework.web.bind.annotation.ResponseBody;

import org.springframework.web.bind.annotation.RestController;

import com.annotation.IgnoreAuth;

import com.baomidou.mybatisplus.mapper.EntityWrapper;

import com.entity.TokenEntity;

import com.entity.UserEntity;

import com.service.TokenService;

import com.service.UserService;

import com.utils.CommonUtil;

import com.utils.MD5Util;

import com.utils.MPUtil;

import com.utils.PageUtils;

import com.utils.R;

import com.utils.ValidatorUtils;

@RequestMapping("users")

@RestController

public class UserController{

@Autowired

private UserService userService;

@Autowired

private TokenService tokenService;

@IgnoreAuth

@PostMapping(value = "/login")

public R login(String username, String password, String captcha, HttpServletRequest request) {

UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));

if(user==null || !user.getPassword().equals(password)) {

return R.error("账号或密码不正确");

}

String token = tokenService.generateToken(user.getId(),username, "users", user.getRole());

return R.ok().put("token", token);

}

@IgnoreAuth

@PostMapping(value = "/register")

public R register(@RequestBody UserEntity user){

if(userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername())) !=null) {

return R.error("用户已存在");

}

userService.insert(user);

return R.ok();

}

@GetMapping(value = "logout")

public R logout(HttpServletRequest request) {

request.getSession().invalidate();

return R.ok("退出成功");

}

@IgnoreAuth

@RequestMapping(value = "/resetPass")

public R resetPass(String username, HttpServletRequest request){

UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));

if(user==null) {

return R.error("账号不存在");

}

user.setPassword("123456");

userService.update(user,null);

return R.ok("密码已重置为:123456");

}

@RequestMapping("/page")

public R page(@RequestParam Map<String, Object> params,UserEntity user){

EntityWrapper<UserEntity> ew = new EntityWrapper<UserEntity>();

PageUtils page = userService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.allLike(ew, user), params), params));

return R.ok().put("data", page);

}

@RequestMapping("/list")

public R list( UserEntity user){

EntityWrapper<UserEntity> ew = new EntityWrapper<UserEntity>();

ew.allEq(MPUtil.allEQMapPre( user, "user"));

return R.ok().put("data", userService.selectListView(ew));

}

@RequestMapping("/info/{id}")

public R info(@PathVariable("id") String id){

UserEntity user = userService.selectById(id);

return R.ok().put("data", user);

}

@RequestMapping("/session")

public R getCurrUser(HttpServletRequest request){

Long id = (Long)request.getSession().getAttribute("userId");

UserEntity user = userService.selectById(id);

return R.ok().put("data", user);

}

@PostMapping("/save")

public R save(@RequestBody UserEntity user){

if(userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername())) !=null) {

return R.error("用户已存在");

}

userService.insert(user);

return R.ok();

}

@RequestMapping("/update")

public R update(@RequestBody UserEntity user){

userService.updateById(user);

return R.ok();

}

@RequestMapping("/delete")

public R delete(@RequestBody Long[] ids){

userService.deleteBatchIds(Arrays.asList(ids));

return R.ok();

}

}

 2、文件上传模块

package com.controller;

import java.io.File;

import java.io.FileNotFoundException;

import java.io.IOException;

import java.util.Arrays;

import java.util.Date;

import java.util.HashMap;

import java.util.List;

import java.util.Map;

import java.util.Random;

import java.util.UUID;

import org.apache.commons.io.FileUtils;

import org.apache.commons.lang3.StringUtils;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.http.HttpHeaders;

import org.springframework.http.HttpStatus;

import org.springframework.http.MediaType;

import org.springframework.http.ResponseEntity;

import org.springframework.util.ResourceUtils;

import org.springframework.web.bind.annotation.PathVariable;

import org.springframework.web.bind.annotation.RequestBody;

import org.springframework.web.bind.annotation.RequestMapping;

import org.springframework.web.bind.annotation.RequestParam;

import org.springframework.web.bind.annotation.RestController;

import org.springframework.web.multipart.MultipartFile;

import com.annotation.IgnoreAuth;

import com.baomidou.mybatisplus.mapper.EntityWrapper;

import com.entity.ConfigEntity;

import com.entity.EIException;

import com.service.ConfigService;

import com.utils.R;

@RestController

@RequestMapping("file")

@SuppressWarnings({"unchecked","rawtypes"})

public class FileController{

@Autowired

private ConfigService configService;

@RequestMapping("/upload")

public R upload(@RequestParam("file") MultipartFile file,String type) throws Exception {

if (file.isEmpty()) {

throw new EIException("上传文件不能为空");

}

String fileExt = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf(".")+1);

File path = new File(ResourceUtils.getURL("classpath:static").getPath());

if(!path.exists()) {

path = new File("");

}

File upload = new File(path.getAbsolutePath(),"/upload/");

if(!upload.exists()) {

upload.mkdirs();

}

String fileName = new Date().getTime()+"."+fileExt;

File dest = new File(upload.getAbsolutePath()+"/"+fileName);

file.transferTo(dest);

FileUtils.copyFile(dest, new File("C:\\Users\\Desktop\\jiadian\\springbootl7own\\src\\main\\resources\\static\\upload"+"/"+fileName));

if(StringUtils.isNotBlank(type) && type.equals("1")) {

ConfigEntity configEntity = configService.selectOne(new EntityWrapper<ConfigEntity>().eq("name", "faceFile"));

if(configEntity==null) {

configEntity = new ConfigEntity();

configEntity.setName("faceFile");

configEntity.setValue(fileName);

} else {

configEntity.setValue(fileName);

}

configService.insertOrUpdate(configEntity);

}

return R.ok().put("file", fileName);

}

@IgnoreAuth

@RequestMapping("/download")

public ResponseEntity<byte[]> download(@RequestParam String fileName) {

try {

File path = new File(ResourceUtils.getURL("classpath:static").getPath());

if(!path.exists()) {

path = new File("");

}

File upload = new File(path.getAbsolutePath(),"/upload/");

if(!upload.exists()) {

upload.mkdirs();

}

File file = new File(upload.getAbsolutePath()+"/"+fileName);

if(file.exists()){

HttpHeaders headers = new HttpHeaders();

headers.setContentType(MediaType.APPLICATION_OCTET_STREAM);

headers.setContentDispositionFormData("attachment", fileName);

return new ResponseEntity<byte[]>(FileUtils.readFileToByteArray(file),headers, HttpStatus.CREATED);

}

} catch (IOException e) {

e.printStackTrace();

}

return new ResponseEntity<byte[]>(HttpStatus.INTERNAL_SERVER_ERROR);

}

}

3、代码封装

package com.utils;

import java.util.HashMap;

import java.util.Map;

public class R extends HashMap<String, Object> {

private static final long serialVersionUID = 1L;

public R() {

put("code", 0);

}

public static R error() {

return error(500, "未知异常,请联系管理员");

}

public static R error(String msg) {

return error(500, msg);

}

public static R error(int code, String msg) {

R r = new R();

r.put("code", code);

r.put("msg", msg);

return r;

}

public static R ok(String msg) {

R r = new R();

r.put("msg", msg);

return r;

}

public static R ok(Map<String, Object> map) {

R r = new R();

r.putAll(map);

return r;

}

public static R ok() {

return new R();

}

public R put(String key, Object value) {

super.put(key, value);

return this;

}

}

网址:基于Spring Boot的自驾游攻略查询系统 https://www.yuejiaxmz.com/news/view/74213

相关内容

【开题报告】基于Spring Boot的家庭菜谱系统设计与实现
Springboot基于SpringBoot的宠物门诊系统6f8jy
Spring Boot 事务的简单使用
037基于java+springboot的课外学习生活活动平台系统
自驾游,自驾游路线查询,自驾游攻略
【毕业设计】基于Java的个人记账系统的设计与实现
关于自驾游必备旅游攻略
016Springboot+vue基于体质分析的个性化健身方案生成系统与设计
自驾游必备旅游攻略
Springboot居家健身系统的设计与实现311b2

随便看看