【从0做项目】Java音缘心动(1)———项目介绍设计

news/2025/2/22 11:00:01

阿华代码,不是逆风,就是我疯

你们的点赞收藏是我前进最大的动力!!

希望本文内容能够帮助到你!!

目录

零:项目结果展示

一:音乐播放器Web网页介绍

二:前期准备工作&项目设计

1:数据库设计

(1)喜欢的音乐——lovemusic

(2)普通存储的音乐——music

(3)用户信息——user

2:sql语句

3:后端开发使用SSM架构

(1)Spring

(2)SpringMVC

(3)Mybatis

4:应用分层

(1)Controller层

(2)Service层

(3)Mapper层

5:yml配置相关

零:项目结果展示

项目目前已经上线

音乐播放器登录页面铁子们可以后台私信获取管理员用户和密码

一:音乐播放器Web网页介绍

这个网页主要的功能包括:用户登录,上传音乐,播放音乐,收藏音乐到喜欢列表,从喜欢列表中移除音乐,删除指定音乐,批量删除音乐,

二:前期准备工作&项目设计

1:数据库设计

这里我们设计三个表

(1)喜欢的音乐——lovemusic

(2)普通存储的音乐——music

(3)用户信息——user

 

2:sql语句

-- 数据库
drop database if exists musicserver;
create database if not exists musicserver character set utf8;
-- 使⽤数据库
use musicserver;
-- 创建表user
DROP TABLE IF EXISTS user;
CREATE TABLE user (
id INT PRIMARY KEY AUTO_INCREMENT,
username varchar(20) NOT NULL,
password varchar(255) NOT NULL
);
INSERT INTO user(username,password)
VALUES("bit","$2a$10$Bs4wNEkledVlGZa6wSfX7eCSD7wRMO0eUwkJH0WyhXzKQJrnk85li");
-- 创建表music
DROP TABLE IF EXISTS music;
CREATE TABLE music (
id int PRIMARY KEY AUTO_INCREMENT,
title varchar(50) NOT NULL,
singer varchar(30) NOT NULL,
time varchar(13) NOT NULL,
url varchar(1000) NOT NULL,
userid int(11) NOT NULL
);
-- title字段为歌曲名称,url字段为歌曲的路径
-- 创建中间表lovemusic
DROP TABLE IF EXISTS lovemusic;
CREATE TABLE lovemusic (
id int PRIMARY KEY AUTO_INCREMENT,
user_id int(11) NOT NULL,
music_id int(11) NOT NULL
);

3:后端开发使用SSM架构

简单介绍一下SSM指Spring、SpringMVC、Mybatis

(1)Spring

Spring是现在主流的Java开发框架,Spring提供了很多开源项目,这些项目都是基于Spring Framework 开发的,但是这玩意配置多,难上手,Spring就搞了个SpringBoot,门槛低上手快,适合我这种小白~

(2)SpringMVC

MVC是一种思想,即视图,控制器,模型。

SpringMVC基于这种思想把Web开发前后端进行分离,前端干前端的活,后端干后端的活。即表现层,业务逻辑层,数据持久层

后端应用分层就为:控制层Controller,业务逻辑层Service,数据持久层Dao

(3)Mybatis

这是一个持久层框架,理解成我们高中学过的映射比较好。

这一层代码主要的工作就相当于一个桥梁,一个中间商,把我们后端的数据和数据库中的数据联系在一起

Java中主要实现方式是通过接口实现——映射方式有注解和XML的方式

注解的方式是Spring特有的,简化了代码。XML的方式是老的方式,虽然有点麻烦但并不过时,当使用一些update等语句的时候,XML就是神!!

4:应用分层

(1)Controller层

接收前端请求,以及返回响应

(2)Service层

数据处理层,负责具体的业务逻辑

(3)Mapper层

数据访问层,

其它的model实体,config配置,constant常量,interceptor拦截器,tools工具等包后续会详细介绍

5:yml配置相关

强调配置

servlet multipart max-file-size 指的是限制最大上传文件的大小不能超过15MB

max-request-size指的是HTTP请求体积最大不能超过100MB

