小言_互联网的博客

【SpringBoot】一文掌握程序的打包与运行

263人阅读  评论(0)

🌕博客x主页:己不由心王道长🌕!
🌎文章说明:SpringBoot关于程序的打包和运行🌎
✅系列专栏:spring
🌴本篇内容:基于Windows对程序进行打包和运行🌴
☕️每日一语:世上有很多不可能,不过不要在你未尽全力之前下结论。☕️
🕤作者详情:作者是一名双非大三在校生,喜欢Java,欢迎大家探讨学习,喜欢的话请给博主一个三连鼓励。🕤
🚩 交流社区:己不由心王道长(优质编程社区)

前言

我个人认为,学习一个知识点或者做一个项目,我们得有一个清晰的思路。知道自己要做什么。这个时候你就得把思路理清,而理清思路又不至于丢失的方法就是画出流程图。这里推荐一些好的软件,如:Xmind、processOn等都值得入手,上手快速。
本次讲解整体流程:

分析、剧透

本次是通过后端的测试,进行程序的打包和运行,并不牵扯到前端,但是可以基于postman进行测试

程序准备

数据库

一、建表:

create table user(
id int(2),
name varchar(15),
age int(3),
email varchar(30),
password varchar(20)
);

二、插入数据:

insert into user(id,name,age,email,password) values(1,"Jone",18,"test1@qq.com","775033");

三、验证

环境搭建

  • 环境搭建是从后端、从底层往上层开发的。就是先数据持久层、然后业务层、然后是控制层。
  • 整体流程图:
创建SpringBoot项目、选择用到的依赖。



1、添加IDEA没有提供选择的技术或者其他需要的技术

  • 我们在选择技术的时候,可能不会一下就完全想到用什么技术来实现我们的功能。而项目已经创建,删除再创建实属不聪明之举。
  • 所以我们需要在创建项目之后再对项目进行一次技术的整合,因为用的是SpringBoot,绝大部分开发用到的技术其实SpringBoot已经帮我们管理好了。
  • 这里就添加一些SpringBoot没有提供的

整体依赖坐标

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
   <modelVersion>4.0.0</modelVersion>
   <parent>
       <groupId>org.springframework.boot</groupId>
       <artifactId>spring-boot-starter-parent</artifactId>
       <version>2.7.5</version>
       <relativePath/> <!-- lookup parent from repository -->
   </parent>
   <groupId>com.example</groupId>
   <artifactId>SpringBoot-development</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <name>SpringBoot-development</name>
   <description>SpringBoot-development</description>
   <properties>
       <java.version>1.8</java.version>
   </properties>
   <!--thymeleaf模板-->
   <dependencies>
       <dependency>
           <groupId>org.springframework.boot</groupId>
           <artifactId>spring-boot-starter-thymeleaf</artifactId>
       </dependency>
       <!--web启动-->
       <dependency>
           <groupId>org.springframework.boot</groupId>
           <artifactId>spring-boot-starter-web</artifactId>
       </dependency>
       <!--Mybatis整合Spring依赖-->
       <dependency>
           <groupId>org.mybatis.spring.boot</groupId>
           <artifactId>mybatis-spring-boot-starter</artifactId>
           <version>2.2.2</version>
       </dependency>
       <!--数据库依赖-->
       <dependency>
           <groupId>com.mysql</groupId>
           <artifactId>mysql-connector-j</artifactId>
           <scope>runtime</scope>
       </dependency>
       <!--Lombok依赖、简化实体类开发-->
       <dependency>
           <groupId>org.projectlombok</groupId>
           <artifactId>lombok</artifactId>
           <optional>true</optional>
       </dependency>
       <!--测试类依赖-->
       <dependency>
           <groupId>org.springframework.boot</groupId>
           <artifactId>spring-boot-starter-test</artifactId>
           <scope>test</scope>
       </dependency>

       <!--Mybatisplus依赖-->
       <dependency>
           <groupId>com.baomidou</groupId>
           <artifactId>mybatisplus-spring-boot-starter</artifactId>
           <version>1.0.5</version>
       </dependency>
       <!-- 连接池依赖 -->
       <dependency>
           <groupId>com.alibaba</groupId>
           <artifactId>druid</artifactId>
           <version>1.2.8</version>
       </dependency>
       <!-- jsp依赖 -->
       <dependency>
           <groupId>javax.servlet.jsp</groupId>
           <artifactId>javax.servlet.jsp-api</artifactId>
           <version>2.2.1</version>
           <scope>provided</scope>
       </dependency>
       <!-- jstl标签库依赖 -->
       <dependency>
           <groupId>javax.servlet.jsp.jstl</groupId>
           <artifactId>jstl-api</artifactId>
           <version>1.2</version>
       </dependency>


   </dependencies>

   <!--打包插件、这里不要删除,这个项目的主要目的就是打包-->
   <build>
       <plugins>
           <plugin>
               <groupId>org.springframework.boot</groupId>
               <artifactId>spring-boot-maven-plugin</artifactId>
               <configuration>
                   <excludes>
                       <exclude>
                           <groupId>org.projectlombok</groupId>
                           <artifactId>lombok</artifactId>
                       </exclude>
                   </excludes>
               </configuration>
           </plugin>
       </plugins>
   </build>

