由于提供的代码已经是一个完整的Spring Boot项目,并且涉及到的内容较多,我将提供一个核心的Spring Boot + Vue + Element UI的图书商城管理系统的登录页面示例。
后端(Spring Boot):
// BookStoreController.java
@RestController
@RequestMapping("/api")
public class BookStoreController {
@PostMapping("/login")
public ResponseEntity<?> login(@RequestBody LoginRequest request) {
// 假设用户名和密码正确
if ("admin".equals(request.getUsername()) && "password".equals(request.getPassword())) {
return ResponseEntity.ok("登录成功");
}
return ResponseEntity.status(HttpStatus.UNAUTHORIZED).body("登录失败");
}
}
// LoginRequest.java
public class LoginRequest {
private String username;
private String password;
// getters and setters
}
前端(Vue + Element UI):
<!-- login.vue -->
<template>
<el-form ref="loginForm" :model="loginForm" label-width="80px">
<el-form-item label="用户名">
<el-input v-model="loginForm.username" autocomplete="off"></el-input>
</el-form-item>
<el-form-item label="密码">
<el-input type="password" v-model="loginForm.password" autocomplete="off"></el-input>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="submitForm">登录</el-button>
</el-form-item>
</el-form>
</template>
<script>
export default {
data() {
return {
loginForm: {
username: '',
password: ''
}
};
},
methods: {
submitForm() {
this.$http.post('/api/login', this.loginForm)
.then(response => {
console.log(response.data);
// 登录成功后的逻辑,如保存token,跳转到首页等
})
.catch(error => {
console.error('登录失败', error);
// 登录失败的逻辑,如提示用户错误信息等
});
}
}
};
</script>
在这个例子中,我们创建了一个简单的登录表单,并在Vue组件中定义了提交方法。当用户点击登录按钮时,会向后端的/api/login
端点发送一个POST请求,并在成功登录后处理响应。
请注意,这只是一个非常基础的示例,实际的项目中还需要包含诸如路由守卫、状态管理、异常处理等功能。