Springboot+vue项目音乐网站与分享平台

发布时间:2023-07-04 11:30

文末获取源码

开发语言:Java

开发工具:IDEA /Eclipse

数据库:MYSQL5.7

应用服务:Tomcat7/Tomcat8

使用框架:springboot+vue

JDK版本:jdk1.8

音乐网站与分享平台的主要使用者分为管理员和用户,实现功能包括管理员:首页、个人中心、用户管理、音乐资讯管理、音乐翻唱管理、在线听歌管理、留言板管理、系统管理,用户:首页、个人中心、音乐翻唱管理、我的收藏管理,前台首页;首页、音乐资讯、音乐翻唱、在线听歌、留言反馈、个人中心、后台管理、客服等功能。 

系统功能分析

本音乐网站与分享平台主要包括二大功能模块,即用户功能模块和管理员功能模块。

(1)管理员模块:系统中的核心用户是管理员,管理员登录后,通过管理员功能来管理后台系统。主要功能有:首页、个人中心、用户管理、音乐资讯管理、音乐翻唱管理、在线听歌管理、留言板管理、系统管理等功能。管理员用例图如图

\"Springboot+vue项目音乐网站与分享平台_第1张图片\"

(2)用户:首页、个人中心、音乐翻唱管理、我的收藏管理等功能,用户如图 

\"Springboot+vue项目音乐网站与分享平台_第2张图片\"

 (3)前台首页:首页、音乐资讯、音乐翻唱、在线听歌、留言反馈、个人中心、后台管理、客服等功能,前台首页如图

\"Springboot+vue项目音乐网站与分享平台_第3张图片\"

系统结构设计

整个系统是由多个功能模块组合而成的,要将所有的功能模块都一一列举出来,然后进行逐个的功能设计,使得每一个模块都有相对应的功能设计,然后进行系统整体的设计。

本音乐网站与分享平台结构图如图 

\"Springboot+vue项目音乐网站与分享平台_第4张图片\"

系统详细设计

前台首页功能模块

音乐网站与分享平台 ,在系统首页可以查看首页、音乐资讯、音乐翻唱、在线听歌、留言反馈、个人中心、后台管理、客服等内容,如图

\"Springboot+vue项目音乐网站与分享平台_第5张图片\"

登录、用户注册,在用户注册页面可以填写用户名、密码、姓名、年龄、手机、邮箱、身份证等信息进行注册,如图 

\"Springboot+vue项目音乐网站与分享平台_第6张图片\"

\"Springboot+vue项目音乐网站与分享平台_第7张图片\"

 音乐资讯

\"Springboot+vue项目音乐网站与分享平台_第8张图片\"

 音乐翻唱

\"Springboot+vue项目音乐网站与分享平台_第9张图片\"

在线听歌,在在线听歌页面通过填写编号、歌曲名称、标签、原唱、作曲、作词、音乐、视频等信息进行点我收藏,如图5-3所示。在音乐翻唱页面通过填写编号、歌曲名称、原唱、标签、音频、图片、翻唱原因、用户名等信息进行点我收藏操作,如图 

\"Springboot+vue项目音乐网站与分享平台_第10张图片\"

\"Springboot+vue项目音乐网站与分享平台_第11张图片\"

\"Springboot+vue项目音乐网站与分享平台_第12张图片\"

 管理员功能模块

管理员登录,通过填写注册时输入的用户名、密码、角色进行登录,如图

管理员登录进入音乐网站与分享平台可以查看首页、个人中心、用户管理、音乐资讯管理、音乐翻唱管理、在线听歌管理、留言板管理、系统管理等信息。

个人信息,在个人信息页面中可以通过填写用户名等内容进行修改、添加,如图1所示。还可以根据需要对用户管理进行添加,修改或删除等详细操作,如图 2

\"Springboot+vue项目音乐网站与分享平台_第13张图片\"

\"Springboot+vue项目音乐网站与分享平台_第14张图片\"

音乐资讯管理,在音乐资讯管理页面中可以填写标题、资讯类型、图片、摘要等信息,并可根据需要对已有音乐资讯管理进行修改或删除等操作,如图

\"Springboot+vue项目音乐网站与分享平台_第15张图片\"

音乐翻唱管理,在音乐翻唱管理页面中可以填写编号、歌曲名称、原唱、标签、音频、图片、翻唱原因、用户名等信息,并可根据需要对已有音乐翻唱管理进行修改或删除等详细操作,如图 

