当前位置: 首页 > news >正文

蓬莱专业做网站公司杭州优化外包哪里好

蓬莱专业做网站公司,杭州优化外包哪里好,如何备份网站数据库,百度url提交入口文章目录 1.登录功能-后端1.思路分析2.完成对用户名和密码的校验1.com/sun/usercenter/service/UserService.java 添加方法2.com/sun/usercenter/service/impl/UserServiceImpl.java 添加方法3.com/sun/usercenter/service/impl/UserServiceImpl.java 新增属性 3.记录用户的登录…

文章目录

    • 1.登录功能-后端
        • 1.思路分析
        • 2.完成对用户名和密码的校验
          • 1.com/sun/usercenter/service/UserService.java 添加方法
          • 2.com/sun/usercenter/service/impl/UserServiceImpl.java 添加方法
          • 3.com/sun/usercenter/service/impl/UserServiceImpl.java 新增属性
        • 3.记录用户的登录态并配置MyBatisPlus的逻辑删除
          • 1.com/sun/usercenter/service/UserService.java 修改doLogin,增加参数 request
          • 2.com/sun/usercenter/service/impl/UserServiceImpl.java 新增属性
          • 3.com/sun/usercenter/service/impl/UserServiceImpl.java 添加代码
          • doLogin 方法添加代码,记录用户登录态
          • 4.配置MyBatisPlus的逻辑删除
            • 1.application.yml 配置
            • 2.实体类添加注解
    • 2.接口开发及测试
        • 1.com/sun/usercenter/controller/UserController.java 注册和登录接口
        • 2.封装登录和注册请求信息的对象
          • 1.文件目录
          • 2.com/sun/usercenter/model/request/UserLoginRequest.java 用户登录请求体
          • 3.com/sun/usercenter/model/request/UserRegisterRequest.java 用户注册请求体
        • 3.单元测试
          • 1.用户注册接口测试
            • 1.debug模式启动IDEA
            • 2.postman测试
          • 2.用户登录接口测试
            • 1.com/sun/usercenter/service/impl/UserServiceImpl.java的doLogin最后下断点
            • 2.postman测试
            • 3.查看session是否有用户登录状态的信息
            • 4.放行,查看postman的返回结果
          • 3.逻辑删除测试
            • 1.在数据库中把刚才进行登录的用户id改成1
            • 2.重新登录一下
    • 3.用户管理接口
        • 1.com/sun/usercenter/controller/UserController.java 添加方法
        • 2.user表新增字段role表示用户权限
          • 1.新增字段role
          • 2.com/sun/usercenter/model/domain/User.java 实体类新增权限字段
          • 3.Mapper.xml不用修改,因为这个字段本来就与表的字段对应
          • 4.com/sun/usercenter/service/impl/UserServiceImpl.java 用户脱敏里面把role字段加进去
        • 3.com/sun/usercenter/contant/UserConstant.java 存放用户常量的接口
        • 4.com/sun/usercenter/controller/UserController.java 对两个接口进行权限验证
          • 1.添加方法 isAdmin 判断是否为管理员
          • 2.修改两个接口的方法
        • 5.application.yml 设置session超时时间
        • 6.单元测试
          • 1.测试 searchUsers接口
            • 1.登录
            • 2.表中增加两条测试记录
            • 3.进行查询,成功查询!
          • 2.测试deleteUser接口
            • 1.删除id为1的用户
            • 2.查看数据库,成功进行逻辑删除
          • 3.解决 searchUsers接口返回的用户信息没有脱敏的问题
            • 1.com/sun/usercenter/service/UserService.java 添加方法
            • 2.com/sun/usercenter/service/impl/UserServiceImpl.java 实现方法并修改逻辑
            • 3.com/sun/usercenter/controller/UserController.java 修改searchUsers方法对查询到的用户列表进行脱敏
            • 4.再次测试,敏感信息变成null了

1.登录功能-后端

1.思路分析

image-20240321111353462

2.完成对用户名和密码的校验
1.com/sun/usercenter/service/UserService.java 添加方法
    public Long userRegister(String userAccount, String userPassword, String checkPassword);/*** 用户登录接口* @param userAccount 账号* @param userPassword 密码* @return 成功返回脱敏后的User对象,失败返回null*/public User doLogin(String userAccount, String userPassword);
