开源SpringBoot项目
- 作者团队:纯洁的微笑
- 作者个人网站:http://www.ityouknow.com/
- 项目github:https://gitee.com/ityouknow/favorites-web?_from=gitee_search (国内的github)
一、IDEA创建工程
- springboot工程初始化
- 初始化配置
- 测试
1. IDEA初始化springboot
问题一:页面跳转
- @RestController
- @Controller
- @ResponseBody
三者之间的灵活使用
问题二:webjars管理前端资源
- 引入webjars-locator
- 在页面中引入前端资源
Hibernate中定义的Entity类(无论是JPA实现,还是Hibernate Native实现),都必须有一个无参数的构造函数。
问题三:ajax中网页的跳转
- window.location.href = "/index" 无法传递session 相当于重定向
- window.open("/index",'_self') 用法注意
问题四:template下子目录下模板的放行
- spring security
二、功能分析
1. 用户模块
1) 注册用户
- 判断邮箱与用户名是否存在,若存在则返回"邮箱与用户名已存在信息",即注册不成功信息
- 获取注册用户必需信息:邮箱、用户名、密码、创建时间(当前时间)、最新修改时间(当前时间)、个人图像(默认:img/favicon.png)
- 添加默认收藏夹:f_count=0、f_public_count=10
- 添加默认属性设置:c_default_model="simple"、c_defaut_collect_type="public"
1 查询用户邮箱是否存在
User registUser = userRepository.findByEmail(user.getEmail());
select * from user u where u.u_email = ?
2 查询用户名是否存在
User userNameUser = userRepository.findByUserName(user.getUserName());
select * from user u where u.u_name = ?
3 注册用户
userRepository.save(user);
insert into user u (u.u_name,u.u_email,u.u_profile_picture,u.u_introduction,u.u_create_time,u.u_last_modify_time,u.u_out_date,u.u_validata_code,u.u_background_picture) values(?,?,?,?,?,?,?,?,?,?)
4 默认收藏文件夹创建
Favorites favorites = favoritesService.saveFavorites(user.getId(), "未读列表");
insert into favorites(f_userId,f_name,f_count,f_create_time,f_last_modify_time,
f_public_name) values (?, ?, ?, ?, ?, ?)
5 默认属性配置的创建
configService.saveConfig(user.getId(),String.valueOf(favorites.getId()));
insert into config (c_user_id,c_default_favorties,c_default_collect_type, c_default_model,c_create_time, c_last_modify_time) values (?, ?, ?, ?, ?, ?)
2) 登录功能
- 使用用户名或者邮箱进行登录
- 保存cookie信息
- 返回的preUrl,第一登录时,preUrl="/"
- 获取收藏的数量
- 获取配置信息
- 获取收藏夹信息
- 获取关注信息
1. 查询用户名或邮箱是否存在
User loginUser = userRepository.findByUserNameOrEmail(user.getUserName(), user.getUserName());
select * from user u where u.u_name = ? or u.u_name = ?
2. 获取收藏数量信息
long size= collectRepository.countByUserIdAndIsDelete(getUserId(),IsDelete.NO);
select count(co.id) as count from collec co where co.co_userId=? and co.co_is_delete=?
3. 收藏夹信息
Favorites favorites = favoritesRepository.findById(Long.parseLong(config.getDefaultFavorties()));
select f.f_id as id, f.f_count as count, f.f_create_time as create_t, f.f_last_modify_time as last_mod, f.f_name as name, f.f_public_count as public, f.f_userId as user_id from favorites f where f.f_id=?
4. 属性配置信息
Config config = configRepository.findByUserId(getUserId());
select c.c_.id as id, c.c_create_time as create_t, c.c_default_collect_type as default, c.c_default_favorties as default_