\"Springboot+vue项目音乐网站与分享平台_第16张图片\"

 在线听歌管理,在在线听歌管理页面中可以查看编号、歌曲名称、标签、原唱、作曲、作词、音乐、视频、图片等内容,并且根据需要对已有在线听歌管理进行添加,修改或删除等详细操作,如图

 \"Springboot+vue项目音乐网站与分享平台_第17张图片\"

留言板管理,在留言板管理页面中可以查看用户名、留言内容、回复内容等内容,并且根据需要对已有留言板管理进行添加,修改或删除等详细操作,如图 

\"Springboot+vue项目音乐网站与分享平台_第18张图片\"

客服管理,在客服管理页面中可以查看新消息、状态等内容,并且根据需要对已有客服管理进行添加,修改或删除等详细操作,如图 

\"Springboot+vue项目音乐网站与分享平台_第19张图片\"

用户功能模块

用户登录进入音乐网站与分享平台可以查看首页、个人中心、音乐翻唱管理、我的收藏管理等内容 

\"Springboot+vue项目音乐网站与分享平台_第20张图片\"

个人信息,在个人信息页面中可以查看用户名、密码、姓名、年龄、性别、手机、邮箱、身份证等信息内容,并且根据需要对已有个人信息进行修改或删除等其他详细操作,如图

\"Springboot+vue项目音乐网站与分享平台_第21张图片\"

音乐翻唱管理,在音乐翻唱管理页面中通过填写编号、歌曲名称、原唱、标签、音频、图片、翻唱原因、用户名等内容进行查看、删除,如图

\"Springboot+vue项目音乐网站与分享平台_第22张图片\"

我的收藏管理,在我的收藏管理页面中可以查看收藏ID、表名、收藏名称、收藏图片等内容,并且根据需要对已有我的收藏管理进行查看等详细操作,如图 

\"Springboot+vue项目音乐网站与分享平台_第23张图片\"

部分代码:  

package com.controller;

import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Calendar;
import java.util.Map;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Date;
import java.util.List;
import javax.servlet.http.HttpServletRequest;

import com.utils.ValidatorUtils;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
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 com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.baomidou.mybatisplus.mapper.Wrapper;
import com.annotation.IgnoreAuth;

import com.entity.YinlefanchangEntity;
import com.entity.view.YinlefanchangView;

import com.service.YinlefanchangService;
import com.service.TokenService;
import com.utils.PageUtils;
import com.utils.R;
import com.utils.MPUtil;
import com.utils.CommonUtil;


/**
 * 音乐翻唱
 * 后端接口
 * @author 
 * @email 
 * @date 2021-01-11 11:34:28
 */