2.com/sun/usercenter/service/impl/UserServiceImpl.java 添加方法
    @Overridepublic User doLogin(String userAccount, String userPassword) {// 1 检验用户名和密码是否合法,如果不合法就没必要去数据库查询// 验证非空if (StringUtils.isAnyBlank(userAccount, userPassword)) {return null;}// 账户4到16位,不能包含特殊字符if (!userAccount.matches("^[a-zA-Z0-9]{4,16}$")) {return null;}// 密码不小于8位if (userPassword.length() < 8) {return null;}// 2 密码加密进行查询String encryptPassword = DigestUtils.md5DigestAsHex((SALT + userPassword).getBytes());// 编写查询条件QueryWrapper<User> userQueryWrapper = new QueryWrapper<>();userQueryWrapper.eq("userPassword", encryptPassword);userQueryWrapper.eq("userAccount", userAccount);// 执行查询User user = userMapper.selectOne(userQueryWrapper);// 判断用户是否存在if (user == null) {// 输出日志log.info("user login faild, userAccount can not match password");return null;}// 3 记录用户的登录态return user;}
3.com/sun/usercenter/service/impl/UserServiceImpl.java 新增属性

image-20240321114714756

3.记录用户的登录态并配置MyBatisPlus的逻辑删除
1.com/sun/usercenter/service/UserService.java 修改doLogin,增加参数 request
    /*** 用户登录接口* @param userAccount 账号* @param userPassword 密码* @return 成功返回脱敏后的User对象,失败返回null*/public User doLogin(String userAccount, String userPassword, HttpServletRequest request);
2.com/sun/usercenter/service/impl/UserServiceImpl.java 新增属性

image-20240321125443877

3.com/sun/usercenter/service/impl/UserServiceImpl.java 添加代码
doLogin 方法添加代码,记录用户登录态
        // 3 如果登录成功,记录用户的登录态// 首先进行脱敏User cleanUser = new User();cleanUser.setId(user.getId());cleanUser.setUsername(user.getUsername());cleanUser.setUserAccount(user.getUserAccount());cleanUser.setAvatarUrl(user.getAvatarUrl());cleanUser.setGender(user.getGender());cleanUser.setPhone(user.getPhone());cleanUser.setEmail(user.getEmail());cleanUser.setUserStatus(user.getUserStatus());cleanUser.setCreateTime(user.getCreateTime());HttpSession session = request.getSession();// 然后将脱敏后的用户信息放入session中session.setAttribute(USER_LOGIN_SAVE, cleanUser);return cleanUser;
4.配置MyBatisPlus的逻辑删除
1.application.yml 配置
global-config:db-config:logic-delete-field: isDelete # 全局逻辑删除的实体字段名(since 3.3.0,配置后可以忽略不配置步骤2)logic-delete-value: 1 # 逻辑已删除值(默认为 1)logic-not-delete-value: 0 # 逻辑未删除值(默认为 0)

2.实体类添加注解

image-20240321125851499

2.接口开发及测试

1.com/sun/usercenter/controller/UserController.java 注册和登录接口
package com.sun.usercenter.controller;import com.sun.usercenter.model.domain.User;
import com.sun.usercenter.model.request.UserLoginRequest;
import com.sun.usercenter.model.request.UserRegisterRequest;
import com.sun.usercenter.service.UserService;
import org.apache.commons.lang3.StringUtils;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;/*** Description:** @Author sun* @Create 2024/3/21 13:04* @Version 1.0*/
@RestController // 作为一个Controller注入容器,并将返回结果转换为json
@RequestMapping("/user") // restful风格的请求
public class UserController {@Resourceprivate UserService userService; // 注入针对Service接口的bean对象,可以调用接口的方法@PostMapping("/register")public Long userRegister(@RequestBody UserRegisterRequest userRegisterRequest) {// 首先判断数据是否成功封装if (userRegisterRequest == null) {return null;}// 对封装的数据进行校验,如果有一个是空直接返回nullString userAccount = userRegisterRequest.getUserAccount();String userPassword = userRegisterRequest.getUserPassword();String checkPassword = userRegisterRequest.getCheckPassword();if (StringUtils.isAnyBlank(userAccount, userPassword, checkPassword)) {return null;}// 调用Service层的注册方法,如果成功注册,则返回注册成功的用户id, 否则返回-1return userService.userRegister(userAccount, userPassword, checkPassword);}@PostMapping("/login")public User userRegister(@RequestBody UserLoginRequest userLoginRequest, HttpServletRequest request) {// 首先判断数据是否成功封装if (userLoginRequest == null) {return null;}// 对封装的数据进行校验,如果有一个是空直接返回nullString userAccount = userLoginRequest.getUserAccount();String userPassword = userLoginRequest.getUserPassword();if (StringUtils.isAnyBlank(userAccount, userPassword)) {return null;}return userService.doLogin(userAccount, userPassword, request);}}
2.封装登录和注册请求信息的对象
1.文件目录

image-20240321140744768

2.com/sun/usercenter/model/request/UserLoginRequest.java 用户登录请求体
package com.sun.usercenter.model.request;import lombok.Data;/*** Description: 用户登录请求体** @Author sun* @Create 2024/3/21 13:39* @Version 1.0*/
@Data
public class UserLoginRequest {private String userAccount;private String userPassword;
}
3.com/sun/usercenter/model/request/UserRegisterRequest.java 用户注册请求体
package com.sun.usercenter.model.request;import lombok.Data;/*** Description: 用户注册请求体** @Author sun* @Create 2024/3/21 13:26* @Version 1.0*/
@Data
public class UserRegisterRequest {private String userAccount;private String userPassword;private String checkPassword;
}
3.单元测试
1.用户注册接口测试
1.debug模式启动IDEA
2.postman测试

image-20240321141238471

2.用户登录接口测试
1.com/sun/usercenter/service/impl/UserServiceImpl.java的doLogin最后下断点

image-20240321141351808

2.postman测试

image-20240321141426988

3.查看session是否有用户登录状态的信息

image-20240321141538940

4.放行,查看postman的返回结果

image-20240321141640952

3.逻辑删除测试
1.在数据库中把刚才进行登录的用户id改成1

image-20240321142052891

2.重新登录一下

image-20240321142150628

3.用户管理接口

1.com/sun/usercenter/controller/UserController.java 添加方法
    /*** 根据用户名进行模糊查询** @param username* @return 成功返回信息,失败返回null*/@GetMapping("/search")public List<User> searchUsers(String username) {QueryWrapper<User> userQueryWrapper = new QueryWrapper<>();if (StringUtils.isNotBlank(username)) {userQueryWrapper.like("username", username);}return userService.list(userQueryWrapper);}/*** 根据id进行逻辑删除(只要配置了MyBatisPlus的逻辑删除即可进行自动逻辑删除)** @param id* @return 成功返回true,失败返回false*/@PostMapping("/delete")public boolean deleteUser(@RequestBody Long id) {if (id <= 0) {return false;}return userService.removeById(id); // 这里会自动逻辑删除}
2.user表新增字段role表示用户权限
1.新增字段role

image-20240321145517358

2.com/sun/usercenter/model/domain/User.java 实体类新增权限字段

image-20240321151111785

3.Mapper.xml不用修改,因为这个字段本来就与表的字段对应
4.com/sun/usercenter/service/impl/UserServiceImpl.java 用户脱敏里面把role字段加进去

image-20240321152845893

3.com/sun/usercenter/contant/UserConstant.java 存放用户常量的接口
package com.sun.usercenter.contant;/*** Description: 用户常量** @Author sun* @Create 2024/3/21 15:14* @Version 1.0*/
public interface UserConstant {/*用户登录状态*/String USER_LOGIN_SAVE = "userLoginState";// 用户权限/*默认权限*/Integer DEFAULT_ROLE = 0;/*管理员权限*/Integer ADMIN_ROLE = 1;
}
4.com/sun/usercenter/controller/UserController.java 对两个接口进行权限验证
1.添加方法 isAdmin 判断是否为管理员
    /*** 判断是否是管理员* @param request* @return 布尔*/public boolean isAdmin(HttpServletRequest request) {User user = (User) request.getSession().getAttribute(USER_LOGIN_SAVE);return user != null && user.getRole() == ADMIN_ROLE;}
2.修改两个接口的方法
    /*** 根据用户名进行模糊查询** @param username* @return 成功返回信息,失败返回null*/@GetMapping("/search")public List<User> searchUsers(String username, HttpServletRequest request) {// 仅管理员可查询if (!isAdmin(request)) {return new ArrayList<>();}QueryWrapper<User> userQueryWrapper = new QueryWrapper<>();if (StringUtils.isNotBlank(username)) {userQueryWrapper.like("username", username);}return userService.list(userQueryWrapper);}/*** 根据id进行逻辑删除(只要配置了MyBatisPlus的逻辑删除即可进行自动逻辑删除)** @param id* @return 成功返回true,失败返回false*/@PostMapping("/delete")public boolean deleteUser(long id, HttpServletRequest request) {// 仅管理员可删除if (!isAdmin(request)) {return false;}if (id <= 0) {return false;}return userService.removeById(id); // 这里会自动逻辑删除}
5.application.yml 设置session超时时间

image-20240321162627353

6.单元测试
1.测试 searchUsers接口
1.登录

image-20240321160903366

2.表中增加两条测试记录

image-20240321161350566

3.进行查询,成功查询!

image-20240321161505507

2.测试deleteUser接口
1.删除id为1的用户

image-20240321162032694

2.查看数据库,成功进行逻辑删除

image-20240321162120945

3.解决 searchUsers接口返回的用户信息没有脱敏的问题
1.com/sun/usercenter/service/UserService.java 添加方法
    /*** 进行用户信息脱敏* @param user* @return*/User getCleanUser(User user);
2.com/sun/usercenter/service/impl/UserServiceImpl.java 实现方法并修改逻辑

image-20240321165022958

    /*** 对得到的user对象,进行用户信息脱敏* @param user* @return*/@Overridepublic User getCleanUser(User user) {User cleanUser = new User();cleanUser.setId(user.getId());cleanUser.setUsername(user.getUsername());cleanUser.setUserAccount(user.getUserAccount());cleanUser.setAvatarUrl(user.getAvatarUrl());cleanUser.setGender(user.getGender());cleanUser.setPhone(user.getPhone());cleanUser.setEmail(user.getEmail());cleanUser.setUserStatus(user.getUserStatus());cleanUser.setCreateTime(user.getCreateTime());cleanUser.setRole(user.getRole());return cleanUser;}
3.com/sun/usercenter/controller/UserController.java 修改searchUsers方法对查询到的用户列表进行脱敏
/*** 根据用户名进行模糊查询** @param username* @return 成功返回信息,失败返回null*/
@GetMapping("/search")
public List<User> searchUsers(String username, HttpServletRequest request) {// 仅管理员可查询if (!isAdmin(request)) {return new ArrayList<>();}QueryWrapper<User> userQueryWrapper = new QueryWrapper<>();if (StringUtils.isNotBlank(username)) {userQueryWrapper.like("username", username);}List<User> userList = userService.list(userQueryWrapper);// 将查询到的用户数据进行脱敏// 这里的逻辑就是把查询到User对象列表使用user来遍历然后对每个user对象进行脱敏最后组合成一个新的listreturn userList.stream().map(user -> {return userService.getCleanUser(user);}).collect(Collectors.toList());
}
4.再次测试,敏感信息变成null了

image-20240321170006198

http://www.dt0577.cn/news/25703.html

相关文章:

  • 宁波网站建设哪家好希爱力副作用太强了
  • 博物馆网站制作自己的网站怎么做seo
  • 做网站之前要先购买服务器吗深圳seo秘籍
  • 服务器做jsp网站教程视频播放免费找客源软件
  • 建湖做网站哪家最好苏州关键词排名系统
  • 怎么判断网站好坏企业培训课程ppt
  • wordpress 海 主题天津百度快照优化公司
  • 公司注册资金可以乱写吗淄博seo
  • 安防网站模板线上如何做推广
  • dede网站名称不能保存唐山百度提升优化
  • 网站如何做移动网站整站seo优化
  • 网站推广策划方案毕业设计如何开发自己的小程序
  • 网站建设武汉优化加速
  • 搜索引擎网站推广法微信管理
  • 做静态网站有什么用百度网盘app
  • 新疆事件最新情况seo专业培训班
  • 大学生免费ppt网站来几个关键词兄弟们
  • 农业网站建设费用预算推广员网站
  • 万网空间最多放几个网站如何制作网址
  • asp 企业网站源码百度推广咨询
  • 国外 设计公司手机网站代运营一个月多少钱
  • 深圳网站建设公司哪个如何获取热搜关键词
  • 企业网站推广联系方式免费网站推广方式
  • 网站页面自适应屏幕直通车怎么开
  • 怎么做网站的外部连接外链链接平台
  • 索尼电视网页浏览器seo综合查询国产
  • 二级建造师报名seo搜索是什么意思
  • 保定聊城网站建设济南seo优化公司助力网站腾飞
  • 自己做网站外包seo是啥软件
  • unix做网站常用的数据库地推接单网