Spring Boot Tutorial
Spring Boot Tutorial
Download latest version of “Eclipse IDE for Java Developers”.
data:image/s3,"s3://crabby-images/5b4a4/5b4a427e500fbc60adb3be22e792634e44e6844b" alt="spring boot tutorial"
- Open the Spring initializr https://start.spring.io
data:image/s3,"s3://crabby-images/1e2ff/1e2ff0b5436574c116cc7659bbafd84005daf969" alt="spring boot tutorial"
- Provide the Group and Artifact name. Now click on the Generate button.
data:image/s3,"s3://crabby-images/aee55/aee5588be3068f21ce947b73ca4db7ca2e289dd1" alt="spring boot tutorial"
When we click on the Generate button, it starts packing the project in a .rar file and downloads the project. Extract the RAR file.
Double-click on file to Install the Eclipse. A new window will open. Click Eclipse IDE for Enterprise Java and Web Developers.
data:image/s3,"s3://crabby-images/a327e/a327ef7bd6318c0c1f66303a3dd54e90b600f404" alt="spring boot tutorial"
data:image/s3,"s3://crabby-images/ab169/ab1691a46efa2a828ba8dbcd0bc1b6cc42237cc9" alt="spring boot tutorial"
Now click on the Install button. By accepting the Agreement you can complete installation. It will take some time to complete the installation.
data:image/s3,"s3://crabby-images/8f93f/8f93fd6d2d48f7699a5f2931f06a05bcb5fd8271" alt="spring boot tutorial"
data:image/s3,"s3://crabby-images/7f528/7f5281dacac9b3ee92ccd769ce33aeb1ec9fa75a" alt="spring boot tutorial"
After successfully installed now click on the LUNCH button as shown below.
data:image/s3,"s3://crabby-images/10598/10598601d6a6f4f83c0ad94e0a302e133d527f4a" alt="spring boot tutorial"
data:image/s3,"s3://crabby-images/ebbad/ebbadee8e5712cc494a374781e97bb6710086ce1" alt="spring boot tutorial"
data:image/s3,"s3://crabby-images/b94aa/b94aa48a90f7a0f8f14cb506b58d39c8ab1d2652" alt="spring boot tutorial"
data:image/s3,"s3://crabby-images/9d4a6/9d4a64052169fa1e00f5d7fd0114a1214427bb23" alt="spring boot tutorial"
File -> Open Projects from file System
data:image/s3,"s3://crabby-images/91cda/91cda291b0e7426f916f97dc3b6e44c1b6a97e1e" alt="spring boot tutorial"
data:image/s3,"s3://crabby-images/3ec08/3ec0841e59e0da3fab2878a46a4681f82aece46e" alt="spring boot tutorial"
data:image/s3,"s3://crabby-images/53f42/53f4233efc366e5f81278e2ab3d1dff5200f5d9b" alt="spring boot tutorial"
data:image/s3,"s3://crabby-images/ddfed/ddfeddbec24adcdc2d4642dab8e32a99d06aefc9" alt="spring boot tutorial"
data:image/s3,"s3://crabby-images/6895a/6895a32d9eb4260b4c8093635a82615701ff0975" alt="spring boot tutorial"
Right Click on Vasan Stores -> New -> Class [create a Java class]
data:image/s3,"s3://crabby-images/7c825/7c825aadd6a4236de78505886b3271ca97cc1d92" alt="spring boot tutorial"
Create Class Name -> Click on Next
data:image/s3,"s3://crabby-images/e4e81/e4e81192b6c97c4f61a760beec3ac5d50dbad9a2" alt="spring boot tutorial"
data:image/s3,"s3://crabby-images/235f8/235f86e96b0b7f44a5818ce951041c3eba226d52" alt="spring boot tutorial"
data:image/s3,"s3://crabby-images/4050c/4050c8d453ac9573598d42254158eef7c7ec8ce8" alt="spring boot tutorial"
In coding Window, Right Click on Source -> Generate Getter and Setter Methods
data:image/s3,"s3://crabby-images/f968b/f968b178565de406ebf494bec40aa611ad026366" alt="spring boot tutorial"
data:image/s3,"s3://crabby-images/f31ee/f31ee7877fd5af6ac1b930dd5a99c4b2ef6d161f" alt="spring boot tutorial"
data:image/s3,"s3://crabby-images/d321f/d321f3793ec6b348888724588defaad9ed12ef65" alt="spring boot tutorial"
In coding Window, Right Click on Source -> Generate Constructors from Super Class
data:image/s3,"s3://crabby-images/a4bec/a4beca7234900dfe1145f7166da59b0a7f7732b1" alt="spring boot tutorial"
data:image/s3,"s3://crabby-images/c329a/c329a05be8febf1be4553b8bffc9d04ed5acfd7f" alt="spring boot tutorial"
Spring Boot Login Registeration Page
data:image/s3,"s3://crabby-images/a439f/a439f9c9ecec9f9ecb18176b84d81ec9b256c4c2" alt="spring boot tutorial"
SQL Database Create
CREATE DATABASE azdatabase
SQL Table Create
USE azdatabase
Create Table kaashiv (
id int PRIMARY KEY IDENTITY(1,1) NOT NULL,
email varchar(50) NULL,
password varchar(50) NULL
)
SQL Store Procedure
create proc student_login(
@eamil varchar(50),
@password varchar(50)
)
as begin
select * from kaashiv where email = @eamil AND password = @password
end
create proc student_register(
@eamil varchar(50),
@password varchar(50)
)
as begin
insert into kaashiv values(@eamil, @password)
end
pom.xml
<?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>3.2.0</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.kaashiv</groupId>
<artifactId>signup.login</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>signup.login</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>17</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
<!-- Declar Your JDK Mssql Driver -->
<dependency>
<groupId>com.microsoft.sqlserver</groupId>
<artifactId>mssql-jdbc</artifactId>
<version>11.2.0.jre18</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
application.properties
spring.datasource.driver-class-name=com.microsoft.sqlserver.jdbc.SQLServerDriver
spring.datasource.url=jdbc:sqlserver://127.0.0.1:1433;databaseName=azdatabase;TrustServerCertificate=True
spring.datasource.username=YOUR_USER_NAME
spring.datasource.password=YOUR_PASSWORD
spring.jpa.show-sql=true
server.port=5000
StudentModel.java
package com.kaashiv.signup.login;
import jakarta.persistence.Entity;
import jakarta.persistence.GeneratedValue;
import jakarta.persistence.GenerationType;
import jakarta.persistence.Id;
import jakarta.persistence.Table;
@Entity
@Table(name = "kaashiv")
public class StudentModel {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private long id;
private String email;
private String password;
public StudentModel() {
super();
// TODO Auto-generated constructor stub
}
public long getId() {
return id;
}
public void setId(long id) {
this.id = id;
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
}
StudentRepository.java
package com.kaashiv.signup.login;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Modifying;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.query.Param;
import org.springframework.stereotype.Repository;
import org.springframework.transaction.annotation.Transactional;
@Repository
public interface StudentRepository extends JpaRepository<StudentModel, Integer> {
@Transactional
@Modifying
@Query(nativeQuery = true, value = "student_register :email , :password")
public void Student_Register(@Param("email") String email,@Param("password") String password);
@Query(nativeQuery = true, value = "student_login :email , :password")
public StudentModel Student_Login(@Param("email") String email,@Param("password") String password);
}
StudentController.java
package com.kaashiv.signup.login;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.PostMapping;
@Controller
public class StudentController {
@Autowired
private StudentRepository repo;
@GetMapping("/register")
public String Register() {
return "register";
}
@PostMapping("/register-post")
public String RegisterPost(@ModelAttribute StudentModel std) {
repo.Student_Register(std.getEmail(),std.getPassword());
return "redirect:/";
}
@GetMapping("/")
public String Login() {
return "login";
}
@PostMapping("/login-post")
public String LoginPost(@ModelAttribute StudentModel std) {
StudentModel check = repo.Student_Login(std.getEmail(),std.getPassword());
if(check != null) {
return "index";
}
return "redirect:/";
}
}
login.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link href="https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-EVSTQN3/azprG1Anm3QDgpJLIm9Nao0Yz1ztcQTwFspd3yD65VohhpuuCOmLASjC" crossorigin="anonymous">
<title>Kaashiv - Login</title>
<style>
body {
display: flex;
align-items: center;
justify-content: center;
height: 100vh;
margin: 0;
}
</style>
</head>
<body>
<div class="container col-4 shadow" style="padding:30px">
<form th:action="@{/login-post}" method="post">
<h1 class="text-center">Kaashiv - Login</h1><br>
<label>Email :</label><br>
<input type="email" name="email" placeholder="Enter Email" class="form-control" required><br>
<label>Password :</label><br>
<input type="password" name="password" placeholder="Enter Password" class="form-control" required><br><br>
<input type="submit" value="Login" class="btn btn-outline-primary"><br><br>
<p>Don't have accounct <a href="/register"> Signup?</a></p>
</form>
</div>
</body>
</html>
register.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link href="https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-EVSTQN3/azprG1Anm3QDgpJLIm9Nao0Yz1ztcQTwFspd3yD65VohhpuuCOmLASjC" crossorigin="anonymous">
<title>Kaashiv - Register</title>
<style>
body {
display: flex;
align-items: center;
justify-content: center;
height: 100vh;
margin: 0;
}
</style>
</head>
<body>
<div class="container col-4 shadow" style="padding:30px">
<form th:action="@{/register-post}" method="post">
<h1 class="text-center">Kaashiv - Register</h1><br>
<label>Email :</label><br>
<input type="email" name="email" placeholder="Enter Email" class="form-control" required><br>
<label>Password :</label><br>
<input type="password" name="password" placeholder="Enter Password" class="form-control" required><br><br>
<input type="submit" value="Register" class="btn btn-outline-primary"><br><br>
<p>Already an accounct <a href="/"> Login </a></p>
</form>
</div>
</body>
</html>
index.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
body {
display: flex;
align-items: center;
justify-content: center;
height: 100vh;
margin: 0;
}
</style>
</head>
<body>
<h1>Welcome to Kaashiv Infotech !</h1>
</body>
</html>