この記事の内容
最近は、YouTubeなどでもノンコーディングでWebサイトを作ってみた系の動画があるので、
おそらく、SpringBootでEntityが一個のWebアプリなら作れるだろうと思い、試してみた。
ChatGPTとの会話
ちなみに、コードは一切手直ししていません。
最初の応答
package com.example.demo.model;
import javax.persistence.*;
@Entity
@Table(name = "employees")
public class Employee {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@Column(name = "name")
private String name;
@Column(name = "email")
private String email;
@Column(name = "phone")
private String phone;
// コンストラクタ、Getter、Setter、toStringの作成
// ...
}
Employee Repositoryの作成
新しいパッケージを作成し、EmployeeRepositoryインターフェースを作成します。
package com.example.demo.repository;
import com.example.demo.model.Employee;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;
@Repository
public interface EmployeeRepository extends JpaRepository<Employee, Long> {
}
Employee Controllerの作成
新しいパッケージを作成し、EmployeeControllerクラスを作成します。
package com.example.demo.controller;
import com.example.demo.model.Employee;
import com.example.demo.repository.EmployeeRepository;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.*;
@Controller
public class EmployeeController {
@Autowired
private EmployeeRepository employeeRepository;
@GetMapping("/")
public String viewHomePage(Model model) {
model.addAttribute("listEmployees", employeeRepository.findAll());
return "index";
}
@GetMapping("/showNewEmployeeForm")
public String showNewEmployeeForm(Model model) {
Employee employee = new Employee();
model.addAttribute("employee", employee);
return "new_employee";
}
@PostMapping("/saveEmployee")
public String saveEmployee(@ModelAttribute("employee") Employee employee) {
employeeRepository.save(employee);
return "redirect:/";
}
@GetMapping("/showFormForUpdate/{id}")
public String showFormForUpdate(@PathVariable(value = "id") Long id, Model model) {
Employee employee = employeeRepository.findById(id).orElseThrow(() -> new IllegalArgumentException("Invalid employee Id:" + id));
model.addAttribute("employee", employee);
return "update_employee";
}
@GetMapping("/deleteEmployee/{id}")
public String deleteEmployee(@PathVariable(value = "id") Long id) {
Employee employee = employeeRepository.findById(id).orElseThrow(() -> new IllegalArgumentException("Invalid employee Id:" + id));
employeeRepository.delete(employee);
return "redirect:/";
}
}
Viewの作成は力尽きたようだ...
Viewの作成を再度依頼
こちらは、もう少し詳しく!とカジュアルに頼んだけど、AIは丁寧だ。
(人間だとブチギレる人もいるので、AIのほうがその点はいいかも)
以下が、View(html)の作品群
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8">
<title>Employee Management System</title>
<link rel="stylesheet" th:href="@{/css/bootstrap.min.css}" />
</head>
<body>
<div class="container">
<h1 class="text-center">Employee Management System</h1>
<br>
<a href="/showNewEmployeeForm" class="btn btn-primary mb-3">Add New Employee</a>
<br>
<table class="table table-striped">
<thead>
<tr>
<th>ID</th>
<th>Name</th>
<th>Email</th>
<th>Phone</th>
<th>Action</th>
</tr>
</thead>
<tbody>
<tr th:each="employee : ${listEmployees}">
<td th:text="${employee.id}"></td>
<td th:text="${employee.name}"></td>
<td th:text="${employee.email}"></td>
<td th:text="${employee.phone}"></td>
<td>
<a th:href="@{'/showFormForUpdate/' + ${employee.id}}" class="btn btn-sm btn-info mr-2">Edit</a>
<a th:href="@{'/deleteEmployee/' + ${employee.id}}" class="btn btn-sm btn-danger" onclick="return confirm('Are you sure you want to delete this employee?')">Delete</a>
</td>
</tr>
</tbody>
</table>
</div>
<script th:src="@{/js/bootstrap.min.js}"></script>
</body>
</html>
登録用のView
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8">
<title>New Employee</title>
<link rel="stylesheet" th:href="@{/css/bootstrap.min.css}" />
</head>
<body>
<div class="container">
<h1 class="text-center">Add New Employee</h1>
<br>
<form th:action="@{/saveEmployee}" th:object="${employee}" method="post">
<div class="form-group">
<label for="name">Name:</label>
<input type="text" th:field="*{name}" class="form-control" placeholder="Enter name" />
</div>
<div class="form-group">
<label for="email">Email:</label>
<input type="email" th:field="*{email}" class="form-control" placeholder="Enter email" />
</div>
<div class="form-group">
<label for="phone">Phone:</label>
<input type="text" th:field="*{phone}" class="form-control" placeholder="Enter phone number" />
</div>
<button type="submit" class="btn btn-primary">Save</button>
<a href="/" class="btn btn-secondary ml-2">Cancel</a>
</form>
</div>
<script th:src="@{/js/bootstrap.min.js}"></script>
</body>
</html>
UpdateのViewが届いていないので催促してみた
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8">
<title>Edit Employee</title>
<link rel="stylesheet" th:href="@{/css/bootstrap.min.css}" />
</head>
<body>
<div class="container">
<h1 class="text-center">Edit Employee</h1>
<br>
<form th:action="@{/updateEmployee}" th:object="${employee}" method="post">
<input type="hidden" th:field="*{id}" />
<div class="form-group">
<label for="name">Name:</label>
<input type="text" th:field="*{name}" class="form-control" placeholder="Enter name" />
</div>
<div class="form-group">
<label for="email">Email:</label>
<input type="email" th:field="*{email}" class="form-control" placeholder="Enter email" />
</div>
<div class="form-group">
<label for="phone">Phone:</label>
<input type="text" th:field="*{phone}" class="form-control" placeholder="Enter phone number" />
</div>
<button type="submit" class="btn btn-primary">Update</button>
<a href="/" class="btn btn-secondary ml-2">Cancel</a>
</form>
</div>
<script th:src="@{/js/bootstrap.min.js}"></script>
</body>
</html>
動作確認
動作確認してみた。
予想通りですが、(ある程度)ちゃんと動いた!
実はUpdateのところでSubmitすると404が返ってくるので、そこは後で、ChatGPTと相談した。
まずは、動作の様子のスクショ
http://localhost:8080
にアクセスした状態。
Employee Management Systemという大仰なタイトルに身が引き締まる。
動作確認前の追加オーダー
実は、application.propertiesを依頼し忘れたので、以下のように追加依頼した。
前回の文脈は覚えていないはず?なので、文脈に依存しない依頼とした。
これで(Updateを除いて)期待通りに動作した。
H2のインメモリーモードのデータをH2コンソールから見る
H2はめったに使わないので、H2コンソールの使い方は毎回調べていた。
今回はChatGPTに気軽に聞いてみた。
H2のコンソールアクセス失敗したので記憶を頼りに追加依頼
上記の状態だとH2コンソールにアクセスすると404になるので、以下の追加依頼を実施!
これで、H2コンソールも使えるようになった。
僕が「いかがでしょうか?」と聞いて、
ChatGPTが「おっしゃるとおりです」と返してきたときに、心が通じ合った気がした。
Updateがエラーとなる問題をChatGPTに相談する。
まずは、問いかけ(なお、このときに、ViewとControllerはChatにベタっと貼り付けた。画像上は省略)

Updateも動くようになった!
感想
周りでの利用例からすると、ChatGPTでSpringBootの超簡単なアプリなら作れるだろうと予測はしてた。
しかし、ちょっとぐらいは自分で考えて手直しする部分はあるだろうと思ってた。
結果としてコードは1行も自分で書いていない(コピペしただけ)ので、これは相当に頼れる相棒感満載だー!
少し真面目な話をすると、テストコードやテストデータの作成などに実際に適用し始めている例も身近にあるので、うまく使っていって良いサービスを作るのに役立てたい!
免責事項
(このセクションだけですます調で)
この作業の進め方は所属組織の標準的なものではありません。(少なくとも現時点では)
単なる個人的な実験です。
バリデーションとかダブルサブミット防止とか実用的なアプリケーションにするためのナレッジについては、別途、所属組織が開設している技術サイトがありますので、そちらを参照ください。












