首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >【尚筹网】二、环境搭建一

【尚筹网】二、环境搭建一

作者头像
用户11332765
发布于 2024-11-26 04:10:23
发布于 2024-11-26 04:10:23
11000
代码可运行
举报
文章被收录于专栏:编程编程
运行总次数:0
代码可运行

环境搭建总体目标

创建工程

系统架构图

工程创建计划

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
atcrowdfunding01-admin-parent
 groupId:com.atguigu.crowd
 artifactId:atcrowdfunding01-admin-parent
 packaging:pom
atcrowdfunding02-admin-webui
 groupId:com.atguigu.crowd
 artifactId:atcrowdfunding02-admin-webui
 packaging:war
atcrowdfunding03-admin-component
 groupId:com.atguigu.crowd
artifactId:atcrowdfunding03-admin-component
 packaging:jar
atcrowdfunding04-admin-entity
 groupId:com.atguigu.crowd
 artifactId:atcrowdfunding04-admin-entity
 packaging:jar
atcrowdfunding05-common-util
 groupId:com.atguigu.crowd
 artifactId:atcrowdfunding05-common-util
 packaging:jar
atcrowdfunding06-common-reverse
 groupId:com.atguigu.crowd
 artifactId:atcrowdfunding06-common-reverse
 packaging:jar

创建空项目

创建对应的 Maven 模块
建立模块间的依赖
  • webui 依赖 component
  • component 依赖 entity
  • component 依赖 util

创建数据库

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
CREATE DATABASE `project_crowd` CHARACTER SET utf8;
use project_crowd;
drop table if exists t_admin;
create table t_admin
(
    id          int          not null auto_increment, # 主键
    login_acct  varchar(255) not null,                # 登录账号
    user_pswd   char(32)     not null,                # 登录密码
    user_name   varchar(255) not null,                # 昵称
    email       varchar(255) not null,                # 邮件地址
    create_time char(19),                             # 创建时间
    primary key (id)
);

基于 Maven 的 Mybatis 的逆向过程

配置 pom

在 atcrowdfunding06-common-reverse 模块的 pom.xml 中配置

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<dependencies>
	<dependency>
		<groupId>org.mybatis</groupId>
		<artifactId>mybatis</artifactId>
		<version>3.2.8</version>
	</dependency>
</dependencies>

<build>
	<plugins>
		<plugin>
			<groupId>org.mybatis.generator</groupId>
			<artifactId>mybatis-generator-maven-plugin</artifactId>
			<version>1.3.0</version>

			<dependencies>

				<dependency>
					<groupId>org.mybatis.generator</groupId>
					<artifactId>mybatis-generator-core</artifactId>
					<version>1.3.2</version>
				</dependency>
				<dependency>
					<groupId>com.mchange</groupId>
					<artifactId>c3p0</artifactId>
					<version>0.9.2</version>
				</dependency>

				<dependency>
					<groupId>mysql</groupId>
					<artifactId>mysql-connector-java</artifactId>
					<version>8.0.33</version>
				</dependency>
			</dependencies>
		</plugin>
	</plugins>
</build>

创建 generatorConfig.xml

在 atcrowdfunding06-common-reverse 模块下的 src/main/resources 目录下创建 generatorConfig.xml,用来配置逆向工程

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE generatorConfiguration
        PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
        "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
