我的第一个后端项目(Springboot项目,环境搭建,项目启动,接口web验证)
后台-插件-广告管理-内容页头部广告(手机) |
一. 安装Java开发工具包(JDK):
访问Java Software | OracleOracle官方网站,下载适合你操作系统的最新版本的JDK。安装JDK并设置好JAVA_HOME环境变量。
二. 安装集成开发环境(IDE):
推荐使用IntelliJ IDEA作为IDE。你可以从官方网站(IntelliJ IDEA – the Leading Java and Kotlin IDE)下载适合你操作系统的版本,并根据安装向导进行安装。最新2023.2版本需要注册登录后才允许试用30天,可以自行寻找破解办法
三. 创建一个Spring Boot项目:
1.打开IDE,选择创建新的项目。
2.在创建项目的向导中选择Spring Initializr,填写项目的基本信息。
比如项目名称和所需的依赖。之后点击next进行下一步。
注:Server URL可改用阿里云:https://start.aliyun.com
3.勾选Spring Web,并点击finish完成项目的创建
4.第一次使用intellij idea,会自动下载加载资源。
四. 目录结构、配置项目依赖。
## SpringBoot项目结构 如下:
src/main/java/com项目根包:SpringBoot项目要求我们将来定义的类和包必须放在这个包下
BootDemoApplications是项目启动类:SpringBoot项目自动生成,里面包含main方法,直接启动后端
src/main/resoures/application.properties中定义端口号,如 server.port=8080
在项目创建过程中,选择添加Spring Boot的相关依赖。这些依赖将提供基本的Spring Boot功能和特性。可以在项目的构建文件(如pom.xml或build.gradle)中手动添加所需的依赖。
五. 编写代码
自动这里生成了样例代码
1.在项目结构中找到主启动类
(通常是一个名为Application的类),这是项目的入口,点击main即可运行。
你可以在这个类中添加启动Spring Boot应用的代码。
- package com.luoyang.bootdemo;
- import org.springframework.boot.SpringApplication;
- import org.springframework.boot.autoconfigure.SpringBootApplication;
- @SpringBootApplication
- public class BootDemoApplication {
- public static void main(String[] args) {
- SpringApplication.run(BootDemoApplication.class, args);
- }
- }
创建控制器(Controller)类来处理请求,创建数据访问对象(DAO)类来访问数据库,创建服务(Service)类来处理业务逻辑等。
2.控制器(Controller)样例代码
这里IDE自动生成了样例代码,给前端和移动端访问,提供了一些简单的Controller接口;
在demos.web目录下生成了Controller类,如下:
BasicController.java -Controller简单实现类
- package com.luoyang.bootdemo.demos.web;
- import org.springframework.stereotype.Controller;
- import org.springframework.web.bind.annotation.ModelAttribute;
- import org.springframework.web.bind.annotation.RequestMapping;
- import org.springframework.web.bind.annotation.RequestParam;
- import org.springframework.web.bind.annotation.ResponseBody;
- /**
- * Controller是所有处理业务请求的类的统称,我们可以创建一个包controller保存实际处理业务的所有Controller类
- * 1. controller包需要放在项目的根包下
- * 2. Controller上要定义@Controller注解,否则Spring MVC框架不识别该类
- * 3. 处理业务的方法要定义@RequestMapping注解,且参数要与页面请求表单中action的值一致
- *
- * @author theonefx
- */
- @Controller
- public class BasicController {
- // http://127.0.0.1:8080/hello?name=lisi
- @RequestMapping("/hello")
- @ResponseBody
- public String hello(@RequestParam(name = "name", defaultValue = "unknown user") String name) {
- return "我是后端,请求返回值是 " + name;
- }
- // http://127.0.0.1:8080/user
- @RequestMapping("/user")
- @ResponseBody
- public User user() {
- User user = new User();
- user.setName("theonefx");
- user.setAge(666);
- return user;
- }
- // http://127.0.0.1:8080/save_user?name=newName&age=11
- @RequestMapping("/save_user")
- @ResponseBody
- public String saveUser(User u) {
- return "user will save: name=" + u.getName() + ", age=" + u.getAge();
- }
- // http://127.0.0.1:8080/html
- @RequestMapping("/html")
- public String html() {
- return "index.html";
- }
- @ModelAttribute
- public void parseUser(@RequestParam(name = "name", defaultValue = "unknown user") String name
- , @RequestParam(name = "age", defaultValue = "12") Integer age, User user) {
- user.setName("zhangsan");
- user.setAge(18);
- }
- }
PathVariableController.java Controller具体实现类简单示例
- package com.luoyang.bootdemo.demos.web;
- import org.springframework.stereotype.Controller;
- import org.springframework.web.bind.annotation.PathVariable;
- import org.springframework.web.bind.annotation.RequestMapping;
- import org.springframework.web.bind.annotation.RequestMethod;
- import org.springframework.web.bind.annotation.ResponseBody;
- /**
- * 子类-具体实现类
- *
- * @author theonefx
- */
- @Controller
- public class PathVariableController {
- // http://127.0.0.1:8080/user/123/roles/222
- @RequestMapping(value = "/user/{userId}/roles/{roleId}", method = RequestMethod.GET)
- @ResponseBody
- public String getLogin(@PathVariable("userId") String userId, @PathVariable("roleId") String roleId) {
- return "User Id : " + userId + " Role Id : " + roleId;
- }
- // http://127.0.0.1:8080/javabeat/somewords
- @RequestMapping(value = "/javabeat/{regexp1:[a-z-]+}", method = RequestMethod.GET)
- @ResponseBody
- public String getRegExp(@PathVariable("regexp1") String regexp1) {
- return "URI Part : " + regexp1;
- }
- }
User.java 实体类
- package com.luoyang.bootdemo.demos.web;
- /**
- * 实体类
- *
- * @author theonefx
- */
- public class User {
- private String name;
- private Integer age;
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- public Integer getAge() {
- return age;
- }
- public void setAge(Integer age) {
- this.age = age;
- }
- }
静态资源目录src/main/resoures/static :用来保存当前web应用(我们的网站)中所有的静态资源(页面,图片和其他素材)
index.html
- <html>
- <body>
- <h1>hello word!!!h1>
- <p>this is a html pagep>
- body>
- html>
六. 配置数据库:
根据项目需求,选择适合的数据库(如MySQL、PostgreSQL、MongoDB等),安装并配置数据库连接信息。可以使用Spring Boot的配置文件(application.properties或application.yml)来设置数据库连接参数。
这里简单样例,直接把数据写死了
七. 运行项目:
在IDE中运行Spring Boot项目,IDE会自动启动内嵌的Web服务器。
1.在编辑器上点击编译项目,开启项目点击运行,如下图
如果使用Maven或Gradle构建项目,则可以使用命令行运行mvn spring-boot:run或gradle bootRun。
可能遇到的问题
1.启动不了,端口被占用
查看8080端口会不会被占用_☆七年的博客-CSDN博客
2.配置下载依赖仓库
File>Setting>Build、Execution、deployment>Build Tools>Maven,设置你自己的setting.xml,配置依赖下载地址,以及存储repository本地仓库
八. 验证项目
1.项目启动后,可以通过浏览器或API测试工具(如Postman)。
访问http://localhost:8080/或者指定的端口号,确保你能够看到Spring Boot欢迎页面。
这表示你的项目已经成功启动并运行。
其中使用了URL-统一资源定位
2.访问后端静态web页面
在浏览器中,根据URL的主机地址信息,可以找到服务器(Tomcat),抽象路径部分最开始的"/",则是让服务器去项目的static目录下找对应的资源文件
3.请求后端接口
以下是简单的示例接口,Get请求类型
http://127.0.0.1:8080/hello?name=lisi
九. 开发和测试
根据项目需求,继续开发和测试功能模块,编写业务逻辑和处理请求的代码。
十. 保存代码和版本控制
定期保存代码,使用版本控制工具(如Git)对代码进行管理,并提交代码到代码仓库。
以上是搭建一个Spring Boot项目及基本开发环境的步骤。你可以根据项目需求,进一步配置和扩展项目,例如添加安全认证、集成第三方服务等。记得在开发过程中关注错误日志和进行单元测试,以确保代码的质量和稳定性。
创造价值,乐哉分享!
一起入门后端 204146007
1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。
在线投稿:投稿 站长QQ:1888636
后台-插件-广告管理-内容页尾部广告(手机) |