Почему мои данные не отправляются и не отправляются в базу данных MySQL, когда я нажимаю кнопку?

#java #spring #spring-boot #mysql-workbench

#java #весна #весенняя загрузка #mysql-workbench

Вопрос:

это мое приложение Java

 package com.example.abdo8;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class CodeJavaApplication {

    public static void main(String[] args) {
        SpringApplication.run(CodeJavaApplication.class, args); 
        
    }

}
 

это мой Admincontroller

 package com.example.abdo8.contoller;

import java.util.Collection;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpHeaders;
import org.springframework.http.HttpStatus;
import org.springframework.http.MediaType;
import org.springframework.http.ResponseEntity;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;

import com.example.abdo8.models.User;
import com.example.abdo8.service.userservice;

@RestController
public class Admincontroller {
    @Autowired
    userservice uDao;
    
    //@RequestMapping(value="/admin/addUser",method = RequestMethod.POST)
    //@PostMapping(path="/admin/addUser",consumes = {MediaType.APPLICATION_FORM_URLENCODED_VALUE})
    //@RequestMapping(value = "/admin/addUser", method = RequestMethod.POST, consumes = MediaType.APPLICATION_JSON_VALUE,
      //      produces = MediaType.APPLICATION_JSON_VALUE)
    @PostMapping(
              value = "admin/addUser", consumes = "application/json", produces = "application/json")
    public User  addUser(@RequestBody User usr)
    {
        //ResponseEntity<String>
        User n = new  User();
        System.out.println(usr);
        n.setEmail(usr.getEmail());
        n.setFirstname(usr.getFirstname());
        n.setLastname(usr.getLastname());
        n.setPassword(usr.getPassword());
        n.setUsername(usr.getUsername());
         uDao.saveUser(n);
         HttpHeaders httpHeaders = new HttpHeaders();

        //  return new ResponseEntity<>("{}", httpHeaders, HttpStatus.CREATED);
         return n;
        
    }
    @GetMapping("/admin/getAll")
    public Collection<User>getAllUsers()
    {
        return uDao.getAllUsers();
    }
    @DeleteMapping("admin/deleteUser/{id}")
    public void removeById(@RequestParam(name="id") int id)
    {
        uDao.removeUser(id);
    }
    
    @RequestMapping("/admin/testMethods/hi")
    @ResponseBody
    public String printHi()
    {
        return "hi";
    }
    
    

}
 

это мой повторный курс

 package com.example.abdo8.DOA;

import javax.persistence.Table;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;

import com.example.abdo8.models.User;

@Repository
public interface RepoCourse extends JpaRepository<User,Integer>  {


}
 

это мой курс

 package com.example.abdo8.models;

import java.io.Serializable;

public class Course implements Serializable{

    private static final long serialVersionUID = 1L;
    
}
 

это мой пользователь

 package com.example.abdo8.models;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;

@Entity
@Table(name = "users")
public class User {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    
    private int id;
    
    @Column
    private String email;
    
    @Column
    private String userpassword;
    
    @Column
    private String firstname;
    
    @Column
    private String lastname;
    
    @Column
    private String username;
    public User() {
        
    }
    public User( String email, String userpassword, String firstname, String lastname, String username) {
        super();
        
        this.email = email;
        this.userpassword = userpassword;
        this.firstname = firstname;
        this.lastname = lastname;
        this.username = username;
    }
    public String getUsername() {
        return username;
    }
    public void setUsername(String username) {
        this.username = username;
    }
    public String getPassword() {
        return userpassword;
    }
    public void setPassword(String password) {
        this.userpassword = password;
    }
    
    
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getEmail() {
        return email;
    }
    public void setEmail(String email) {
        this.email = email;
    }
    public String getFirstname() {
        return firstname;
    }
    public void setFirstname(String firstname) {
        this.firstname = firstname;
    }
    public String getLastname() {
        return lastname;
    }
    public void setLastname(String lastname) {
        this.lastname = lastname;
    }
    
}

 

this is my userservice

 package com.example.abdo8.service;

import java.util.Collection;

import javax.transaction.Transactional;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import com.example.abdo8.DOA.RepoCourse;
import com.example.abdo8.models.User;
@Service
@Transactional
public class userservice {
    @Autowired
    private RepoCourse dao;
    