<generatorConfiguration>
	<!--mybatis-generator:generate-->
	<context id="atguiguTables" targetRuntime="MyBatis3">
		<commentGenerator>
			<!--是否去除自动生成的注释true:;false:-->
			<property name="suppressAllComments" value="true"/>
		</commentGenerator>
		<!--数据库连接的信息:驱动类、连接地址、用户名、密码-->
		<jdbcConnection
				driverClass="com.mysql.cj.jdbc.Driver"
				connectionURL="jdbc:mysql://localhost:3306/project_crowd?serverTimezone=Asia/Shanghai"
				userId="root"
				password="123456">
		</jdbcConnection>
		<!--默认false,把JDBCDECIMALNUMERIC类型解析为Integer,为true时把 JDBC DECIMALNUMERIC类型解析为java.math.BigDecimal-->
		<javaTypeResolver>
			<property name="forceBigDecimals" value="false"/>
		</javaTypeResolver>
		<!--targetProject:生成Entity类的路径-->
		<javaModelGenerator targetProject=".\src\main\java"
		                    targetPackage="com.atguigu.crowd.entity">
			<!--enableSubPackages:是否让schema作为包的后缀-->
			<property name="enableSubPackages" value="false"/>
			<!--从数据库返回的值被清理前后的空格-->
			<property name="trimStrings" value="true"/>
		</javaModelGenerator>
		<!--targetProject:XxxMapper.xml映射文件生成的路径-->
		<sqlMapGenerator targetProject=".\src\main\java"
		                 targetPackage="com.atguigu.crowd.mapper">
			<!--enableSubPackages:是否让schema作为包的后缀-->
			<property name="enableSubPackages" value="false"/>
		</sqlMapGenerator>
		<!--targetPackage:Mapper接口生成的位置-->
		<javaClientGenerator type="XMLMAPPER"
		                     targetProject=".\src\main\java"
		                     targetPackage="com.atguigu.crowd.mapper">
			<!--enableSubPackages:是否让schema作为包的后缀-->
			<property name="enableSubPackages" value="false"/>
		</javaClientGenerator>
		<!--数据库表名字和我们的entity类对应的映射指定-->
		<table tableName="t_admin" domainObjectName="Admin"/>
	</context>
</generatorConfiguration>

执行逆向工程操作的 maven 指令

双击即可

将逆向工程生成的资源归位

创建完后给 Admin 添加无参全参构造器,然后给生成的资源归位

父工程依赖管理

版本声明

在 atcrowdfunding01-admin-parent 模块的 pom.xml 中进行版本声明

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<properties>
	<maven.compiler.source>8</maven.compiler.source>
	<maven.compiler.target>8</maven.compiler.target>
	<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
	<!--声明属性,对Spring的版本进行统一管理-->
	<atguigu.spring.version>4.3.20.RELEASE</atguigu.spring.version>
	<!--声明属性,对SpringSecurity的版本进行统一管理-->
	<atguigu.spring.security.version>4.2.10.RELEASE</atguigu.spring.security.version>
</properties>

依赖管理

在 atcrowdfunding01-admin-parent 中进行版本声明后,还需要引入依赖