spring:
  datasource:
    url: jdbc:mysql://127.0.0.1:3306/musicserver?characterEncoding=utf8&useSSL=false
    username: root
    password: 613718long
    driver-class-name: com.mysql.cj.jdbc.Driver
  servlet:
    multipart:
      max-file-size: 15MB
      max-request-size: 100MB
  mvc:
    favicon:
      enable: false

# 设置 Mybatis 的 xml 保存路径
mybatis:
  mapper-locations: classpath:mybatis/*Mapper.xml
  configuration: # 配置打印 MyBatis 执行的 SQL
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
    map-underscore-to-camel-case: true  #自动驼峰转换
# 配置打印 MyBatis 执行的 SQL
logging:
  file:
    name: logs/springboot.log
  logback:
    rollingpolicy:
      max-file-size: 1KB
      file-name-pattern: ${LOG_FILE}.%d{yyyy-MM-dd}.%i
  level:
    com:
      example:
        demo: debug
music:
  local:
    path: "D:/music/"

#debug: true


http://www.niftyadmin.cn/n/5862145.html

相关文章

Effective Objective-C 2.0 读书笔记——协议和分类

Effective Objective-C 2.0 读书笔记——协议和分类 文章目录 Effective Objective-C 2.0 读书笔记——协议和分类在分类中添加属性使用 “class-continuation分类” 隐藏实现细节通过协议提供匿名对象 在分类中添加属性 尽管从技术上说,分类里也可以声明属性&…

JAVA JUC 并发编程学习笔记(一)

文章目录 JUC进程概述对比 线程创建线程ThreadRunnableCallable 线程方法APIrun startsleep yieldjoininterrupt打断线程打断 park终止模式 daemon不推荐 线程原理运行机制线程调度未来优化 线程状态查看线程 同步临界区syn-ed使用锁同步块同步方法线程八锁 锁原理Monitor字节码…

如何用deepseek快速生成思维导图和流程图?

一起来看看md格式和mermaid格式,与deepseek的碰撞会产生怎样的魔法吧! 1、md格式deepseek,快速生成思维导图 Markdown 是一种轻量级的标记语言,旨在以易读易写的纯文本格式编写文档,并能够轻松转换为结构化的 HTML&a…

Spring Boot (maven)分页4.0.1版本 专业版- 改

前言: 通过实践而发现真理,又通过实践而证实真理和发展真理。从感性认识而能动地发展到理性认识,又从理性认识而能动地指导革命实践,改造主观世界和客观世界。实践、认识、再实践、再认识,这种形式,循环往…

C++17中的std::scoped_lock:简化多锁管理的利器

文章目录 1. 为什么需要std::scoped_lock1.1 死锁问题1.2 异常安全性1.3 锁的管理复杂性 2. std::scoped_lock的使用方法2.1 基本语法2.2 支持多种互斥锁类型2.3 自动处理异常 3. std::scoped_lock的优势3.1 避免死锁3.2 简化代码3.3 提供异常安全保证 4. 实际应用场景4.1 数据…

qt:输入控件操作

1.单行输入框 QLineEdit ,单行输入,但是不能换行 属性特点text输入框中的文本inputMask输入内容格式约束,限制用户输入的格式。maxLength最大长度,定义输入框允许的最大字符数。frame是否添加边框,默认为 true 显示边…

【GitHub】github学生认证,在vscode中使用copilot的教程

github学生认证并使用copilot教程 写在最前面一.注册github账号1.1、注册1.2、完善你的profile 二、Github 学生认证注意事项:不完善的说明 三、Copilot四、在 Visual Studio Code 中安装 GitHub Copilot 扩展4.1 安装 Copilot 插件4.2 配置 Copilot 插件&#xff0…

什么是超越编程(逾编程)(元编程?)

超越编程(逾编程)(元编程?)(meta-programming) 目录 1. meta- 的词源 2. 逾编程(meta-programming) 的直实含义 2.1 定义 2.2 说明 3. 翻译成“元编程”应该是一种错误 1. meta- 的词源 这是一个源自希腊语的构词元素,其有三种含义&#xff…