質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.44%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Thymeleaf

Thymeleaf(タイムリーフ)とは、Java用のテンプレートエンジンで、特定のフレームワークに依存せず使用することが可能です。

Spring Boot

Spring Bootは、Javaのフレームワークの一つ。Springプロジェクトが提供する様々なフレームワークを統合した、アプリケーションを高速で開発するために設計されたフレームワークです。

Q&A

解決済

1回答

1973閲覧

spring bootでユーザー新規登録を実装したい データベースに保存されない

sei_7

総合スコア10

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Thymeleaf

Thymeleaf(タイムリーフ)とは、Java用のテンプレートエンジンで、特定のフレームワークに依存せず使用することが可能です。

Spring Boot

Spring Bootは、Javaのフレームワークの一つ。Springプロジェクトが提供する様々なフレームワークを統合した、アプリケーションを高速で開発するために設計されたフレームワークです。

0グッド

0クリップ

投稿2022/01/14 15:38

前提・実現したいこと

Java,、spring boot,、thymeleaf,、mysql 使用しています。
ユーザー新規登録を実装したい

発生している問題・エラーメッセージ

エラー文は出ておりません。

該当のソースコード

add.html

1 2 3<!DOCTYPE html> 4<html xmlns:th="http://www.thymeleaf.org"> 5 6<head> 7 <meta charset="UTF-8"> 8 <link rel="stylesheet" th:href="@{/css/reset.css}" type="text/css"> 9 <link rel="stylesheet" th:href="@{/css/user.css}" type="text/css"> 10 <title>新規登録</title> 11</head> 12 13<body> 14 <div th:insert="~{html/user/header :: copy}"></div> 15 16 <main class="addTop"> 17 <div class="form"> 18 <h1>ユーザー登録画面</h1> 19 <form action="/showAdd"> 20 <table> 21 <tr> 22 <th>名前</th> 23 <td><input type="text" name="name" class="text" required></td> 24 </tr> 25 <tr> 26 <th>メールアドレス</th> 27 <td><input type="text" name="email" class="text" required></td> 28 </tr> 29 <tr> 30 <th>住所</th> 31 <td><input type="text" name="address" class="text" required></td> 32 </tr> 33 <tr> 34 <th>パスワード</th> 35 <td><input type="text" name="password" class="text" required></td> 36 </tr> 37 </table> 38 <input type="submit" value="登録" class="btn"> 39 </form> 40 </div> 41 </main> 42 43 <div th:insert="~{html/user/footer :: copy}"></div> 44 45</body> 46 47</html> 48

UserController.java

1package com.example.demo; 2 3import org.springframework.beans.factory.annotation.Autowired; 4import org.springframework.stereotype.Controller; 5import org.springframework.web.bind.annotation.RequestMapping; 6import org.springframework.web.bind.annotation.RequestParam; 7import org.springframework.web.servlet.ModelAndView; 8 9@Controller 10public class UserController { 11 12 @Autowired 13 UserRepository UserRepository; 14 15 // 初期画面 16 @RequestMapping("/") 17 public String index() { 18 return "html/user/index"; 19 } 20 21 // 登録画面 22 @RequestMapping("/showAdd") 23 public String AddUser() { 24 return "html/user/add"; 25 } 26 27 @RequestMapping("/add") 28 public ModelAndView addUser( 29 @RequestParam(name = "name") String name, 30 @RequestParam(name = "email") String email, 31 @RequestParam(name = "address") String address, 32 @RequestParam(name = "password") String password, 33 ModelAndView mv) { 34 UserRepository.save(new User(name, email, address, password)); 35 36 mv.setViewName("html/user/add"); 37 return mv; 38 } 39} 40 41

UserRepository.java

1package com.example.demo; 2 3import org.springframework.data.jpa.repository.JpaRepository; 4import org.springframework.stereotype.Repository; 5 6@Repository 7public interface UserRepository extends JpaRepository<User, Integer> { 8} 9 10

User.java

1package com.example.demo; 2 3import javax.persistence.Column; 4import javax.persistence.Entity; 5import javax.persistence.GeneratedValue; 6import javax.persistence.GenerationType; 7import javax.persistence.Id; 8import javax.persistence.Table; 9 10@Entity 11@Table(name = "users") 12public class User { 13 @Id 14 @GeneratedValue(strategy = GenerationType.IDENTITY) 15 @Column(name = "code") 16 private int code; 17 18 @Column(name = "name") 19 private String name; 20 21 @Column(name = "email") 22 private String email; 23 24 @Column(name = "address") 25 private String address; 26 27 @Column(name = "password") 28 private String password; 29 30 public User() { 31 } 32 33 public User(String name, String email, String address, String password) { 34 this.name = name; 35 this.email = email; 36 this.address = address; 37 this.password = password; 38 } 39 40 public int getCode() { 41 return code; 42 } 43 44 public String getName() { 45 return name; 46 } 47 48 public String getEmail() { 49 return email; 50 } 51 52 public String getAddress() { 53 return address; 54 } 55 56 public String getPassword() { 57 return password; 58 } 59} 60 61

試したこと

データが保存されないのでUserControllerの下記の記述に間違いはないか

UserRepository.save(new User(name, email, address, password));

データ接続する記述に間違いはないか など確認
間違いの場所が分からなかった為ご教授をよろしくお願い致します。

補足情報(FW/ツールのバージョンなど)

Eclipceでプロジェクト作成

htmlのファイルは /templates/html/user/ の配下に配置しております。

データベース名 merikari
カラム code, name, email, address, password
codeにprimary keyを設定

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

add.htmlのactionで"/showAdd"と指定していて

add.html

1<form action="/showAdd">

UserControllerで新規登録の処理を行なっている部分の@RequestMappingでは”/add”と記述していました。

UserController.java

1@RequestMapping("/add")

/showAddは新規登録画面を表示するだけでなので
htmlのactionで/showAddを指定していた為、
登録ボタンを押したら新規登録画面に遷移するという処理を行なっていた為登録処理は行われなかったということでした。

投稿2022/01/15 07:27

sei_7

総合スコア10

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.44%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問