遇到的问题:若依赖基本全部爆红(没下载 jar 包),可以将 dependencyManagement 删去后再重新加载,等下载完 jar 包后再加回去

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<dependencyManagement>
	<dependencies>
		<!-- Spring 依赖 -->
		<!-- https://mvnrepository.com/artifact/org.springframework/spring-orm -->
		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-orm</artifactId>
			<version>${atguigu.spring.version}</version>
		</dependency>
		<!-- https://mvnrepository.com/artifact/org.springframework/spring-webmvc -->
		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-webmvc</artifactId>
			<version>${atguigu.spring.version}</version>
		</dependency>
		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-test</artifactId>
			<version>${atguigu.spring.version}</version>
		</dependency>
		<!-- https://mvnrepository.com/artifact/org.aspectj/aspectjweaver -->
		<dependency>
			<groupId>org.aspectj</groupId>
			<artifactId>aspectjweaver</artifactId>
			<version>1.9.2</version>
		</dependency>
		<!-- https://mvnrepository.com/artifact/cglib/cglib -->
		<dependency>
			<groupId>cglib</groupId>
			<artifactId>cglib</artifactId>
			<version>2.2</version>
		</dependency>
		<!-- 数据库依赖 -->
		<!-- MySQL 驱动 -->
		<dependency>
			<groupId>mysql</groupId>
			<artifactId>mysql-connector-java</artifactId>
			<version>5.1.3</version>
		</dependency>
		<!-- 数据源 -->
		<dependency>
			<groupId>com.alibaba</groupId>
			<artifactId>druid</artifactId>
			<version>1.0.31</version>
		</dependency>
		<!-- MyBatis -->
		<dependency>
			<groupId>org.mybatis</groupId>
			<artifactId>mybatis</artifactId>
			<version>3.2.8</version>
		</dependency>
		<!-- MyBatis 与 Spring 整合 -->
		<dependency>
			<groupId>org.mybatis</groupId>
			<artifactId>mybatis-spring</artifactId>
			<version>1.2.2</version>
		</dependency>
		<!-- MyBatis 分页插件 -->
		<dependency>
			<groupId>com.github.pagehelper</groupId>
			<artifactId>pagehelper</artifactId>
			<version>4.0.0</version>
		</dependency>
		<!-- 日志 -->
		<dependency>
			<groupId>org.slf4j</groupId>
			<artifactId>slf4j-api</artifactId>
			<version>1.7.7</version>
		</dependency>
		<dependency>
			<groupId>ch.qos.logback</groupId>
			<artifactId>logback-classic</artifactId>
			<version>1.2.3</version>
		</dependency>
		<!-- 其他日志框架的中间转换包 -->
		<dependency>
			<groupId>org.slf4j</groupId>
			<artifactId>jcl-over-slf4j</artifactId>
			<version>1.7.25</version>
		</dependency>
		<dependency>
			<groupId>org.slf4j</groupId>
			<artifactId>jul-to-slf4j</artifactId>
			<version>1.7.25</version>
		</dependency>
		<!-- Spring 进行 JSON 数据转换依赖 -->
		<dependency>
			<groupId>com.fasterxml.jackson.core</groupId>
			<artifactId>jackson-core</artifactId>
			<version>2.9.8</version>
		</dependency>
		<dependency>
			<groupId>com.fasterxml.jackson.core</groupId>
			<artifactId>jackson-databind</artifactId>
			<version>2.9.8</version>
		</dependency>
		<dependency>
			<groupId>com.fasterxml.jackson.core</groupId>
			<artifactId>jackson-annotations</artifactId>
			<version>2.9.8</version>
		</dependency>
		<!-- JSTL 标签库 -->
		<dependency>
			<groupId>jstl</groupId>
			<artifactId>jstl</artifactId>
			<version>1.2</version>
		</dependency>
		<!-- junit 测试 -->
		<dependency>
			<groupId>junit</groupId>
			<artifactId>junit</artifactId>
			<version>4.12</version>
			<scope>test</scope>
		</dependency>
		<!-- 引入 Servlet 容器中相关依赖 -->
		<dependency>
			<groupId>javax.servlet</groupId>
			<artifactId>servlet-api</artifactId>
			<version>2.5</version>
			<scope>provided</scope>
		</dependency>
		<!-- JSP 页面使用的依赖 -->
		<dependency>
			<groupId>javax.servlet.jsp</groupId>
			<artifactId>jsp-api</artifactId>
			<version>2.1.3-b06</version>
			<scope>provided</scope>
		</dependency>
		<!-- https://mvnrepository.com/artifact/com.google.code.gson/gson -->
		<dependency>
			<groupId>com.google.code.gson</groupId>
			<artifactId>gson</artifactId>
			<version>2.8.5</version>
		</dependency>
		<!-- SpringSecurity 对 Web 应用进行权限管理 -->
		<dependency>
			<groupId>org.springframework.security</groupId>
			<artifactId>spring-security-web</artifactId>
			<version>4.2.10.RELEASE</version>
		</dependency>
		<!-- SpringSecurity 配置 -->
		<dependency>
			<groupId>org.springframework.security</groupId>
			<artifactId>spring-security-config</artifactId>
			<version>4.2.10.RELEASE</version>
		</dependency>
		<!-- SpringSecurity 标签库 -->
		<dependency>
			<groupId>org.springframework.security</groupId>
			<artifactId>spring-security-taglibs</artifactId>
			<version>4.2.10.RELEASE</version>
		</dependency>
	</dependencies>
