为了账号安全,请及时绑定邮箱和手机立即绑定

Java全栈入门教程:从零开始学习Java全栈开发

标签:
Java
概述

本文详细介绍了从零开始学习Java全栈开发的过程,涵盖Java基础、后端开发、前端技术以及项目实践等内容,帮助读者全面掌握Java全栈技能。通过系统的学习,读者可以熟练运用Java进行全栈开发,从基础语法到实战项目,逐步提升开发能力。

Java全栈入门教程:从零开始学习Java全栈开发
Java基础入门

Java简介

Java是一种广泛使用的面向对象编程语言,由Sun Microsystems(现为Oracle公司)开发。Java以其“一次编写,到处运行”的特性而闻名,这意味着编写的Java程序可以在任何支持Java的平台上运行,而无需重新编译。

Java是跨平台的,因为它使用了Java虚拟机(JVM)作为运行时环境。Java语言被广泛应用于后端开发、Android应用开发、大数据处理、云计算等领域。

Java环境搭建

为了开始使用Java进行开发,你需要安装Java开发工具包(JDK)。以下是安装JDK的步骤:

  1. 下载JDK
    访问Oracle官网或OpenJDK官网下载适合你的操作系统的JDK版本。

  2. 安装JDK
    按照下载页面上的说明进行安装。安装完成后,你需要设置环境变量。

  3. 配置环境变量

    • 在Windows中,右键点击“计算机”,选择“属性” -> “高级系统设置” -> “环境变量”。在系统变量中添加“JAVA_HOME”变量,值为JDK的安装路径。在“Path”变量中添加“%JAVA_HOME%\bin”。

    • 在Linux或Mac中,打开终端,编辑~/.bashrc~/.zshrc文件,添加以下内容:
      export JAVA_HOME=/path/to/java
      export PATH=$JAVA_HOME/bin:$PATH

      保存文件后,运行source ~/.bashrcsource ~/.zshrc使更改生效。

Java基本语法

变量与类型

在Java中,变量用于存储数据值。Java有多种数据类型,包括基本数据类型和引用数据类型。基本数据类型包括整数类型、浮点类型、字符类型和布尔类型。

// 整数类型
int age = 20;
byte num = 100;
short number = 32767;
long largeNumber = 9999999999L;

// 浮点类型
float price = 19.99f;
double salary = 5000.00;

// 字符类型
char letter = 'A';

// 布尔类型
boolean isTrue = true;

控制流语句

控制流语句用于控制程序的执行流程。常见的控制流语句包括条件语句和循环语句。

// if语句
int score = 85;
if (score >= 60) {
    System.out.println("及格了");
} else {
    System.out.println("不及格");
}

// switch语句
int day = 3;
switch (day) {
    case 1:
        System.out.println("星期一");
        break;
    case 2:
        System.out.println("星期二");
        break;
    default:
        System.out.println("其他");
}

// while循环
int i = 0;
while (i < 5) {
    System.out.println(i);
    i++;
}

// for循环
for (int j = 0; j < 5; j++) {
    System.out.println(j);
}

// do-while循环
int k = 0;
do {
    System.out.println(k);
    k++;
} while (k < 5);

Java面向对象编程

Java是一门面向对象的语言,支持封装、继承、多态三大特性。

封装

封装是指将数据和操作数据的方法组合在一起,形成一个整体。通过访问控制符(如privatepublicprotected)来控制成员变量的访问。

public class Person {
    private String name;
    private int age;

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }
}

继承

继承允许一个类继承另一个类的属性和方法。子类可以扩展父类的功能,也可以重写父类的方法。

public class Animal {
    protected String name;

    public Animal(String name) {
        this.name = name;
    }

    public void speak() {
        System.out.println("Animal says: " + name);
    }
}

public class Dog extends Animal {
    public Dog(String name) {
        super(name);
    }

    @Override
    public void speak() {
        System.out.println("Dog " + name + " says: Woof!");
    }
}

public class Main {
    public static void main(String[] args) {
        Animal animal = new Animal("Generic");
        animal.speak();

        Dog dog = new Dog("Buddy");
        dog.speak();
    }
}

多态

多态允许一个对象在不同情况下表现出不同的行为。通过使用方法覆盖,子类可以重写父类的方法,从而实现多态。

public class Shape {
    public void draw() {
        System.out.println("Drawing Shape");
    }
}

public class Circle extends Shape {
    @Override
    public void draw() {
        System.out.println("Drawing Circle");
    }
}

public class Square extends Shape {
    @Override
    public void draw() {
        System.out.println("Drawing Square");
    }
}

