五,搭建环境:辅助功能

cnblogs 2024-08-09 11:09:00 阅读 50

五,搭建环境:辅助功能

@

目录

    <li>五,搭建环境:辅助功能
  • 编写登录失败异常
  • 编写常量类
  • MD5 工具 (加密工具类)
  • 日志配置文件

编写登录失败异常

我们在 <code>demo-module04-util 模块下,创建一个名为:com.rainbowsea.imperial.court.exception的包下,创建一个名为:LoginFailedException 的异常类——> 作为登录异常的处理。

在这里插入图片描述

<code>package com.rainbowsea.imperial.court.exception;

public class LoginFailedException extends RuntimeException {

public LoginFailedException() {

}

public LoginFailedException(String message) {

super(message);

}

public LoginFailedException(String message, Throwable cause) {

super(message, cause);

}

public LoginFailedException(Throwable cause) {

super(cause);

}

public LoginFailedException(String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) {

super(message, cause, enableSuppression, writableStackTrace);

}

}

编写常量类

我们在 demo-module04-util 模块下,创建一个名为:com.rainbowsea.imperial.court.utils的包下,创建一个名为:ImperialCourtConst类——> 作为常量类,定义我们项目中所需要的一些常量信息。

在这里插入图片描述

<code>package com.rainbowsea.imperial.court.utils;

public class ImperialCourtConst {

public static final String LOGIN_FAILED_MESSAGE = "账号、密码错误,不可进宫!";

public static final String ACCESS_DENIED_MESSAGE = "宫闱禁地,不得擅入!";

public static final String LOGIN_EMP_ATTR_NAME = "loginInfo";

}

MD5 工具 (加密工具类)

我们在 demo-module04-util 模块下,创建一个名为:com.rainbowsea.imperial.court.utils的包下,创建一个名为:MD5Util类——> 作为工具类,定义我们项目中所需要的一些工具方法。

在这里插入图片描述

<code>package com.rainbowsea.imperial.court.utils;

import java.math.BigInteger;

import java.security.MessageDigest;

import java.security.NoSuchAlgorithmException;

public class MD5Util {

/**

* 针对明文字符串执行MD5加密

*

* @param source

* @return

*/

public static String encode(String source) {

// 1.判断明文字符串是否有效

if (source == null || "".equals(source)) {

throw new RuntimeException("用于加密的明文不可为空");

}

// 2.声明算法名称

String algorithm = "md5";

// 3.获取MessageDigest对象

MessageDigest messageDigest = null;

try {

messageDigest = MessageDigest.getInstance(algorithm);

} catch (NoSuchAlgorithmException e) {

e.printStackTrace();

}

// 4.获取明文字符串对应的字节数组

byte[] input = source.getBytes();

// 5.执行加密

byte[] output = messageDigest.digest(input);

// 6.创建BigInteger对象

int signum = 1;

BigInteger bigInteger = new BigInteger(signum, output);

// 7.按照16进制将bigInteger的值转换为字符串

int radix = 16;

String encoded = bigInteger.toString(radix).toUpperCase();

return encoded;

}

}

日志配置文件

在该 demo-module01-web 模块下的src/main/resources根路径下,创建一个名为logback.xml 的日志配置文件。注意:文件名就是为logback.xml不可以是其他的,必须是这个

在这里插入图片描述

<code><?xml version="1.0" encoding="UTF-8"?>code>

<configuration debug="true">code>

<!-- 指定日志输出的位置 -->

<appender name="STDOUT"code>

>

<encoder>

<!-- 日志输出的格式 -->

<!-- 按照顺序分别是:时间、日志级别、线程名称、打印日志的类、日志主体内容、换行 -->

<pattern>[%d{HH:mm:ss.SSS}] [%-5level] [%thread] [%logger] [%msg]%n</pattern>

<charset>UTF-8</charset>

</encoder>

</appender>

<!-- 设置全局日志级别。日志级别按顺序分别是:DEBUG、INFO、WARN、ERROR -->

<!-- 指定任何一个日志级别都只打印当前级别和后面级别的日志。 -->

<root level="INFO">code>

<!-- 指定打印日志的appender,这里通过“STDOUT”引用了前面配置的appender -->

<appender-ref ref="STDOUT" />code>

</root>

<!-- 专门给某一个包指定日志级别 -->

<logger name="com.atguigu" level="DEBUG" additivity="false">code>

<appender-ref ref="STDOUT" />code>

</logger>

</configuration>

    <li>

    对应顺序上一节内容:✏️✏️✏️ 四,搭建环境:表述层-CSDN博客

  • 对应顺序是下一节内容:✏️✏️✏️


上一篇: C++知识要点总结笔记

下一篇: 【C++】C++内存管理分布

本文标签

Maven   


声明

本文内容仅代表作者观点,或转载于其他网站,本站不以此文作为商业用途
如有涉及侵权,请联系本站进行删除
转载本站原创文章,请注明来源及作者。