</dependencyManagement>

Spring 整合 MyBatis

思路

具体操作

在子工程中加入搭建环境的所需的具体依赖

在 atcrowdfunding03-admin-component 模块添加依赖

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<!-- Spring依赖 -->
<!-- https://mvnrepository.com/artifact/org.springframework/spring-orm -->
<dependency>
	<groupId>org.springframework</groupId>
	<artifactId>spring-orm</artifactId>
	<exclusions>
		<exclusion>
			<groupId>commons-logging</groupId>
			<artifactId>commons-logging</artifactId>
		</exclusion>
	</exclusions>
</dependency>
<!-- https://mvnrepository.com/artifact/org.springframework/spring-webmvc -->
<dependency>
	<groupId>org.springframework</groupId>
	<artifactId>spring-webmvc</artifactId>
</dependency>
<!-- https://mvnrepository.com/artifact/org.aspectj/aspectjweaver -->
<dependency>
	<groupId>org.aspectj</groupId>
	<artifactId>aspectjweaver</artifactId>
</dependency>
<!-- https://mvnrepository.com/artifact/cglib/cglib -->
<dependency>
	<groupId>cglib</groupId>
	<artifactId>cglib</artifactId>
</dependency>

<!-- 数据库依赖 -->
<!-- MySQL驱动 -->
<dependency>
	<groupId>mysql</groupId>
	<artifactId>mysql-connector-java</artifactId>
</dependency>

<!-- 数据源 -->
<dependency>
	<groupId>com.alibaba</groupId>
	<artifactId>druid</artifactId>
</dependency>

<!-- MyBatis -->
<dependency>
	<groupId>org.mybatis</groupId>
	<artifactId>mybatis</artifactId>
</dependency>

<!-- MyBatis与Spring整合 -->
<dependency>
	<groupId>org.mybatis</groupId>
	<artifactId>mybatis-spring</artifactId>
</dependency>

<!-- MyBatis分页插件 -->
<dependency>
	<groupId>com.github.pagehelper</groupId>
	<artifactId>pagehelper</artifactId>
</dependency>

<!-- 日志 -->
<dependency>
	<groupId>org.slf4j</groupId>
	<artifactId>slf4j-api</artifactId>
</dependency>
<dependency>
	<groupId>ch.qos.logback</groupId>
	<artifactId>logback-classic</artifactId>
</dependency>

<!-- 其他日志框架的中间转换包 -->
<dependency>
	<groupId>org.slf4j</groupId>
	<artifactId>jcl-over-slf4j</artifactId>
</dependency>

<!-- Spring进行JSON数据转换依赖 -->
<dependency>
	<groupId>com.fasterxml.jackson.core</groupId>
	<artifactId>jackson-core</artifactId>
</dependency>
<dependency>
	<groupId>com.fasterxml.jackson.core</groupId>
	<artifactId>jackson-databind</artifactId>
</dependency>
<dependency>
	<groupId>com.fasterxml.jackson.core</groupId>
	<artifactId>jackson-annotations</artifactId>
</dependency>

<!-- JSTL标签库 -->
<dependency>
	<groupId>jstl</groupId>
	<artifactId>jstl</artifactId>
</dependency>

<!-- 引入Servlet容器中相关依赖 -->
<dependency>
	<groupId>javax.servlet</groupId>
	<artifactId>servlet-api</artifactId>
	<scope>provided</scope>
</dependency>

<!-- https://mvnrepository.com/artifact/com.google.code.gson/gson -->
<dependency>
	<groupId>com.google.code.gson</groupId>
	<artifactId>gson</artifactId>
