基于javaweb+mysql的ssm音乐管理系统(java+ssm+jsp+jquery+h-ui+mysql)

基于javaweb+mysql的ssm音乐管理系统(java+ssm+jsp+jquery+h-ui+mysql)

私信源码获取及调试交流

运行环境

Java≥8、MySQL≥5.7、Tomcat≥8

开发工具

eclipse/idea/myeclipse/sts等均可配置运行

适用

课程设计,大作业,毕业设计,项目练习,学习演示等

功能说明

基于javaweb+mysql的SSM音乐管理系统(java+ssm+jsp+jquery+h-ui+mysql)

项目介绍

本在线音乐网站采用JSP动态网页开发技术,JAVA编程语言,基于B/S架构,使用SSM框架技术,使用MySQL数据库,充分保证了系统的稳定性和安全性。

该系统主要分为前台和后台两大功能模块,共包含两个角色:用户、管理员。 具体的系统功能如下: 1.前台功能 前台首页、音乐浏览、音乐搜索、音乐分类查找、音乐详情、音乐播放、音乐下载、添加收藏、新闻公告、留言交流、用户注册、用户登陆、个人中心、用户信息修改、我的收藏、意见反馈、修改密码等功能。 2.后台功能 后台系统登陆、管理员管理、用户信息管理、音乐管理、音乐类型管理、新闻公告管理、用户评价管理、意见反馈管理、留言交流管理、消息回复管理等功能。

环境需要

1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。 2.IDE环境:IDEA,Eclipse,Myeclipse都可以。推荐IDEA; 3.tomcat环境:Tomcat 7.x,8.x,9.x版本均可 4.硬件环境:windows 7/8/10 1G内存以上;或者 Mac OS; 5.是否Maven项目: 否;查看源码目录中是否包含pom.xml;若包含,则为maven项目,否则为非maven项目; 6.数据库:MySql 5.7/8.0等版本均可;

技术栈

后台框架:Spring、SpringMVC、MyBatis UI界面:JSP、jQuery 、H-ui 数据库:MySQL

使用说明

  1. 使用Navicat或者其它工具,在mysql中创建对应名称的数据库,并导入项目的sql文件;

  2. 使用IDEA/Eclipse/MyEclipse导入项目,修改配置,运行项目;

statusCode = 201;

return webResponse.getWebResponse(statusCode, statusMsg, data);

User user = new User();

boolean isAdd = true;

return this.addOrEditUser(request, response, session, data, user, user_name, user_password, isAdd);

@RequestMapping(value = "/editUser", method = RequestMethod.POST, produces = "application/json;charset=UTF-8")

@ResponseBody