public class Main {
    public static void main(String[] args) {
        Shape shape = new Shape();
        shape.draw();

        Shape circle = new Circle();
        circle.draw();

        Shape square = new Square();
        square.draw();
    }
}
Java后端开发

Java Web基础

Java Web开发通常涉及到服务器端技术,如Servlet、JSP和JavaServer Faces (JSF)。下面是一个简单的Servlet示例。

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

@WebServlet("/hello")
public class HelloWorldServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        response.setContentType("text/html");
        response.getWriter().println("<h1>Hello, World!</h1>");
    }
}

Spring Boot入门

Spring Boot是Spring框架的简化版本,旨在简化Spring应用的创建和部署。下面是一个简单的Spring Boot应用程序示例。

  1. 创建一个新的Spring Boot项目

  2. 启动Spring Boot应用程序
    • 创建一个Application类,作为Spring Boot应用程序的入口点。
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class Application {
    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}
  • src/main/resources目录下创建一个application.properties文件,设置端口号等配置。
server.port=8080
  • 创建一个简单的控制器来处理HTTP请求。
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class HelloController {
    @GetMapping("/hello")
    public String hello() {
        return "Hello, Spring Boot!";
    }
}

数据库操作(MySQL)

在Java中,可以通过JDBC或ORM框架(如Hibernate)来操作数据库。下面是一个使用JDBC连接MySQL数据库的例子,以及一个使用Hibernate框架的例子。

  1. 安装MySQL数据库

    • 在本地或远程服务器上安装MySQL数据库。
  2. 添加依赖
    • 使用Maven或Gradle在项目中添加MySQL和JDBC驱动依赖。
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.23</version>
</dependency>
  1. 编写数据库操作代码
    • 创建一个数据库连接管理和SQL操作类。
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

public class DatabaseUtil {
    private static String url = "jdbc:mysql://localhost:3306/mydb";
    private static String user = "root";
    private static String password = "password";

    public static Connection getConnection() throws SQLException, ClassNotFoundException {
        Class.forName("com.mysql.cj.jdbc.Driver");
        return DriverManager.getConnection(url, user, password);
    }

    public static void main(String[] args) throws SQLException, ClassNotFoundException {
        Connection conn = getConnection();
        String sql = "SELECT * FROM users";
        PreparedStatement ps = conn.prepareStatement(sql);
        ResultSet rs = ps.executeQuery();

        while (rs.next()) {
            System.out.println(rs.getString("name"));
        }

        rs.close();
        ps.close();
        conn.close();
    }
}
  1. 使用Hibernate操作数据库
    • 创建一个Hibernate配置文件hibernate.cfg.xml
<hibernate-configuration>
    <session-factory>
        <property name="hibernate.connection.driver_class">com.mysql.cj.jdbc.Driver</property>
        <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/mydb</property>
        <property name="hibernate.connection.username">root</property>
        <property name="hibernate.connection.password">password</property>
        <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
        <mapping class="com.example.User"/>
    </session-factory>
</hibernate-configuration>
  • 创建一个实体类User,定义数据库表的映射。
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;

@Entity
public class User {
    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Long id;
    private String name;
    private String email;

    // Getter and Setter
}
  • 编写代码来操作数据库。
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

public class HibernateUtil {
    private static SessionFactory sessionFactory;