</dependency>
创建 jdbc.properties
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
jdbc.user=root
jdbc.password=123456
jdbc.url=jdbc:mysql://localhost:3306/project_crowd?useSSL=false&serverTimezone=UTC&useUnicode=true&characterEncoding=UTF-8
jdbc.driver=com.mysql.cj.jdbc.Driver
创建 mybatis-config.xml
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
		PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
		"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
</configuration>
创建 spring-persist-mybatis.xml
Spring 配置第一步 配置数据源
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
       http://www.springframework.org/schema/beans/spring-beans.xsd
       http://www.springframework.org/schema/context
       http://www.springframework.org/schema/context/spring-context.xsd">
	<!-- 加载外部属性文件 -->
	<context:property-placeholder location="classpath:jdbc.properties" />

	<!-- 配置数据源 -->
	<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
		<property name="driverClassName" value="${jdbc.driver}" />
		<property name="url" value="${jdbc.url}" />
		<property name="username" value="${jdbc.user}" />
		<property name="password" value="${jdbc.password}" />
	</bean>
</beans>
测试能否连接数据库

若控制台输出 connection,则连接成功

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
package com.atguigu.crowd.test;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

import java.sql.Connection;
import java.sql.SQLException;

/**
 * Copyright (C) 2024 - 2024 Jasonakeke, Inc. All Rights Reserved
 *
 * @Desc :
 * @Time : 2024/11/17 17:13
 * @Author : Code_By_Jasonakeke
 * @Email : 2284037977@qq.com
 * @Class : CrowdTest
 * @IDE : IntelliJ IDEA
 */
// 在类上标记必要的注解
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = {"classpath:spring-persist-mybatis.xml"})
public class CrowdTest {

	@Autowired
	private DataSource dataSource;

	@Test
	public void test() throws SQLException {
		Connection connection = dataSource.getConnection();
		System.out.println(connection);
	}
}
Spring 配置第二步 配置 SqlSessionFactoryBean 及 MapperScannerConfigurer
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<!-- 配置 SqlSessionFactoryBean 整合 MyBatis -->
<bean id="sqlSessionFactoryBean" class="org.mybatis.spring.SqlSessionFactoryBean" >
	<!-- 指定 MyBatis 全局配置文件位置 -->
	<property name="configLocation" value="classpath:mybatis/mybatis-config.xml" />
	<!-- 指定 Mapper.xml 配置文件位置 -->
	<property name="mapperLocations" value="classpath:mybatis/mapper/*Mapper.xml" />
	<!-- 配置数据源  -->
	<property name="dataSource" ref="dataSource" />
</bean>

<!-- 配置 MapperScannerConfigurer 来扫描 Mapper 接口所在的包 -->
<bean id="mapperScannerConfigurer" class="org.mybatis.spring.mapper.MapperScannerConfigurer">
	<property name="basePackage" value="com.atguigu.crowd.mapper" />
</bean>
测试能否插入数据
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
package com.atguigu.crowd.test;

import com.atguigu.crowd.entity.Admin;
import com.atguigu.crowd.mapper.AdminMapper;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;


/**
 * Copyright (C) 2024 - 2024 Jasonakeke, Inc. All Rights Reserved
 *
 * @Desc :
 * @Time : 2024/11/17 17:13
 * @Author : Code_By_Jasonakeke
 * @Email : 2284037977@qq.com
 * @Class : CrowdTest
 * @IDE : IntelliJ IDEA
 */
// 在类上标记必要的注解
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = {"classpath:spring-persist-mybatis.xml", "classpath:spring-persist-tx.xml"})
public class CrowdTest {

	@Autowired
	private AdminMapper adminMapper;

	@Test
	public void testInsertAdmin() {
		Admin admin = new Admin(null, "tom", "123456", "汤姆", "tom@atguigu.com", null);
		int count = adminMapper.insert(admin);
		System.out.println("受影响行数:" + count);
	}
}

日志系统

意义

