Springboot3+vue3从0到1开发实战项目(一)

一. 可以在本项目里面自由发挥拓展

二. 知识整合项目使用到的技术

后端开发 : Validation, Mybatis,Redis, Junit,SpringBoot3 ,mysql,Swagger, JDK17 ,JWT,项目部署

前端开发: Vue3,Vite,Router,Pina ,Element-Plus

开发工具idea ,VsCode,navicat。。。

KunkunFamily新闻需求

用户:注册,登录,用户详细信息,更新用户基本信息, 更新用户头像,更新用户密码

文章新闻分类管理: 文章分类列表, 新增文章分类,更新文章分类,获取文章分类,删除文章分类

文章管理:新增文章, 更新文章,获取文章详情, 删除文章,文章列表(条件分页)

文件上传

后端开发要求以及前端需要熟知知识

三. 后端环境搭建:

1.根据前面的需求来写mysql数据库, 准备数据库表

-- 创建User表
create table user (
                      id int unsigned primary key auto_increment comment 'ID',
                      username varchar(20) not null unique comment '用户名',
                      password varchar(32)  comment '密码',
                      nickname varchar(10)  default '' comment '昵称',
                      email varchar(128) default '' comment '邮箱',
                      user_pic varchar(128) default '' comment '头像',
                      create_time datetime not null comment '创建时间',
                      update_time datetime not null comment '修改时间'
) comment '用户表';
-- 后面添加数据
insert into user(id, username, password, nickname, email,user_pic,create_time,update_time) VALUES ();


-- 分类表
create table category(
                         id int unsigned primary key auto_increment comment 'ID',
                         category_name varchar(32) not null comment '分类名称',
                         category_alias varchar(32) not null comment '分类别名',
                         create_user int unsigned not null comment '创建人ID',
                         create_time datetime not null comment '创建时间',
                         update_time datetime not null comment '修改时间',
                         constraint fk_category_user foreign key (create_user) references user(id) -- 外键约束
);

-- 文章表
create table article(
                        id int unsigned primary key auto_increment comment 'ID',
                        title varchar(30) not null comment '文章标题',
                        content varchar(10000) not null comment '文章内容',
                        cover_img varchar(128) not null  comment '文章封面',
                        state varchar(3) default '草稿' comment '文章状态: 只能是[已发布] 或者 [草稿]',
                        category_id int unsigned comment '文章分类ID',
                        create_user int unsigned not null comment '创建人ID',
                        create_time datetime not null comment '创建时间',
                        update_time datetime not null comment '修改时间',
                        constraint fk_article_category foreign key (category_id) references category(id),-- 外键约束
                        constraint fk_article_user foreign key (create_user) references user(id) -- 外键约束
)

2.创建springboot工程项目 引入依赖

注意: 这里需要下载JDK17 SpringBoot3需要JDK17的支持,不再支持JDK8, 我的成功是因为把Springboot版本降低了实现效果,以为自己就是17

3. 书写配置文件

修改配置文件后缀名为yml

application.yml文件配置连接mysql

spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/dahsijian
    username: root
    password: 1234

4. 创建基本的包结构

四. 开始编写开发

1. 根据数据库书写实体类pojo

1.1注册功能    这是自己画的注册需要什么

User.java

@Data
public class User {
    private  Integer id; // 主键id
    private String username; // 用户名
    private  String  password; // 密码
    private String  nickname; //昵称
    private String email; // 邮箱
    private String userPic; // 用户头像地址
    private LocalDateTime createTime;// 创建时间
    private LocalDateTime updateTime;// 更新时间
}

在Maven配置lombok就可以不用写set,get了, 前面配置@Data

接口文档参数返回值类 Result.java

@NoArgsConstructor
@AllArgsConstructor
public class Result<T> {
    private Integer code; //业务状态码  0-成功  1-失败
    private String message; //提示信息
    private T data; //响应数据

    //快速返回操作成功响应结果(带响应数据)
    public static <E> Result<E> success(E data) {
        return new Result<>(0, "操作成功", data);
    }

    //快速返回操作成功响应结果
    public static Result success() {
        return new Result(0, "操作成功", null);
    }

    public static Result error(String message) {
        return new Result(1, message, null);
    }
}