@RestController
@RequestMapping(\"/yinlefanchang\")
public class YinlefanchangController {
    @Autowired
    private YinlefanchangService yinlefanchangService;
    


    /**
     * 后端列表
     */
    @RequestMapping(\"/page\")
    public R page(@RequestParam Map params,YinlefanchangEntity yinlefanchang, HttpServletRequest request){
		String tableName = request.getSession().getAttribute(\"tableName\").toString();
		if(tableName.equals(\"yonghu\")) {
			yinlefanchang.setYonghuming((String)request.getSession().getAttribute(\"username\"));
		}
        EntityWrapper ew = new EntityWrapper();
		PageUtils page = yinlefanchangService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, yinlefanchang), params), params));

        return R.ok().put(\"data\", page);
    }
    
    /**
     * 前端列表
     */
	@IgnoreAuth
    @RequestMapping(\"/list\")
    public R list(@RequestParam Map params,YinlefanchangEntity yinlefanchang, HttpServletRequest request){
        EntityWrapper ew = new EntityWrapper();
		PageUtils page = yinlefanchangService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, yinlefanchang), params), params));
        return R.ok().put(\"data\", page);
    }

	/**
     * 列表
     */
    @RequestMapping(\"/lists\")
    public R list( YinlefanchangEntity yinlefanchang){
       	EntityWrapper ew = new EntityWrapper();
      	ew.allEq(MPUtil.allEQMapPre( yinlefanchang, \"yinlefanchang\")); 
        return R.ok().put(\"data\", yinlefanchangService.selectListView(ew));
    }

	 /**
     * 查询
     */
    @RequestMapping(\"/query\")
    public R query(YinlefanchangEntity yinlefanchang){
        EntityWrapper< YinlefanchangEntity> ew = new EntityWrapper< YinlefanchangEntity>();
 		ew.allEq(MPUtil.allEQMapPre( yinlefanchang, \"yinlefanchang\")); 
		YinlefanchangView yinlefanchangView =  yinlefanchangService.selectView(ew);
		return R.ok(\"查询音乐翻唱成功\").put(\"data\", yinlefanchangView);
    }
	
    /**
     * 后端详情
     */
    @RequestMapping(\"/info/{id}\")
    public R info(@PathVariable(\"id\") String id){
        YinlefanchangEntity yinlefanchang = yinlefanchangService.selectById(id);
        return R.ok().put(\"data\", yinlefanchang);
    }

    /**
     * 前端详情
     */
	@IgnoreAuth
    @RequestMapping(\"/detail/{id}\")
    public R detail(@PathVariable(\"id\") String id){
        YinlefanchangEntity yinlefanchang = yinlefanchangService.selectById(id);
        return R.ok().put(\"data\", yinlefanchang);
    }
    


    /**
     * 赞或踩
     */
    @RequestMapping(\"/thumbsup/{id}\")
    public R vote(@PathVariable(\"id\") String id,String type){
        YinlefanchangEntity yinlefanchang = yinlefanchangService.selectById(id);
        if(type.equals(\"1\")) {
        	yinlefanchang.setThumbsupnum(yinlefanchang.getThumbsupnum()+1);
        } else {
        	yinlefanchang.setCrazilynum(yinlefanchang.getCrazilynum()+1);
        }
        yinlefanchangService.updateById(yinlefanchang);
        return R.ok(\"投票成功\");
    }

    /**
     * 后端保存
     */
    @RequestMapping(\"/save\")
    public R save(@RequestBody YinlefanchangEntity yinlefanchang, HttpServletRequest request){
    	yinlefanchang.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
    	//ValidatorUtils.validateEntity(yinlefanchang);
        yinlefanchangService.insert(yinlefanchang);
        return R.ok();
    }
    
    /**
     * 前端保存
     */
    @RequestMapping(\"/add\")
    public R add(@RequestBody YinlefanchangEntity yinlefanchang, HttpServletRequest request){
    	yinlefanchang.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
    	//ValidatorUtils.validateEntity(yinlefanchang);
        yinlefanchangService.insert(yinlefanchang);
        return R.ok();
    }

    /**
     * 修改
     */
    @RequestMapping(\"/update\")
    public R update(@RequestBody YinlefanchangEntity yinlefanchang, HttpServletRequest request){
        //ValidatorUtils.validateEntity(yinlefanchang);
        yinlefanchangService.updateById(yinlefanchang);//全部更新
        return R.ok();
    }
    

    /**
     * 删除
     */
    @RequestMapping(\"/delete\")
    public R delete(@RequestBody Long[] ids){
        yinlefanchangService.deleteBatchIds(Arrays.asList(ids));
        return R.ok();
    }
    
    /**
     * 提醒接口
     */
	@RequestMapping(\"/remind/{columnName}/{type}\")
	public R remindCount(@PathVariable(\"columnName\") String columnName, HttpServletRequest request, 
						 @PathVariable(\"type\") String type,@RequestParam Map map) {
		map.put(\"column\", columnName);
		map.put(\"type\", type);
		
		if(type.equals(\"2\")) {
			SimpleDateFormat sdf = new SimpleDateFormat(\"yyyy-MM-dd\");
			Calendar c = Calendar.getInstance();
			Date remindStartDate = null;
			Date remindEndDate = null;
			if(map.get(\"remindstart\")!=null) {
				Integer remindStart = Integer.parseInt(map.get(\"remindstart\").toString());
				c.setTime(new Date()); 
				c.add(Calendar.DAY_OF_MONTH,remindStart);
				remindStartDate = c.getTime();
				map.put(\"remindstart\", sdf.format(remindStartDate));
			}
			if(map.get(\"remindend\")!=null) {
				Integer remindEnd = Integer.parseInt(map.get(\"remindend\").toString());
				c.setTime(new Date());
				c.add(Calendar.DAY_OF_MONTH,remindEnd);
				remindEndDate = c.getTime();
				map.put(\"remindend\", sdf.format(remindEndDate));
			}
		}
		
		Wrapper wrapper = new EntityWrapper();
		if(map.get(\"remindstart\")!=null) {
			wrapper.ge(columnName, map.get(\"remindstart\"));
		}
		if(map.get(\"remindend\")!=null) {
			wrapper.le(columnName, map.get(\"remindend\"));
		}

		String tableName = request.getSession().getAttribute(\"tableName\").toString();
		if(tableName.equals(\"yonghu\")) {
			wrapper.eq(\"yonghuming\", (String)request.getSession().getAttribute(\"username\"));
		}

		int count = yinlefanchangService.selectCount(wrapper);
		return R.ok().put(\"count\", count);
	}
	


}

ItVuer - 免责声明 - 关于我们 - 联系我们

本网站信息来源于互联网,如有侵权请联系:561261067@qq.com

桂ICP备16001015号