项目日志系统在现代项目管理中扮演着至关重要的角色。它不仅是记录项目进展、问题和解决方案的工具,还是团队协作、决策支持和项目回顾的重要基础。

  1. 记录项目进展
    • 项目日志系统能够实时、详细地记录项目的各个阶段和任务的完成情况。
    • 这有助于团队成员和项目经理了解项目的当前状态,确保所有工作都在预定的时间表和预算内进行。
  2. 跟踪问题和风险
    • 通过日志系统,团队成员可以记录在项目执行过程中遇到的各种问题和风险。
    • 这些问题和风险可以被分类、优先级排序,并关联到具体的任务或阶段,以便进行后续跟踪和解决。
  3. 促进团队协作
    • 项目日志系统通常具有协作功能,如评论、点赞和分享等,这有助于增强团队成员之间的沟通和协作。
    • 团队成员可以实时查看彼此的日志,了解各自的工作进展和遇到的问题,从而更加紧密地合作。
  4. 提供决策支持
    • 项目经理和决策层可以通过日志系统获取项目的全面信息,包括进度、成本、质量和风险等方面。
    • 这些信息为决策提供了有力的数据支持,有助于项目经理做出更加明智的决策。
  5. 便于项目回顾和总结
    • 在项目结束后,项目日志系统可以作为项目回顾和总结的重要参考。
    • 通过查看日志,团队成员可以了解项目的成功经验和不足之处,为未来的项目提供宝贵的经验和教训。
  6. 提高项目透明度
    • 项目日志系统增加了项目的透明度,使得所有相关方都能够清晰地了解项目的进展和状态。
    • 这有助于建立信任,减少误解和冲突,提高项目的整体效率和质量。
  7. 支持持续改进
    • 通过分析项目日志中的数据,团队可以识别出项目中的瓶颈、低效环节和潜在改进点。
    • 这些信息为项目的持续改进提供了有力的支持,有助于团队不断优化项目管理流程和方法。

综上所述,项目日志系统在项目管理中具有不可替代的作用。它不仅能够提高项目的执行效率和质量,还能够促进团队协作和决策支持,为项目的成功提供有力的保障。因此,在项目管理中,建立和维护一个有效的项目日志系统是非常重要的。

具体操作

加入 slf4j + logback

将 atcrowdfunding03-admin-component 模块中之前日志相关的依赖全部删去,然后加入 slf4j+logback 依赖

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<dependency>
	<groupId>org.slf4j</groupId>
	<artifactId>slf4j-api</artifactId>
</dependency>
<dependency>
	<groupId>ch.qos.logback</groupId>
	<artifactId>logback-classic</artifactId>
</dependency>
主动打印日志的方法
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@Test
public void testLog(){
	// 1.获取 Logger 对象
	Logger logger = LoggerFactory.getLogger(CrowdTest.class);

	// 2.根据不同日志级别,打印不同级别的日志
	logger.debug("这是 DEBUG 级别的日志");
	logger.info("这是 INFO 级别的日志");
	logger.warn("这是 WARN 级别的日志");
	logger.error("这是 ERROR 级别的日志");
}
更换框架的日志系统
  1. 排除 commons-logging
  2. 加入转换包(atcrowdfunding03-admin-component 模块)
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<dependency>
	<groupId>org.slf4j</groupId>
	<artifactId>jcl-over-slf4j</artifactId>
</dependency>
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2024-11-22,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
ES6笔记(7)-- Promise异步编程
Promise是一种异步编程的解决方案,本质来说其实它是一种规范,Promises/A+规范
书童小二
2018/09/03
6920
ES6笔记(7)-- Promise异步编程
如何写出一个惊艳面试官的 Promise【近 1W字】 前言源码1.Promise2.Generator3.async 和 await4.Pro
1.高级 WEB 面试会让你手写一个Promise,Generator 的 PolyFill(一段代码); 2.在写之前我们简单回顾下他们的作用; 3.手写模块见PolyFill.
火狼1
2020/05/09
7520
如何写出一个惊艳面试官的 Promise【近 1W字】
                            前言源码1.Promise2.Generator3.async 和 await4.Pro
