今天小编给大家分享一下基于SpringBoot和Vue3的博客平台的用户注册与登录功能怎么实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
1. 后端Spring Boot实现
首先,我们需要创建一个Spring Boot项目,并配置所需的依赖。
1.1 创建Spring Boot项目
通过Spring Initializr或者IDEA创建一个新的Spring Boot项目,选择以下依赖:
Web
MyBatis
MySQL
1.2 配置application.yml
配置数据库连接信息、MyBatis配置等。
spring:
datasource:
url: jdbc:mysql://localhost:3306/your_database?useSSL=false&allowPublicKeyRetrieval=true&serverTimezone=UTC
username: your_username
password: your_password
mybatis:
mapper-locations: classpath:mapper/*.xml
type-aliases-package: com.example.demo.entity
server:
port: 8080
1.3 实现后端API
创建实体类、Mapper接口、Service接口及实现、Controller类。
1.3.1 创建User实体类
public class User {
private Integer id;
private String username;
private String password;
// Getter and Setter methods
}
1.3.2 创建UserMapper接口
@Mapper
public interface UserMapper {
User findByUsername(String username);
void insert(User user);
}
1.3.3 创建UserService接口及实现
public interface UserService {
User findByUsername(String username);
void register(User user);
}
@Service
public class UserServiceImpl implements UserService {
@Autowired
private UserMapper userMapper;
@Override
public User findByUsername(String username) {
return userMapper.findByUsername(username);
}
@Override
public void register(User user) {
userMapper.insert(user);
}
}
2. 前端Vue3实现
接下来,我们将使用Vue3实现前端部分。
2.1 创建Vue3项目
使用Vue CLI创建一个Vue3项目,并安装Element Plus、Axios等插件。
vue create my-project
cd my-project
vue add element-plus
npm install axios
2.2 实现注册页面组件
创建一个名为
Register.vue
的新组件,并添加以下内容:<template>
<el-form ref="form" :model="form" label-width="80px">
<el-form-item label="用户名" prop="username">
<el-input v-model="form.username"></el-input>
</el-form-item>
<el-form-item label="密码" prop="password">
<el-input v-model="form.password" show-password></el-input>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="submitForm('form')">注册</el-button>
</el-form-item>
</el-form>
</template>
<script>
import { reactive } from "vue";
import axios from "axios";
export default {
setup() {
const form = reactive({ username: "", password: "" });
const submitForm = async () => {
try {
await axios.post("/api/user/register", form);
alert("注册成功");
} catch (error) {
alert("注册失败");
}
};
return { form, submitForm };
},
};
</script>
2.3 实现登录页面组件
创建一个名为
Login.vue
的新组件,并添加以下内容:<template>
<el-form ref="form" :model="form" label-width="80px">
<el-form-item label="用户名" prop="username">
<el-input v-model="form.username"></el-input>
</el-form-item>
<el-form-item label="密码" prop="password">
<el-input v-model="form.password" show-password></el-input>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="submitForm('form')">登录</el-button>
</el-form-item>
</el-form>
</template>
<script>
import { reactive } from "vue";
import axios from "axios";
export default {
setup() {
const form = reactive({ username: "", password: "" });
const submitForm = async () => {
try {
const response = await axios.post("/api/user/login", form);
if (response.data.success) {
alert("登录成功");
// 保存登录状态
} else {
alert("登录失败");
}
} catch (error) {
alert("登录失败");
}
};
return { form, submitForm };
},
};
</script>
2.4 使用Vue Router配置路由
安装Vue Router并配置路由:
vue add router
在
src/router/index.js
中添加注册和登录组件的路由:import { createRouter, createWebHashHistory } from "vue-router";
import Register from "../views/Register.vue";
import Login from "../views/Login.vue";
const routes = [
{
path: "/register",
name: "Register",
component: Register,
},
{
path: "/login",
name: "Login",
component: Login,
},
];
const router = createRouter({
history: createWebHashHistory(),
routes,
});
export default router;
现在,您可以在浏览器中通过访问/register和/login路由来查看注册和登录页面。
至此,您已经完成了基于Spring Boot和Vue3的用户注册与登录功能的实现。这个教
程仅作为一个简单示例,实际项目中可能还需要加入表单验证、错误处理、用户权限管理等功能。
接下来,我们将实现一个简单的登录状态管理。
2.5 实现登录状态管理
在
src
目录下创建一个名为store.js
的文件,用于管理登录状态:import { reactive } from "vue";
const state = reactive({
user: null,
});
const setUser = (user) => {
state.user = user;
};
const clearUser = () => {
state.user = null;
};
export default {
state,
setUser,
clearUser,
};
在登录页面组件中,将用户信息保存到
store.js
:// 在Login.vue中导入store
import store from "../store";
// ...
const submitForm = async () => {
try {
const response = await axios.post("/api/user/login", form);
if (response.data.success) {
alert("登录成功");
store.setUser(response.data.data);
// 跳转到首页或其他页面
} else {
alert("登录失败");
}
} catch (error) {
alert("登录失败");
}
};
// ...
现在,您可以在其他组件中访问store.state.user来获取登录用户的信息。如果user为null,则表示用户尚未登录。
这是一个非常简单的登录状态管理实现。在实际项目中,您可以考虑使用更为复杂的状态管理库,如Vuex,以更好地管理应用程序的状态。