    static {
        try {
            sessionFactory = new Configuration().configure().buildSessionFactory();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    public static Session getSession() {
        return sessionFactory.openSession();
    }
}

RESTful API设计

RESTful API是一种设计Web服务的标准。下面是一个使用Spring Boot创建RESTful API的示例。

  1. 创建一个实体类
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;

@Entity
public class User {
    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Long id;
    private String name;
    private String email;

    // Getter and Setter
}
  1. 创建一个数据访问对象(DAO)
import org.springframework.stereotype.Repository;
import java.util.List;

@Repository
public interface UserRepository extends JpaRepository<User, Long> {
    // 自定义查询方法
}
  1. 创建一个服务层
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;

@Service
public class UserService {
    @Autowired
    private UserRepository userRepository;

    public List<User> getAllUsers() {
        return userRepository.findAll();
    }
}
  1. 创建一个控制器
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import java.util.List;

@RestController
@RequestMapping("/api/users")
public class UserController {
    @Autowired
    private UserService userService;

    @GetMapping
    public List<User> getAllUsers() {
        return userService.getAllUsers();
    }

    @PostMapping
    public User createUser(@RequestBody User user) {
        return userService.createUser(user);
    }

    @PutMapping("/{id}")
    public User updateUser(@PathVariable Long id, @RequestBody User user) {
        user.setId(id);
        return userService.updateUser(user);
    }

    @DeleteMapping("/{id}")
    public void deleteUser(@PathVariable Long id) {
        userService.deleteUser(id);
    }
}
前端技术基础

HTML/CSS基础

HTML(HyperText Markup Language)用于创建网页的结构,CSS(Cascading Style Sheets)用于美化和布局网页。

HTML基础

<!DOCTYPE html>
<html>
<head>
    <title>My Web Page</title>
</head>
<body>
    <h1>Welcome to My Web Page</h1>
    <p>This is a paragraph.</p>
    <ul>
        <li>Item 1</li>
        <li>Item 2</li>
    </ul>
</body>
</html>

CSS基础

<!DOCTYPE html>
<html>
<head>
    <style>
        body {
            background-color: #f0f0f0;
        }
        h1 {
            color: #333;
            font-size: 30px;
        }
        p {
            color: #666;
            font-size: 16px;
        }
        ul {
            list-style-type: none;
        }
        li {
            background-color: #ddd;
            margin-bottom: 5px;
            padding: 5px;
        }
    </style>
</head>
<body>
    <h1>Welcome to My Web Page</h1>
    <p>This is a paragraph.</p>
    <ul>
        <li>Item 1</li>
        <li>Item 2</li>
    </ul>
</body>
</html>

JavaScript入门

JavaScript是一种广泛使用的脚本语言,用于在网页上添加交互性。以下是一个简单的JavaScript示例。

<!DOCTYPE html>
<html>
<head>
    <title>My Web Page</title>
</head>
<body>
    <h1 id="title">Welcome to My Web Page</h1>
    <button onclick="changeTitle()">Click Me</button>
    <script>
        function changeTitle() {
            document.getElementById('title').innerHTML = 'Hello, JavaScript!';
        }
    </script>
</body>
</html>

前端框架(如Vue.js)

Vue.js是一个渐进式的JavaScript框架,用于构建用户界面。下面是一个简单的Vue.js示例。

  1. 安装Vue.js
    • 通过CDN引入Vue.js。
<!DOCTYPE html>
<html>
<head>
    <title>My Web Page</title>
    <script class="lazyload" src="" data-original="https://cdn.jsdelivr.net/npm/vue@2"></script>
</head>
<body>
    <div id="app">
        <h1>{{ message }}</h1>
        <button v-on:click="changeMessage">Change Message</button>
    </div>
    <script>
        var app = new Vue({
            el: '#app',
            data: {
                message: 'Hello, Vue.js!'
            },
            methods: {
                changeMessage: function() {
                    this.message = 'Hello, World!';
                }
            }
        });
    </script>
</body>
</html>

前后端交互

前后端交互通常是通过HTTP请求来实现的。前端请求后端API,后端处理请求并返回数据。

后端(Spring Boot)

import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class DataController {
    @GetMapping("/data")
    public String getData() {
        return "Data from backend";
    }
}

前端(JavaScript)

<!DOCTYPE html>
<html>
<head>
    <title>My Web Page</title>
    <script class="lazyload" src="" data-original="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script>
</head>
<body>
    <h1 id="content"></h1>
    <button onclick="fetchData()">Fetch Data</button>
    <script>
        function fetchData() {
            axios.get('/data')
                .then(function (response) {
                    document.getElementById('content').innerHTML = response.data;
                })
                .catch(function (error) {
                    console.error(error);
                });
        }
    </script>
</body>
</html>
Java全栈实践项目

项目需求分析

假设我们需要开发一个简单的博客系统。该系统需要具备以下功能:

  • 用户注册和登录
  • 发布和查看博客文章
  • 评论和点赞功能

后端功能实现

后端主要使用Spring Boot来实现。

  1. 创建实体类

    • User:用户实体
    • Post:博客文章实体
    • Comment:评论实体
  2. 创建数据访问对象(DAO)

    • UserRepository:用户数据访问接口
    • PostRepository:博客文章数据访问接口
    • CommentRepository:评论数据访问接口
  3. 创建服务层

    • UserService:用户服务
    • PostService:博客文章服务
    • CommentService:评论服务
  4. 创建控制器

    • UserController:用户控制器
    • PostController:博客文章控制器
    • CommentController:评论控制器
  5. 具体代码实现
@Entity
public class User {
    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Long id;
    private String name;
    private String email;

    // Getter and Setter
}

@Entity
public class Post {
    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Long id;
    private String title;
    private String content;
    private User author;

    // Getter and Setter
}

@Entity
public class Comment {
    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Long id;
    private String content;
    private Post post;

    // Getter and Setter
}

@Repository
public interface UserRepository extends JpaRepository<User, Long> {
    // 自定义查询方法
}

@Repository
public interface PostRepository extends JpaRepository<Post, Long> {
    // 自定义查询方法
}

@Repository
public interface CommentRepository extends JpaRepository<Comment, Long> {
    // 自定义查询方法
}

@Service
public class UserService {
    @Autowired
    private UserRepository userRepository;

    public List<User> getAllUsers() {
        return userRepository.findAll();
    }

    public User saveUser(User user) {
        return userRepository.save(user);
    }

    // 其他服务方法
}

@Service
public class PostService {
    @Autowired
    private PostRepository postRepository;

    public List<Post> getAllPosts() {
        return postRepository.findAll();
    }

    public Post savePost(Post post) {
        return postRepository.save(post);
    }

    // 其他服务方法
}

@Service
public class CommentService {
    @Autowired
    private CommentRepository commentRepository;

    public List<Comment> getAllComments() {
        return commentRepository.findAll();
    }

    public Comment saveComment(Comment comment) {
        return commentRepository.save(comment);
    }

    // 其他服务方法
}

@RestController
@RequestMapping("/users")
public class UserController {
    @Autowired
    private UserService userService;

    @GetMapping
    public List<User> getAllUsers() {
        return userService.getAllUsers();
    }

    @PostMapping
    public User saveUser(@RequestBody User user) {
        return userService.saveUser(user);
    }

    // 其他控制器方法
}

@RestController
@RequestMapping("/posts")
public class PostController {
    @Autowired
    private PostService postService;

    @GetMapping
    public List<Post> getAllPosts() {
        return postService.getAllPosts();
    }

    @PostMapping
    public Post savePost(@RequestBody Post post) {
        return postService.savePost(post);
    }

    // 其他控制器方法
}

@RestController
@RequestMapping("/comments")
public class CommentController {
    @Autowired
    private CommentService commentService;

    @GetMapping
    public List<Comment> getAllComments() {
        return commentService.getAllComments();
    }

    @PostMapping
    public Comment saveComment(@RequestBody Comment comment) {
        return commentService.saveComment(comment);
    }

    // 其他控制器方法
}

前端页面设计

前端使用Vue.js来实现。

  1. 基础结构
<!DOCTYPE html>
<html>
<head>
    <title>Blog System</title>
    <script class="lazyload" src="" data-original="https://cdn.jsdelivr.net/npm/vue@2"></script>
    <script class="lazyload" src="" data-original="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script>
</head>
<body>
    <div id="app">
        <h1>{{ title }}</h1>
        <router-view></router-view>
    </div>
    <script class="lazyload" src="" data-original="js/app.js"></script>
</body>
</html>
  1. Vue组件
    • User.vue:用户登录和注册组件
    • Post.vue:发布和查看博客文章组件
    • Comment.vue:评论组件
<!-- User.vue -->
<template>
    <div>
        <h2>User Management</h2>
        <button @click="fetchUsers">Fetch Users</button>
        <ul>
            <li v-for="user in users">{{ user.name }} - {{ user.email }}</li>
        </ul>
    </div>
</template>

<script>
export default {
    data() {
        return {
            users: []
        }
    },
    methods: {
        fetchUsers() {
            axios.get('/users')
                .then(response => {
                    this.users = response.data;
                })
                .catch(error => {
                    console.error(error);
                });
        }
    }
}
</script>

<!-- Post.vue -->
<template>
    <div>
        <h2>Posts</h2>
        <button @click="fetchPosts">Fetch Posts</button>
        <ul>
            <li v-for="post in posts">{{ post.title }} - {{ post.content }}</li>
        </ul>
    </div>
</template>

<script>
export default {
    data() {
        return {
            posts: []
        }
    },
    methods: {
        fetchPosts() {
            axios.get('/posts')
                .then(response => {
                    this.posts = response.data;
                })
                .catch(error => {
                    console.error(error);
                });
        }
    }
}
</script>

<!-- Comment.vue -->
<template>
    <div>
        <h2>Comments</h2>
        <button @click="fetchComments">Fetch Comments</button>
        <ul>
            <li v-for="comment in comments">{{ comment.content }}</li>
        </ul>
    </div>
</template>

<script>
export default {
    data() {
        return {
            comments: []
        }
    },
    methods: {
        fetchComments() {
            axios.get('/comments')
                .then(response => {
                    this.comments = response.data;
                })
                .catch(error => {
                    console.error(error);
                });
        }
    }
}
</script>

整合前后端

  1. 前端请求后端API
    • 使用axios发送HTTP请求到后端API
<script>
export default {
    data() {
        return {
            title: 'Blog System',
            posts: []
        }
    },
    methods: {
        fetchPosts() {
            axios.get('/posts')
                .then(response => {
                    this.posts = response.data;
                })
                .catch(error => {
                    console.error(error);
                });
        }
    }
}
</script>
  1. 后端处理请求
    • 在控制器中处理前端发送的请求
@RestController
@RequestMapping("/posts")
public class PostController {
    @Autowired
    private PostService postService;

    @GetMapping
    public List<Post> getPosts() {
        return postService.getAllPosts();
    }

    @PostMapping
    public Post savePost(@RequestBody Post post) {
        return postService.savePost(post);
    }
}
开发工具和框架

开发环境搭建

开发环境通常包括IDE(如IntelliJ IDEA、Eclipse)、版本控制工具(如Git)、构建工具(如Maven或Gradle)等。

  1. 安装IDE

    • 下载并安装IntelliJ IDEA或Eclipse。
  2. 配置Git
    • 在终端中安装Git,并配置用户名和邮箱。
git config --global user.name "Your Name"
git config --global user.email "your.email@example.com"
  1. 创建新的Git仓库
git init
git add .
git commit -m "Initial commit"

版本控制工具(如Git)

Git是目前最流行的版本控制工具之一,用于跟踪源代码的变更历史,支持多人协作开发。Git的常用命令包括:

  • git clone:克隆一个远程仓库。
  • git pull:从远程仓库获取最新的代码。
  • git push:将本地的代码推送到远程仓库。
  • git commit:提交本地的代码变更。
  • git branch:创建、切换和删除分支。
  • git merge:合并分支。
  • git log:查看提交历史。

构建工具(如Maven、Gradle)

Maven和Gradle是两种流行的构建工具,用于自动化构建、测试和部署Java项目。

Maven

Maven使用pom.xml文件来定义项目的配置和依赖关系。

<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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.example</groupId>
    <artifactId>my-project</artifactId>
    <version>1.0-SNAPSHOT</version>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <version>2.3.4.RELEASE</version>
        </dependency>
    </dependencies>
</project>

Gradle

Gradle使用build.gradle文件来定义项目的配置和依赖关系。

plugins {
    id 'org.springframework.boot' version '2.3.4.RELEASE'
    id 'io.spring.dependency-management' version '1.0.9.RELEASE'
    id 'java'
}

group = 'com.example'
version = '1.0-SNAPSHOT'

repositories {
    mavenCentral()
}

dependencies {
    implementation 'org.springframework.boot:spring-boot-starter-web'
}

单元测试框架(如JUnit)

JUnit是Java中最流行的单元测试框架之一。以下是一个简单的JUnit测试示例。

import org.junit.jupiter.api.Test;
import static org.junit.jupiter.api.Assertions.assertEquals;

public class CalculatorTest {
    @Test
    public void testAddition() {
        Calculator calculator = new Calculator();
        assertEquals(4, calculator.add(2, 2));
    }
}
持续学习和资源推荐

学习路径规划

  1. Java基础

    • 掌握Java基本语法、面向对象编程、异常处理等。
  2. Java Web开发

    • 学习Servlet、JSP、Spring框架等。
  3. 数据库操作

    • 学习JDBC、Hibernate等数据库操作技术。
  4. 前端技术

    • 学习HTML、CSS、JavaScript、React或Vue.js等前端技术。
  5. 全栈开发
    • 集成前后端技术,开发完整的Web应用。

推荐书籍和在线资源

虽然这里不推荐书籍,但是可以推荐一些在线资源,如:

社区和论坛推荐

  1. Stack Overflow:解决编程问题的好地方。
  2. GitHub:分享代码和项目,参与开源社区。
  3. Reddit:加入与编程相关的子版块,如r/programming。
  4. Codecademy:在线学习编程的平台。

实战练习建议

  1. 个人项目:从简单的博客系统开始,逐渐增加功能。
  2. 开源项目:参与开源项目,提高实际开发能力。
  3. 竞赛平台:参加编程竞赛,如LeetCode、HackerRank。
  4. 在线课程:完成慕课网等平台上的实战项目。

通过上述步骤,你可以逐步掌握Java全栈开发的技能,成为一名优秀的全栈开发人员。

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消