手写Promise完整介绍
Promise是一种用于处理异步操作的机制,它可以将异步操作的结果以同步的方式进行处理和返回。在JavaScript中,Promise是一种内置对象,但我们也可以手动实现一个Promise类来更好地理解其原理和工作方式。
can4hou6joeng4
2023/11/16
5360
前端二面手写面试题总结
then 方法返回一个新的 promise 实例,为了在 promise 状态发生变化时(resolve / reject 被调用时)再执行 then 里的函数,我们使用一个 callbacks 数组先把传给then的函数暂存起来,等状态改变时再调用。
helloworld1024
2022/10/27
8760
京东前端高频面试题合集
现代计算机中数据都是以二进制的形式存储的,即0、1两种状态,计算机对二进制数据进行的运算加减乘除等都是叫位运算,即将符号位共同参与运算的运算。
yyzzabc123
2022/09/13
5610
从零开始写一个符合Promises/A+规范的promise
Promise 是异步编程的一种解决方案,比传统的解决方案回调函数和事件更合理更强大。它由社区最早提出和实现,ES6 将其写进了语言标准,统一了用法,原生提供了Promise对象。本篇不注重讲解promise的用法,关于用法,可以看阮一峰老师的ECMAScript 6系列里面的Promise部分:
Nealyang
2019/09/29
1.6K0
从零开始写一个符合Promises/A+规范的promise
看了就会,手写Promise原理,最通俗易懂的版本!!!
大家好,我是林三心,相信大家在日常开发中都用过Promise,我一直有个梦想,就是以最通俗的话,讲最复杂的知识,所以我把通俗易懂放在了首位,今天就带大家手写实现以下Promise吧,相信大家一看就懂。
用户6256742
2024/05/17
8420
看了就会,手写Promise原理,最通俗易懂的版本!!!
从零开始实现一个Promise
众所周知,Promise是ES6引入的新特性,旨在解决回调地狱。下面是一个简单的例子:控制接口调用顺序:
helloworld1024
2022/10/14
2000
社招前端经典手写面试题合集
使用时间戳的节流函数会在第一次触发事件时立即执行,以后每过 wait 秒之后才执行一次,并且最后一次触发事件不会被执行
helloworld1024
2022/10/19
8060
【吐血整理】前端JavaScript高频手写面试大全,助你查漏补缺
https://segmentfault.com/a/1190000038910420
@超人
2021/02/26
9070
【吐血整理】前端JavaScript高频手写面试大全,助你查漏补缺
异步发展流程-手摸手带你实现一个Promise
首先介绍一下高阶函数,即一个函数的参数是函数或者函数返回值为函数,此函数称做高阶函数。
Careteen
2022/02/14
1K0
JavaScript异步编程
#前言 从我们一开始学习JavaScript的时候就听到过一段话:JS是单线程的,天生异步,适合IO密集型,不适合CPU密集型。但是,多数JavaScript开发者从来没有认真思考过自己程序中的异步到底是怎么出现的,以及为什么会出现,也没有探索过处理异步的其他方法。到目前为止,还有很多人坚持认为回调函数就完全够用了。
leocoder
2018/10/31
1.2K0
20道前端高频面试题(附答案)_2023-02-27
最简单的Promise实现有7个主要属性, state(状态), value(成功返回值), reason(错误信息), resolve方法, reject方法, then方法
gogo2027
2023/02/27
9890
一杯喜茶的时间手搓Promise
我们都知道,JS是单线程的,只有前一个任务结束,才能执行下一个任务。显然在浏览器上,这样执行会堵塞浏览器对DOM的渲染。所以,JS中会有很多异步操作,那JS是如何实现异步操作呢?这就要想到「Promise对象」了,文本先来认识Promise,再手写代码实现Promise。
JowayYoung
2020/04/01
8280
前端异步代码解决方案实践(二)
早前有针对 Promise 的语法写过博文,不过仅限入门级别,浅尝辄止食而无味。后面一直想写 Promise 实现,碍于理解程度有限,多次下笔未能满意。一拖再拖,时至今日。
前朝楚水
2018/07/26
3.4K0
JavaScript的异步编程之Promise
一种更优的异步编程统一 方法,如果直接使用传统的回调函数去完成复杂操作就会形成回调深渊
开水泡饭
2022/12/26
7380
JavaScript的异步编程之Promise
手写系列-这一次,彻底搞懂 Promise
想要实现 Promise,必须先了解 Promise 是什么,以及 Promise 有哪些功能。
游魂
2023/10/17
4410
手写系列-这一次,彻底搞懂 Promise
JavaScript异步编程
平时开发经常会用到js异步编程,由于前端展示页面都是基于网络机顶盒(IPTV的一般性能不太好,OTT较好),目前公司主要采取的异步编程的方式有setTimeout、setInterval、requestAnimationFrame、ajax,为什么会用到异步呢,就拿业务来说,若前端全部采取同步的方式,那加载图片、生成dom、网络数据请求都会大大增加页面渲染时长。
Jack Chen
2018/09/14
9640
JavaScript异步编程
原生JS灵魂之问(下), 冲刺进阶最后一公里(附个人成长经验分享)
笔者最近在对原生JS的知识做系统梳理,因为我觉得JS作为前端工程师的根本技术,学再多遍都不为过。打算来做一个系列,一共分三次发,以一系列的问题为驱动,当然也会有追问和扩展,内容系统且完整,对初中级选手会有很好的提升,高级选手也会得到复习和巩固。这是本系列的第三篇。
用户4131414
2020/03/19
2.1K0
Javascript之我也来手写一下Promise
  Promise太重要了,可以说是改变了JavaScript开发体验重要内容之一。而Promise也可以说是现代Javascript中极为重要的核心概念,所以理解Promise/A+规范,理解Promise的实现,手写Promise就显得格外重要。如果要聊Promise就要从回调函数聊到回调地狱,再聊到同步异步,最终聊到Promise、async await。但是我们这篇文章,目的是手写Promise,这些前置知识如果大家不了解的话,希望可以去补充一下。那你可能会说了,我他妈不懂你在说啥,我就是想手写Promise,不行么?大佬~~那肯定是没问题的。好了,废话不多说,咱们开始吧。