看接口要有用户名密码校验,这里使用spring的注解方式导入包validation

		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-validation</artifactId>
		</dependency>

UserController.java类

@RestController
@RequestMapping("/user")
public class UserController {

    // service层
    @Autowired
    private  UserService userService;



    // 注册类   判断是否已存在用户查数据库
    @PostMapping("/register")
    // 使用注解 @Pattern以及表达式
    public Result register(@Pattern(regexp = "^\\${5,16}$") String username, @Pattern(regexp = "^\\${5,16}$")String password) {
        if (userService.findByUsername(username) != null) {
            return Result.error("该用户已被占用");
        }
        userService.register(username, password);
        return  Result.success();

//        以前的校验方式 : 调用查询用户的方法
//        User u = userService.findByUsername(username);
//        // 注册
//        if (u == null) {
//            // 没有占有
//            // 注册
//            userService.register(username, password);
//            return Result.success();
//        }else {
//            // 占用
//            return Result.error("用户已经被占用");
//        }
    }
}

UserService

public interface UserService{
    //根据用户名查询用户
    User findByUsername(String username);

    //注册
    void register(String username,String password);

}

UserServiceImpl实现类

@Service
public class UserServiceImpl  implements UserService {

    @Autowired
    private UserMapper userMapper;
    @Override
    public User findByUsername(String username) {
        User user =userMapper.findByUserName(username);
        return user;
    }

    @Override
    public void register(String username, String password) {
        // 加密
        String md5String = Md5Util.getMD5String(password);
        // 添加
        userMapper.add(username,md5String);
    }
}

MD5util.java


public class Md5Util {
    /**
     * 默认的密码字符串组合,用来将字节转换成 16 进制表示的字符,apache校验下载的文件的正确性用的就是默认的这个组合
     */
    protected static char hexDigits[] = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f'};

    protected static MessageDigest messagedigest = null;

    static {
        try {
            messagedigest = MessageDigest.getInstance("MD5");
        } catch (NoSuchAlgorithmException nsaex) {
            System.err.println(Md5Util.class.getName() + "初始化失败,MessageDigest不支持MD5Util。");
            nsaex.printStackTrace();
        }
    }

    /**
     * 生成字符串的md5校验值
     *
     * @param s
     * @return
     */
    public static String getMD5String(String s) {
        return getMD5String(s.getBytes());
    }

    /**
     * 判断字符串的md5校验码是否与一个已知的md5码相匹配
     *
     * @param password  要校验的字符串
     * @param md5PwdStr 已知的md5校验码
     * @return
     */
    public static boolean checkPassword(String password, String md5PwdStr) {
        String s = getMD5String(password);
        return s.equals(md5PwdStr);
    }


    public static String getMD5String(byte[] bytes) {
        messagedigest.update(bytes);
        return bufferToHex(messagedigest.digest());
    }

    private static String bufferToHex(byte bytes[]) {
        return bufferToHex(bytes, 0, bytes.length);
    }

    private static String bufferToHex(byte bytes[], int m, int n) {
        StringBuffer stringbuffer = new StringBuffer(2 * n);
        int k = m + n;
        for (int l = m; l < k; l++) {
            appendHexPair(bytes[l], stringbuffer);
        }
        return stringbuffer.toString();
    }

    private static void appendHexPair(byte bt, StringBuffer stringbuffer) {
        char c0 = hexDigits[(bt & 0xf0) >> 4];// 取字节中高 4 位的数字转换, >>>
        // 为逻辑右移,将符号位一起右移,此处未发现两种符号有何不同
        char c1 = hexDigits[bt & 0xf];// 取字节中低 4 位的数字转换
        stringbuffer.append(c0);
        stringbuffer.append(c1);
    }

UserMapper

@Mapper
public interface UserMapper {
    // 查询用户
    @Select("select * from user where username=#{username}")
    User findByUserName(String username);

    // 添加用户
    @Insert("insert into user(username,password,create_time,update_time) values(#{username},#{password},now(),now())")
    void add(String username, String password);// md5String
}

完整的项目结构如下:

 测试接口使用postman 注册用户添加到数据库

数据库已经注册一个用户了

 

注意: 这里需要下载JDK17 SpringBoot3需要JDK17的支持,不再支持JDK8, 我的成功是因为把Springboot版本降低了实现效果,以为自己就是17

五. 项目遇到的小问题

1. 版本问题:java: 警告: 源发行版 17 需要目标发行版 17

安装了jdk17后之前是jdk1.8 想要把项目换成jdk17然后出现的这个问题

 解决 检查项目是不是使用到了jdk17:

 

 

 这一章完结!!!

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: Spring Boot是一种用于构建Java应用程序的开发框架,而Vue.js是一个用于构建用户界面的JavaScript框架。Spring Boot和Vue.js的结合使用可以实现前后端分离的项目开发,其中包括实战pdf的生成和展示功能。 首先,我们可以使用Spring Boot来搭建后端接口服务。通过使用Spring Boot的Web模块,我们可以很方便地创建RESTful API,用于接收前端请求并处理数据。在这个项目中,我们可以设计一个用于生成pdf的API,在接收到相关请求时,利用Java的pdf生成库(如iText)来生成pdf文档,并将生成的pdf保存到服务器或返回给前端。 接下来,我们需要利用Vue.js来创建前端界面,并与后端的API进行交互。我们可以使用Vue.js的组件化和路由功能,创建多个页面来展示pdf文档。对于pdf的展示,可以使用Vue.js的插件或引入第三方pdf阅读器库(如pdf.js),来实现在前端浏览器中展示pdf文档的功能。 在前端界面中,我们可以设计一个上传pdf的功能,用户可以选择本地的pdf文件进行上传,并通过调用后端的API来将pdf保存到服务器,然后在页面中展示出来。 除了生成和展示pdf文档的功能之外,我们还可以通过Spring Boot和Vue.js的结合来实现其他的功能,比如用户登录、权限控制、pdf搜索和标注等等。通过使用Spring Boot和Vue.js这样的前后端分离的开发方式,我们可以更好地实现项目的模块化、可扩展性和易维护性。 总结来说,通过结合使用Spring Boot和Vue.js,我们可以实现一个具有pdf生成和展示功能的项目。使用Spring Boot来搭建后端接口服务,并利用Java的pdf生成库来生成pdf文档;使用Vue.js来创建前端界面,并通过调用后端的API来展示和处理pdf文档。这样的开发方式可以更好地满足项目的需求,同时提高开发效率和用户体验。 ### 回答2: Spring Boot 是一个 Java 开发框架,用于简化和加速 Spring 应用程序的开发Vue 是一个流行的 JavaScript 框架,用于构建用户界面。Spring Boot 和 Vue 可以一起使用,实现全栈开发。 PDF 是一种常见的文件格式,用于在不同平台上展示、共享和打印文档。在一个实践项目中使用 Spring Boot 3 和 Vue 3 来处理 PDF 文件是可行的。 首先,可以使用 Spring Boot 来创建一个 RESTful API,用于处理 PDF 文件的上传、下载和其他操作。Spring Boot 提供了丰富的库和功能,可以轻松处理文件上传和下载的逻辑。 然后,可以使用 Vue 3 来构建一个用户界面,用于展示 PDF 文件的列表和操作。Vue 3 提供了许多强大的工具和组件,可以方便地处理用户界面的交互和数据传输。 在实际项目中,可以使用 Spring Boot 来处理用户上传的 PDF 文件,并将其保存到服务器上的指定位置。同时,可以使用 Vue 3 构建一个界面,展示已上传的 PDF 文件列表,并提供下载和删除等功能。 为了实现这个功能,可以使用 Spring Boot 的文件上传功能来处理用户上传的 PDF 文件,并将其保存到指定的目录。然后,可以使用 Vue 3 的组件和路由来构建一个用户界面,用于展示和操作已上传的 PDF 文件。 总结来说,Spring Boot 3 和 Vue 3 可以一起使用,实现一个实战项目,用于处理 PDF 文件的上传、下载和其他操作。使用 Spring Boot 来处理文件上传和下载的逻辑,使用 Vue 3 来构建用户界面,展示和操作已上传的 PDF 文件。这样可以实现一个功能完善的 PDF 文件处理项目。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

全能技术师

相关资源在博客首页资源下获取

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值