</project>


 

2、把Application启动类提到上一个目录

  • 这里为什么这么做是有原因的
  • SpringBootApplication类默认扫描本层包及其子包的文件,所以启动类必须在所有类的外面或者在同一层。
    这里启动类在三层架构的同级目录之中。

3、把application.properties文件改为application.yml

  • 这里我们用yml语法,yml语法有很多好处,这里就不再赘述。
完善三层架构基本框架
  • 三层架构:dao/mapper、service、controller。
  • 这里直接添加包即可,本不止于作为一个小结点。
构建实体类
  • 实体类与数据库的字段要一一对应
  • 这里添加了lombok依赖,我们可以看看lombok的强大之处。
package com.example.entity;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

/**
 * @author 不止于梦想
 * @date 2022/10/29 21:53
 */

@Data
@NoArgsConstructor
@AllArgsConstructor
public class User {
   
    private Integer id;
    private String Username;
    private Integer age;
    private String email;
}

 
开发持久层
  • 回想一下我们当时开发两天半时长项目时,持久层用到了两个方法,一个是验证用户名和密码是否存在。
  • 另一个是添加用户,一共两个方法。

一、开发接口

package com.example.mapper;

import com.example.pojo.User;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.springframework.stereotype.Repository;

/**
 * @author 不止于梦想
 * @date 2022/11/11 14:34
 */
@Mapper
public interface UserMapper {
   
    //通过用户名和密码查询
    User selectByNameAndPwd(@Param("username") String username,@Param("password") String password);
    //添加用户
    int insertByUser(@Param("user") User user);
}



 

四、测试

  • 从底层往上开发,一个好处就是可以方便测试数据是否正确。
开发业务层

UserService:

package com.example.service;

import com.example.pojo.User;

/**
 * @author 不止于梦想
 * @date 2022/11/11 14:51
 */
public interface UserService {
   
    User selectByNameAndPwd(String name, String password);
    int insertUser(User user);
}

ImplUserService:

package com.example.service.impl;

import com.example.mapper.UserMapper;
import com.example.pojo.User;
import com.example.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

/**
 * @author 不止于梦想
 * @date 2022/11/11 14:53
 */
@Service
public class ImplUserService implements UserService {
   
    @Autowired
    private UserMapper userMapper;
    @Override
    public User selectByNameAndPwd(String name, String password) {
   
       return userMapper.selectByNameAndPwd(name,password);
    }

    @Override
    public int insertUser(User user) {
   
        return userMapper.insertByUser(user);
    }
}


 

测试:

开发控制层

UserController:

package com.example.controller;

import com.example.pojo.User;
import com.example.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;

