用户账号密码登录

实体类

public class User extends UserLoginRo implements Serializable {

    private static final long serialVersionUID = 1L;

    @ApiModelProperty(value = "uuid")
    @TableId("pk_id")
    private String pkId;

    @ApiModelProperty(value = "用户名")
    @TableField("user_name")
    private String userName;

    @ApiModelProperty(value = "用户手机")
    @TableField("user_tel")
    private String userTel;

    @ApiModelProperty(value = "头像图片")
    @TableField("head_portrait")
    private String headPortrait;

    @ApiModelProperty(value = "密码")
    private String password;

    @ApiModelProperty(value = "昵称")
    private String nickname;

    @ApiModelProperty(value = "性别")
    private String sex;

    @ApiModelProperty(value = "生日")
    private LocalDateTime birthday;

    @ApiModelProperty(value = "地址")
    private String address;

    @ApiModelProperty(value = "签名")
    private String sign;

}

service

@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements IUserService {

    @Autowired
    private UserMapper userMapper;

    /**
     * @description 通过用户查询密码
     */
    @Override
    public UserLoginRo findByPassword(String uName){
        QueryWrapper wrapper=new QueryWrapper();
        wrapper
                .select("password")
                .eq("user_name",uName);
        UserLoginRo userLogin1=userMapper.selectOne(wrapper);
       return userLogin1;
    }

    /**
     * @description 判断用户是否存在,验证密码
     */
    @Override
    public boolean VerifyPassword(String pwd, String uName){
        if(ObjectUtils.isEmpty(findByPassword(uName))){
            return false;
        }else if (Md5Utils.code(pwd).equals(findByPassword(uName).getPassword())){
            return true;
        }else {
            return false;
        }


    }
    @Override
    public boolean VerifyPhone(String uName){
       boolean phone=uName.matches("^((13[0-9])|(14[5-9])|(15([0-3]|[5-9]))|(16[6-7])|(17[1-8])|(18[0-9])|(19[1|3])|(19[5|6])|(19[8|9]))\\d{8}$");
       return phone;
    }

工具类 

public class Md5Utils {
    /**
     * @description md5加密
     */
    public static String code(String str) {
        try {
            MessageDigest md = MessageDigest.getInstance("MD5");
            md.update(str.getBytes());
            byte[] byteDigest = md.digest();
            int i;
            StringBuffer buf = new StringBuffer("");
            for (int offset = 0; offset < byteDigest.length; offset++) {
                i = byteDigest[offset];
                if (i < 0) {
                    i += 256;
                }
                if (i < 16) {
                    buf.append("0");
                }
                buf.append(Integer.toHexString(i));
            }
            //32位加密(小写)
            return buf.toString();
            //32位加密(大写)
            //return buf.toString().toUpperCase();
            // 16位的加密(小写)
            //return buf.toString().substring(8, 24);
            // 16位的加密(大写)
            //return buf.toString().substring(8, 24).toUpperCase();
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
            return null;
        }

    }

controller

  @PostMapping("/myLogin")
    @ApiOperation("用户登录")
    public Results logins(@Validated @RequestBody UserLoginRo userLoginro) {
        if (!StringUtils.hasLength(userLoginro.getUserName())) {
            return Results.fail("请输入用户名");
        } else {
            String uName = userLoginro.getUserName();
            String pwd = userLoginro.getPassword();
            if (userService.VerifyPhone(uName)) {
                if (userService.VerifyPassword(pwd, uName)) {
                    return Results.ok();
                } else {
                    return Results.fail("用户名或密码错误");
                }
            } else {
                return Results.fail("用户名错误");
            }
        }
    }

### 回答1: Java Netty是一个基于NIO的网络框架,可以用于开发高性能、高可靠性的网络应用程序。在使用Java Netty进行用户账号密码登录时,可以按照以下步骤进行: 1. 创建一个Server端和一个Client端,分别用于处理用户账号密码的验证和发送登录请求。 2. Server端:创建一个ServerBootStrap对象,设置相关的参数,如端口号、线程池大小等。接收客户端的连接请求,并使用ChannelPipeline添加处理器。 3. 在ChannelPipeline中添加一个自定义的ChannelHandler,用于处理客户端请求和用户账号密码验证。该处理器会在用户发送登录请求时,获取用户名和密码,并对其进行验证。验证通过后返回一个登录成功的响应给客户端。 4. Client端:创建一个Bootstrap对象,设置相关的参数,如服务器地址、端口号等。连接到服务器,并使用ChannelPipeline添加处理器。 5. 在ChannelPipeline中添加一个自定义的ChannelHandler,用于处理用户登录响应。该处理器会在登录响应返回后,判断是否登录成功,并进行相应的处理。 6. 用户向客户端发送登录请求,包括用户名和密码等信息。客户端将请求写入Channel并发送给服务器。 7. 服务器接收到请求后,进行用户账号密码验证。如果验证通过,则返回登录成功的响应给客户端。 8. 客户端接收到登录响应后,判断是否登录成功。如果登录成功,则继续进行后续操作;否则,进行相应的错误处理。 使用Java Netty进行用户账号密码登录需要注意网络安全问题,如加密传输、防止恶意攻击等。同时,还要注意异常处理,确保程序的稳定性。 以上是使用Java Netty进行用户账号密码登录的大致过程,具体实现会根据需求的不同而有所变化。 ### 回答2: 在使用Java Netty Socket实现用户账号密码登录时,可以按照以下步骤进行: 1. 客户端连接服务器:客户端使用Java的Socket对象连接服务器的IP地址和端口号,与服务器建立TCP连接。 2. 客户端发送登录请求:客户端向服务器发送一个登录请求,请求包含用户的账号和密码信息。可以将账号和密码按照一定的格式进行封装,并通过Socket的输出流发送给服务器。 3. 服务器接收请求并验证:服务器使用Java的ServerSocket监听指定的端口号,并接收来自客户端的连接请求。一旦连接建立,服务器使用Socket的输入流接收客户端发送的登录请求信息。 4. 服务器验证账号密码:服务器验证用户提供的账号和密码是否正确。可以在服务器端维护一个用户信息的数据库,利用数据库查询功能进行账号密码的验证。如果验证通过,服务器将返回登录成功的响应给客户端;如果验证失败,则返回登录失败的响应。 5. 客户端接收响应并处理结果:客户端使用Socket的输入流接收服务器返回的响应结果。根据响应的内容,客户端可以显示登录成功或者登录失败的提示信息。 6. 客户端与服务器断开连接:登录完成后,客户端与服务器结束通信,可以关闭Socket连接。 通过以上步骤,就可以使用Java Netty Socket实现用户账号密码登录功能。这种方式可以实现客户端和服务器之间的实时通信,并能够保护用户账号密码的安全性。同时,Netty框架的优势在于高性能、高并发的网络编程,使得用户登录过程更加快速和稳定。 ### 回答3: 使用Java Netty库实现基于Socket的用户账号密码登录可以通过以下步骤完成: 1. 服务器端: - 创建一个ServerSocket对象,监听指定的端口。 - 使用Netty的EventLoopGroup创建两个线程组,一个用于接收和处理连接,另一个用于处理I/O操作。 - 创建一个ServerBootstrap对象,并设置EventLoopGroup和Channel类型。 - 使用ServerBootstrap设置ChannelInitializer,用于配置ChannelPipeline,添加用于解码和编码的处理器。 - 在ChannelInitializer中添加自定义的ChannelHandler,用于处理登录逻辑。 - 最后,使用bind()方法绑定端口,启动服务器。 2. 客户端: - 创建一个Socket对象,指定服务器IP和端口。 - 使用Netty的EventLoopGroup创建一个线程组。 - 创建一个Bootstrap对象,并设置EventLoopGroup和Channel类型。 - 使用Bootstrap设置ChannelInitializer,用于配置ChannelPipeline,添加用于解码和编码的处理器。 - 在ChannelInitializer中添加自定义的ChannelHandler,用于发送账号密码给服务器。 - 最后,使用connect()方法连接服务器。 3. 自定义ChannelHandler: - 客户端的ChannelHandler实现ChannelOutboundHandlerAdapter,用于发送账号密码给服务器。 - 服务器的ChannelHandler实现ChannleInboundHandlerAdapter,用于接收并解析账号密码,并进行验证。 - 对于客户端和服务器都可以通过channelRead()方法接收和处理数据。 - 在channelRead()方法中,可以根据数据类型进行相应的逻辑处理,如验证账号密码是否正确。 - 如果账号密码验证成功,可以发送登录成功的反馈给客户端。 通过上述步骤的实现,即可实现基于Socket的用户账号密码登录功能。需要注意的是,此方法中传输的账号密码是明文传输的,为了增加安全性,可以使用加密算法对账号密码进行加密,然后再进行传输。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值