    public User saveUser(User u)
    {
        
        return dao.save(u);
    }
    public Collection<User> getAllUsers()
    {
        return dao.findAll();
    }
    public void removeUser(int id )
    {
        dao.deleteById(id);
    }
    public User updateUser(User u )
    {
        return dao.save(u);
    }
}
 

this is my application properties

 #server.port=7000
spring.jpa.database-platform=org.hibernate.dialect.MySQL5InnoDBDialect
spring.jpa.hibernate.ddl-auto=update
spring.datasource.url = jdbc:mysql://localhost:3306/abdoDb?allowPublicKeyRetrieval=trueamp;createDatabaseIfNotExist=trueamp;useLegacyDatetimeCode=falseamp;serverTimezone=UTCamp;useSSL=false
spring.datasource.driverClassName=com.mysql.cj.jdbc.Driver
spring.datasource.username=admin
spring.datasource.password=Alma12345
spring.jpa.open-in-view=false
logging.level.org.hibernate.SQL=DEBUG
logging.level.org.hibernate.type=TRACE
spring.security.user.name=adam
spring.security.user.password=shlaz2009
 

this is my index.html

 <html lang="en">
<head>
    
<meta charset="utf-8">
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css" >
    <style type="text/css">
 <link href='http://fonts.googleapis.com/css?family=Open Sans Condensed:300' rel='stylesheet' type='text/css'>