public WebResponse editUser(HttpServletRequest request, HttpServletResponse response, HttpSession session,

String user_id, @RequestParam(required = false) String user_name,

@RequestParam(required = false) String user_password) {

Object data = null;

String statusMsg = "";

Integer statusCode = 200;

Map<String, String> paramMap = new HashMap<String, String>();

//	@Autowired

//	MyMusicService myMusicService2;

// 歌曲收藏

@RequestMapping(value = "/addMusicCollect", method = RequestMethod.POST, produces = "application/json;charset=UTF-8")

@ResponseBody

public WebResponse addMusicCollect(HttpServletRequest request, HttpServletResponse response, HttpSession session,

@RequestParam(required = false) String user_name) {

WebResponse webResponse = new WebResponse();

MyMusic myMusic = new MyMusic();

System.out.println("接收到的用户名:" + user_name);

String statusMsg = "";

int statusCode = 200;

LinkedHashMap<String, String> condition = new LinkedHashMap<String, String>();

/*

* if (tbStatus != null && tbStatus.length() > 0) { condition.put("tb_status='"

* + tbStatus + "'", "and"); }

*/

if (keyword != null && keyword.length() > 0) {

StringBuffer buf = new StringBuffer();

buf.append("(");


voFont = new MusicLink();

map.put("list", listFont);

data = map;

//				for (int i = 0; i < map.size(); i++) {

//					System.out.println(map.get(listFont).toString());

//				}

//

statusMsg = "根据条件获取分页数据成功!!!";

} else {

map.put("list", list);

data = map;

statusCode = 202;


Object data = null;

String statusMsg = "";

int statusCode = 200;

LinkedHashMap<String, String> condition = new LinkedHashMap<String, String>();

if (tbStatus != null && tbStatus.length() > 0) {

condition.put("tb_status='" + tbStatus + "'", "and");

if (keyword != null && keyword.length() > 0) {

StringBuffer buf = new StringBuffer();

buf.append("(");

buf.append("test_name like '%").append(keyword).append("%'");

buf.append(" or ");

buf.append("info like '%").append(keyword).append("%'");

buf.append(" or ");

public WebResponse getMusicLinkList(HttpServletRequest request, HttpServletResponse response, HttpSession session,

@RequestParam(defaultValue = "1", required = false) Integer pageNo,

@RequestParam(defaultValue = "30", required = false) Integer pageSize,

@RequestParam(defaultValue = "正常", required = false) String tbStatus,

@RequestParam(required = false) String keyword,

@RequestParam(defaultValue = "ml_id", required = false) String order,

@RequestParam(defaultValue = "desc", required = false) String desc) {

Object data = null;

String statusMsg = "";

int statusCode = 200;

LinkedHashMap<String, String> condition = new LinkedHashMap<String, String>();

List<MusicLink> list = this.musicLinkService.getList(condition, pageNo, pageSize, order, field);

Map<Object, Object> map = new HashMap<Object, Object>();

map.put("total", count);

// 如果数据库有15条音乐,则list中有15个对象,则size的大小为15

int size = list.size();

if (size > 0) {

List<MusicLink> listFont = new ArrayList<MusicLink>();

MusicLink vo;

MusicLink voFont = new MusicLink();

// 循环将获取到的对象及结构属性克隆到一个新的voFont对象中,并保存到动态数组中

for (int i = 0; i < size; i++) {

vo = list.get(i);

// 通过java反射将类中当前属性字段对应的内容复制到另外一个类中

//					System.out.println(map.get(listFont).toString());

//				}

//

statusMsg = "根据条件获取分页数据成功!!!";

} else {

map.put("list", list);

data = map;

statusCode = 202;

statusMsg = "no record!!!";

return webResponse.getWebResponse(statusCode, statusMsg, data);

return webResponse.getWebResponse(statusCode, statusMsg, data);

// 歌曲收藏

data = map;

statusMsg = "根据条件获取分页数据成功!!!";

} else {

map.put("list", list);

data = map;

statusCode = 202;

statusMsg = "no record!!!";

return webResponse.getWebResponse(statusCode, statusMsg, data);

return webResponse.getWebResponse(statusCode, statusMsg, data);

// 歌曲搜索功能

@RequestMapping(value = "/getSongRearch", method = RequestMethod.POST, produces = "application/json;charset=UTF-8")

@ResponseBody

public WebResponse getSongRearch(HttpServletRequest request, HttpServletResponse response, HttpSession session,


} else {

statusCode = 202;

statusMsg = "no record!!!";

return webResponse.getWebResponse(statusCode, statusMsg, data);

@RequestMapping(value = "/getOneUser", method = RequestMethod.POST, produces = "application/json;charset=UTF-8")

@ResponseBody

public WebResponse getOneTest(@RequestParam(defaultValue = "正常", required = false) String tbStatus) {

LinkedHashMap<String, String> condition = new LinkedHashMap<String, String>();

condition.put("tb_status='" + tbStatus + "'", "");

User userVo = this.userService.getOne(condition);

Object data = null;


System.out.println("歌曲名:" + songName);

String jSong = this.musicLinkService.judgeSong(songName, userId);

int my_Id = 0;

try {

// 判断字符串是否是数字,并且抛出异常

// boolean NotisNum

// =(user_Id.equals(null)||user_Id.equals("")||user_Id.equals("null"));

boolean NotisNum = (jSong.equals("null"));

if (!NotisNum) {

my_Id = Integer.parseInt(jSong);

} catch (Exception e) {

if (my_Id > 0) {

statusCode = 201;
String user_Id = null;

try {

user_Id = musicLinkService2.getUserId(user_name, user_password);

} catch (Exception e) {

int userId = 0;

try {

// 判断字符串是否是数字,并且抛出异常

boolean NotisNum = (user_Id.equals("null"));

// System.out.println(NotisNum);

if (!NotisNum) {

userId = Integer.parseInt(user_Id);

} catch (Exception e) {
Map<Object, Object> map = new HashMap<Object, Object>();

map.put("total", count);

// 如果数据库有15条音乐,则list中有15个对象,则size的大小为15

int size = list.size();

if (size > 0) {

List<MusicLink> listFont = new ArrayList<MusicLink>();

MusicLink vo;

MusicLink voFont = new MusicLink();

// 循环将获取到的对象及结构属性克隆到一个新的voFont对象中,并保存到动态数组中

for (int i = 0; i < size; i++) {

vo = list.get(i);

// 通过java反射将类中当前属性字段对应的内容复制到另外一个类中

BeanUtils.copyProperties(vo, voFont);

statusCode = 201;

return webResponse.getWebResponse(statusCode, statusMsg, data);

User userVo = this.userService.getById(user_idNumeri);

User user = new User();

BeanUtils.copyProperties(userVo, user); // 浅复制,重要

boolean isAdd = false;

return this.addOrEditUser(request, response, session, data, user, user_name, user_password, isAdd);

/*

*/

private WebResponse addOrEditUser(HttpServletRequest request, HttpServletResponse response, HttpSession session,

Object data, User user, String user_name, String user_password, boolean isAdd) {

String statusMsg = "";

Integer statusCode = 200;

String user_name = request.getParameter("user_name");

String newUser_password = request.getParameter("newUser_password");

try {

uId = (int) this.userService2.resetPassword(user_name, newUser_password);

System.out.println("修改密码返回的id:" + uId);

} catch (Exception e) {

return webResponse.getWebResponse(statusCode, statusMsg, data);

// 用户注册

@RequestMapping(value = "/addOrEditUser", method = RequestMethod.POST, produces = "application/json;charset=UTF-8")

@ResponseBody

public WebResponse addOrEditTest(HttpServletRequest request, HttpServletResponse response, HttpSession session,

String user_id, @RequestParam(required = false) String user_name,

@RequestParam(required = false) String user_password) {

Object data = null;


// 判断字符串是否是数字,并且抛出异常

// boolean NotisNum

// =(user_Id.equals(null)||user_Id.equals("")||user_Id.equals("null"));

boolean NotisNum = (jSong.equals("null"));

if (!NotisNum) {

my_Id = Integer.parseInt(jSong);

} catch (Exception e) {

if (my_Id > 0) {

statusCode = 201;

statusMsg = "已收藏,请不要重复收藏!";


MusicLink vo;

MusicLink voFont = new MusicLink();

for (int i = 0; i < size; i++) {

vo = list.get(i);

BeanUtils.copyProperties(vo, voFont);

listFont.add(voFont);

voFont = new MusicLink();

map.put("list", listFont);

data = map;

//				for (int i = 0; i < map.size(); i++) {

//					System.out.println(map.get(listFont).toString());

//				}

请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述

  • 6
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值