/**
 * @author 不止于梦想
 * @date 2022/11/11 15:12
 */
@Controller
@RequestMapping("/user")
public class UserController {
   
    @Autowired
    UserService userService;
    //登录成功跳转到登录页面
    @RequestMapping("/login")
    public void login(String name, String password) {
   
        ModelAndView mv = new ModelAndView();
        User user = userService.selectByNameAndPwd(name, password);
        if(user!=null){
   
            //如果用户存在,跳转到登录成功页面
            mv.setViewName("succeed");
            mv.addObject("user",user);
            System.out.println("登录成功");
            System.out.println(mv);
        }else {
   
            mv.setViewName("login");
            System.out.println("登录失败");
            System.out.println(mv);
        }
    }
    //注册成功跳转登录页面,注册失败留在注册页面
    @RequestMapping("/register")
    public void register(User user){
   //这里没有视图,所有设置为void
        //如果影响行数不等于0,则说明加入成功,返回登录页面
        int i = userService.insertUser(user);
        if(i!=0){
   
            //return "login";
        }
        //否则注册失败,留在注册界面
        //return "register";
    }
}





 

测试:当账号密码存在,跳转成功页面

当密码不正确:跳转登录页面

程序打包和运行

第一,为什么我们需要打包?因为当我们把项目在我们的电脑上写好以后,需要发布项目供客户使用,不能你一写好,关机回家,客户也跟着下线。所以一般会把程序打包,然后在专门的服务器上运行。
程序打包:找到我们的项目的生命周期,先clean,然后执行package。


注意以下输出:


看到BUILD SUCCESS说明我们已经打包成功了。
运行程序:
找到打包好的target目录,右键——>open in——>Explorer


进入到存储的项目target目录中:

在地址栏里输入cmd,敲入Java -jar s+tab键自动补全,运行项目

然后看下图:您猜怎么着?我们刚才的项目运行的时候已经把端口占用了,有没有解决办法?有

教你一招

解决端口占用问题:
一、以临时端口号解决

java -jar 项目 --server.port=临时端口号
启动:可以看到启动是没问题的

而且端口已经变成了8085,我们在上面的时候设置的端口号是8081

可是设置临时端口号也有弊端,弊端就是很混乱,今天这个被占用,明天那个被占用。有没有一劳永逸的办法?没有,但是有一个你掌握了就能解决此类问题的办法。

二:杀死端口占用

#查询端口
netstat -ano
#查询指定端口
netstat -ano|findstr "端口号"
#根据进程PID查询进程名称
tasklist | findstr "进程PID号"
#根据PID杀死任务
taskkill /F /PID "进程PID号"
# 根据进程名称杀死任务
taskkill -f -t -im "进程名称"

举例:

小结:

还有一个需要注意的点就是,打包我们的项目,需要导入一个插件,不过这个插件在我们创建springboot项目之初就已经导入了。

另外还有一些常见的小问题,如打包之后多出来很多东西,还记得我们在上面打包过程中的test过程吗?不记得了?上去看看,我已经截图放在文章中了,在我们执行打包的时候,一般需要跳过这个test过程,以保证数据的准确性。

找到maven生命周期,选择test,点击闪电符号即可跳过测试。

结尾小结

我这里在调试debug的时候,出现了一些小问题,如下图所示:

问题:Skipped breakpoint at com.sun.proxy.$Proxy74.toString()+0 because it happened inside debugger evaluatio

翻译:跳过com.sun.proxy.$Proxy74.toString()+0处的断点,因为它发生在调试器评估中

看不懂,查看了资料说:IDEA的debugger是默认会在内部将方法执行一次,然后回显提示数据,本意是很好,但有时候会干扰影响结果。

解决方案:file——>settings——>build——>Debugger——>Data Views——>java

把上图中的1取消勾选即可,一般取消这个即可,如果还是不行就把1、2处都取消勾选,这样就万无一失了。
大家又掌握一个小方法。


转载:https://blog.csdn.net/qq_63992577/article/details/127591378
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场