<style type="text/css">
.form-style-8{
    font-family: 'Open Sans Condensed', arial, sans;
    width: 500px;
    padding: 30px;
    background: #FFFFFF;
    margin: 50px auto;
    box-shadow: 0px 0px 15px rgba(0, 0, 0, 0.22);
    -moz-box-shadow: 0px 0px 15px rgba(0, 0, 0, 0.22);
    -webkit-box-shadow:  0px 0px 15px rgba(0, 0, 0, 0.22);

}
.form-style-8 h2{
    background: #4D4D4D;
    text-transform: uppercase;
    font-family: 'Open Sans Condensed', sans-serif;
    color: #797979;
    font-size: 18px;
    font-weight: 100;
    padding: 20px;
    margin: -30px -30px 30px -30px;
}
.form-style-8 input[type="text"],
.form-style-8 input[type="date"],
.form-style-8 input[type="datetime"],
.form-style-8 input[type="email"],
.form-style-8 input[type="number"],
.form-style-8 input[type="search"],
.form-style-8 input[type="time"],
.form-style-8 input[type="url"],
.form-style-8 input[type="password"],
.form-style-8 textarea,
.form-style-8 select 
{
    box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    outline: none;
    display: block;
    width: 100%;
    padding: 7px;
    border: none;
    border-bottom: 1px solid #ddd;
    background: transparent;
    margin-bottom: 10px;
    font: 16px Arial, Helvetica, sans-serif;
    height: 45px;
}
.form-style-8 textarea{
    resize:none;
    overflow: hidden;
}
.form-style-8 input[type="button"], 
.form-style-8 input[type="submit"]{
    -moz-box-shadow: inset 0px 1px 0px 0px #45D6D6;
    -webkit-box-shadow: inset 0px 1px 0px 0px #45D6D6;
    box-shadow: inset 0px 1px 0px 0px #45D6D6;
    background-color: #2CBBBB;
    border: 1px solid #27A0A0;
    display: inline-block;
    cursor: pointer;
    color: #FFFFFF;
    font-family: 'Open Sans Condensed', sans-serif;
    font-size: 14px;
    padding: 8px 18px;
    text-decoration: none;
    text-transform: uppercase;
}
.form-style-8 input[type="button"]:hover, 
.form-style-8 input[type="submit"]:hover {
    background:linear-gradient(to bottom, #34CACA 5%, #30C9C9 100%);
    background-color:#34CACA;
}
        table{
         border-width: thick;
  border-collapse: collapse;
  width: 100%;
       
}

th, td {
  text-align: left;
  padding: 8px;
}
</style>
 <style type="text/css">
    *:lang(ar) { direction:rtl }
    *:lang(en) { direction:ltr }
</style> 
<title> login page </title>
</head>
<body dir="rtl" > 

    <div class="form-style-8">
  <h2>Login to your account</h2>
  <form>
    <input type="text" id="a1" name="field1" placeholder="FirstName" />
    <input type="text" id="a2" name="field2" placeholder="LastName" />
        <input type="text" id="a3" name="field4" placeholder="email" />
    <input type="text" id="a4" name="field5" placeholder="username" />
  <input type="text" id="a5" name="field6" placeholder="password" />
      
   <button type = "submit" class="btn btn-success btn-lg" onclick="postApi(this);" dir="rtl"> Sign Up</button>
    
  </form>
</div>
    <table class="table">
        <thead>
            
        <tr>
            <td>
                id
            </td>
             <td>
                firstname
            </td>
             <td>
                lastname
            </td>
             <td>
                email
            </td>
             <td>
                username
            </td>
             <td>
                password
            </td>
            </tr>
        </thead>
    </table>
    <!--  --script src="https://code.jquery.com/jquery-3.2.1.slim.min.js" ></script-->
<!--  -script src="https://ajax.googleapis.com/ajax/libs/jquery/1.8.3/jquery.min.js"></script-->
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.12.9/umd/popper.min.js" ></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/js/bootstrap.min.js"></script>

    <script>
    function postApi(val){
    var model = {
    "firstname": this.$("#a1").val(),
    "lastname": this.$("#a2").val(),
    "email" : this.$("#a3").val(),
    "username" : this.$("#a4").val(),
    "userpassword" : this.$("#a5").val()
    };
    console.log("post data:" model);
        $.ajax(
        {
            type:"POST",
            url : "admin/addUser",
            
            ContentType:"application/json ;charset=UTF-8",
            
            crossOrigin:true,
            dataType:"json",
            headers: {
                'Accept': 'application/json',
                'Content-Type': 'application/json'
                },
            data:this.JSON.stringify(model),
            
            success:function(data)
            {
                console.log("successfuly" data);
                alert("done");
            },error:function(jqXHR,testStatus,errorThrown)
            {
                alert("error");
            }
        }
        );
    }
    </script>
    <script type="text/javascript">
    $(document).ready(function(){
    $.ajax(
            {
                type:"get",
                url : "admin/getAll",
                
                ContentType:"application/json ;charset=UTF-8",
                
                crossOrigin:true,
                dataType:"json",
                headers: {
                    'Accept': 'application/json',
                    'Content-Type': 'application/json'
                    },
                
                
                success:function(result)
                {
                    console.log(result)
                    var table = $(".table")
                    for(i=0;i<result.length;i  )
                        {
                            table.append('<tr><td>'  result[i]["id"]   '</td>'  
                                    '<td>' result[i]["firstname"]   '</td>' 
                                    '<td>'  result[i]["lastname"]   '</td>' 
                                    '<td>'  result[i]["email"]   '</td>' 
                                    '<td>'  result[i]["username"]   '</td>' 
                                    '<td>'  result[i]["password"]  '</td>' 
                                    '<td><button class="btn btn-danger" id="remove" onclick="removeUser(' result[i]["id"] ')">حذف</button></td></tr>'
                                    
                            
                            );
                            $('message').html(table);
                        }
                    console.log("successfuly" data);
                    alert("done");
                },error:function(jqXHR,testStatus,errorThrown)
                {
                    alert("error");
                }
            });
    });
    
</script>
<script>
function removeUser(id){
         
         $.ajax({
                url: "admin/deleteUser/id?id=" id,
                method:'DELETE',
                dataType:'json',
                success:function(data){
                    alert("the user  number " id " is  deleted");
                    
                
            },error: function(jqXHR,testStatus,errorThrown){
                alert("faild !!!");
            }
         });
}
</script>
</body>
</html>
 

это мой 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 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.4.2</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.example</groupId>
    <artifactId>abdo-8</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>abdo-8</name>
    <description>Demo project for Spring Boot</description>
    <properties>
        <java.version>1.8</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jdbc</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-security</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-thymeleaf</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.thymeleaf.extras</groupId>
            <artifactId>thymeleaf-extras-springsecurity5</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.security</groupId>
            <artifactId>spring-security-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>
 

это мой abdotest

 package com.example.abdo8;

import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest;

@SpringBootTest
class  abdotest {

    @Test
    void contextLoads() {
    }

}
 

когда я нажимаю кнопку «Зарегистрироваться» на своей индексной странице, и я возвращаюсь к базе данных MySQL, и я перехожу к таблице, а в таблицах ничего нет

Ответ №1:

Ваш элемент формы не имеет действия или метода. Это просто

 <form>
 

Измените его на

 <form action="/admin/addUser" method="post">
 

Это должно отправить запрос вашему контроллеру. Обновите html, установите точку останова в вашем контроллере и запустите его в режиме отладки.