zaking
2022/09/09
8820
推荐阅读
相关推荐
ES6笔记(7)-- Promise异步编程
更多 >
LV.3
这个人很懒,什么都没有留下~
目录
  • 环境搭建总体目标
  • 创建工程
    • 系统架构图
    • 工程创建计划
    • 创建空项目
      • 创建对应的 Maven 模块
      • 建立模块间的依赖
  • 创建数据库
  • 基于 Maven 的 Mybatis 的逆向过程
    • 配置 pom
    • 创建 generatorConfig.xml
    • 执行逆向工程操作的 maven 指令
    • 将逆向工程生成的资源归位
  • 父工程依赖管理
  • 版本声明
  • 依赖管理
  • Spring 整合 MyBatis
    • 思路
    • 具体操作
      • 在子工程中加入搭建环境的所需的具体依赖
      • 创建 jdbc.properties
      • 创建 mybatis-config.xml
      • 创建 spring-persist-mybatis.xml
      • Spring 配置第一步 配置数据源
      • 测试能否连接数据库
      • Spring 配置第二步 配置 SqlSessionFactoryBean 及 MapperScannerConfigurer
      • 测试能否插入数据
  • 日志系统
    • 意义
    • 具体操作
      • 加入 slf4j + logback
      • 主动打印日志的方法
      • 更换框架的日志系统
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档