spring boot +mybatis+druid 多数据源配置
因为我的工程需要在两个数据库中操作数据,所以要配置两个数据库,我这里没有数据源没有什么主从之分,只是配合多数据源必须要指定一个主数据源,所以我就把
操作相对要对的那个数据库设置为主数据(dataBase1 库)源
数据源配置
###################本地应用配置#################
spring:
application:
name: test
datasource:
url:
dataBase1: jdbc:mysql://192.168.666666.66:3306/dataBase1
dataBase2: jdbc:mysql://192.168.66666.67:3306/dataBase2?useUnicode=true&characterEncoding=utf-8&allowMultiQueries=true
username:
dataBase1: dataBase1
dataBase2: dataBase2
password:
dataBase1: dataBase1
dataBase2: dataBase2
driver: com.mysql.jdbc.Driver
type: com.alibaba.druid.pool.DruidDataSource
initialSize: 5
minIdle: 5
maxActive: 20
maxWait: 10000
timeBetweenEvictionRunsMillis: 60000
minEvictableIdleTimeMillis: 300000
validationQuery: SELECT 1 FROM DUAL
testWhileIdle: true
testOnBorrow: true
testOnReturn: false
poolPreparedStatements: true
maxOpenPreparedStatementConnectionSize: 20
filters: stat,wall,log4j
connectionProperties: druid.stat.mergeSql:true;druid.stat.slowSqlMillis:5000
数据源抽象类(因为数据库的配置属性太多了,所以把通用的数据放到这个抽象类中,默认的配置也是主数据源)
package so.dian.device.common.config; import java.sql.SQLException; import javax.sql.DataSource; import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.web.servlet.FilterRegistrationBean;
import org.springframework.boot.web.servlet.ServletRegistrationBean;
import org.springframework.context.annotation.Configuration; import com.alibaba.druid.pool.DruidDataSource;
import com.alibaba.druid.support.http.StatViewServlet;
import com.alibaba.druid.support.http.WebStatFilter; @Configuration
public abstract class AbstractDBConfig { private static Logger log = LoggerFactory.getLogger(AbstractDBConfig.class); private String driver; private String url; private String username; private String password; private int maxActive; private int maxWait; private int initialSize; private int minEvictableIdleTimeMillis; private int minIdle; private String validationQuery; private boolean testWhileIdle; private boolean testOnBorrow; private boolean testOnReturn; private String connectionProperties; private String filters; private long timeBetweenEvictionRunsMillis; private boolean poolPreparedStatements; private int maxOpenPreparedStatementConnectionSize; private String mapperLocations; @Value("${maxOpenPreparedStatementConnectionSize}")
public int getMaxOpenPreparedStatementConnectionSize() {
return maxOpenPreparedStatementConnectionSize;
} public void setMaxOpenPreparedStatementConnectionSize(int maxOpenPreparedStatementConnectionSize) {
this.maxOpenPreparedStatementConnectionSize = maxOpenPreparedStatementConnectionSize;
} public String getMapperLocations() {
return mapperLocations;
} @Value("${mybatis.configuration.mapper-locations.dataBase1}")
public void setMapperLocations(String mapperLocations) {
this.mapperLocations = mapperLocations;
} public String getFilters() {
return filters;
} public String getDriver() {
return driver;
} @Value("${spring.datasource.driver}")
public void setDriver(String driver) {
this.driver = driver;
} public String getUrl() {
return url;
} @Value("${spring.datasource.url.dataBase1}")
public void setUrl(String url) {
this.url = url;
} public String getUsername() {
return username;
} @Value("${spring.datasource.username.dataBase1}")
public void setUsername(String username) {
this.username = username;
} public String getPassword() {
return password;
} @Value("${spring.datasource.password.dataBase1}")
public void setPassword(String password) {
this.password = password;
} public int getMaxActive() {
return maxActive;
} @Value("${spring.datasource.maxActive}")
public void setMaxActive(int maxActive) {
this.maxActive = maxActive;
} public int getMaxWait() {
return maxWait;
} @Value("${spring.datasource.maxWait}")
public void setMaxWait(int maxWait) {
this.maxWait = maxWait;
} public int getInitialSize() {
return initialSize;
} @Value("${spring.datasource.initialSize}")
public void setInitialSize(int initialSize) {
this.initialSize = initialSize;
} public int getMinEvictableIdleTimeMillis() {
return minEvictableIdleTimeMillis;
} @Value("${spring.datasource.minEvictableIdleTimeMillis}")
public void setMinEvictableIdleTimeMillis(int minEvictableIdleTimeMillis) {
this.minEvictableIdleTimeMillis = minEvictableIdleTimeMillis;
} public int getMinIdle() {
return minIdle;
} @Value("${spring.datasource.minIdle}")
public void setMinIdle(int minIdle) {
this.minIdle = minIdle;
} public String getValidationQuery() {
return validationQuery;
} @Value("${spring.datasource.validationQuery}")
public void setValidationQuery(String validationQuery) {
this.validationQuery = validationQuery;
} public boolean isTestWhileIdle() {
return testWhileIdle;
} @Value("${spring.datasource.testWhileIdle}")
public void setTestWhileIdle(boolean testWhileIdle) {
this.testWhileIdle = testWhileIdle;
} public boolean isTestOnBorrow() {
return testOnBorrow;
} @Value("${spring.datasource.testOnBorrow}")
public void setTestOnBorrow(boolean testOnBorrow) {
this.testOnBorrow = testOnBorrow;
} public boolean isTestOnReturn() {
return testOnReturn;
} @Value("${spring.datasource.testOnReturn}")
public void setTestOnReturn(boolean testOnReturn) {
this.testOnReturn = testOnReturn;
} public String getConnectionProperties() {
return connectionProperties;
} @Value("${spring.datasource.connectionProperties}")
public void setConnectionProperties(String connectionProperties) {
this.connectionProperties = connectionProperties;
} @Value("${spring.datasource.filters}")
public void setFilters(String filters) {
this.filters = filters;
} public long getTimeBetweenEvictionRunsMillis() {
return timeBetweenEvictionRunsMillis;
} @Value("${spring.datasource.timeBetweenEvictionRunsMillis}")
public void setTimeBetweenEvictionRunsMillis(long timeBetweenEvictionRunsMillis) {
this.timeBetweenEvictionRunsMillis = timeBetweenEvictionRunsMillis;
} public boolean isPoolPreparedStatements() {
return poolPreparedStatements;
} @Value("${spring.datasource.poolPreparedStatements}")
public void setPoolPreparedStatements(boolean poolPreparedStatements) {
this.poolPreparedStatements = poolPreparedStatements;
} public int getmaxOpenPreparedStatementConnectionSize() {
return maxOpenPreparedStatementConnectionSize;
} @Value("${spring.datasource.maxOpenPreparedStatementConnectionSize}")
public void setmaxOpenPreparedStatementConnectionSize(int maxOpenPreparedStatementConnectionSize) {
this.maxOpenPreparedStatementConnectionSize = maxOpenPreparedStatementConnectionSize;
} /**
* AbstractDBConfig.java
* @Description:自定义数据源
* @return
* @throws Exception
* @date 2018年1月22日 下午5:26:25
* @author ningque
*
*/
public abstract DataSource dataSource()throws Exception;
/**
*
* AbstractDBConfig.java
* @Description:自定义事物
* @return
* @throws Exception
* @date 2018年1月22日 下午5:26:38
* @author ningque
*
*/
public abstract DataSourceTransactionManager transactionManager()throws Exception;
/**
*
* AbstractDBConfig.java
* @Description:自定义session
* @param dataSource
* @return
* @throws Exception
* @date 2018年1月22日 下午5:27:41
* @author ningque
*
*/
public abstract SqlSessionFactory sqlSessionFactory( DataSource dataSource)throws Exception;
/**
*
* AbstractDBConfig.java
* @Description:配置druid 监控
* @return
* @date 2018年1月22日 下午5:28:01
* @author ningque
*
*/
public abstract ServletRegistrationBean druidServlet();
public abstract FilterRegistrationBean filterRegistrationBean();
}
主数据源类
package so.dian.device.common.config; import java.sql.SQLException; import javax.sql.DataSource; import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.annotation.MapperScan;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.boot.web.servlet.FilterRegistrationBean;
import org.springframework.boot.web.servlet.ServletRegistrationBean;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;
import org.springframework.core.io.support.PathMatchingResourcePatternResolver;
import org.springframework.jdbc.datasource.DataSourceTransactionManager; import com.alibaba.druid.pool.DruidDataSource;
import com.alibaba.druid.support.http.StatViewServlet;
import com.alibaba.druid.support.http.WebStatFilter; @Configuration
@ConfigurationProperties(prefix = "spring.datasource")
@MapperScan(basePackages="so.dian.device.dao.dataBase1",sqlSessionFactoryRef = "dataBase1SqlSessionFactory")
public class dataBase1DruidDBConfig extends AbstractDBConfig { private static Logger log = LoggerFactory.getLogger(dataBase1DruidDBConfig.class); private String url;
private String mapperLocations;
public String userName;
public String passWord;
private String typeAliasesPackage; public String getTypeAliasesPackage() {
return typeAliasesPackage;
} @Value("${mybatis.type-aliases-package.dataBase1}")
public void setTypeAliasesPackage(String typeAliasesPackage) {
this.typeAliasesPackage = typeAliasesPackage;
} public String getUserName() {
return userName;
} @Value("${spring.datasource.username.dataBase1}")
public void setUserName(String userName) {
this.userName = userName;
} public String getPassWord() {
return passWord;
} @Value("${spring.datasource.password.dataBase1}")
public void setPassWord(String passWord) {
this.passWord = passWord;
} public String getUrl() {
return url;
} @Value("${spring.datasource.url.dataBase1}")
public void setUrl(String url) {
this.url = url;
} public String getMapperLocations() {
return mapperLocations;
} @Value("${mybatis.mapper-locations.dataBase1}")
public void setMapperLocations(String mapperLocations) {
this.mapperLocations = mapperLocations;
} @Bean(name = "dataBase1DataSource")
@Primary
public DataSource dataSource() throws SQLException {
log.info("---------------开始初始化 dataBase1DataSource!!");
DruidDataSource druidDataSource = new DruidDataSource();
log.info("driver -->:" + getDriver() + ", url -->:" + url);
druidDataSource.setDriverClassName(getDriver());
druidDataSource.setUrl(getUrl());
druidDataSource.setUsername(getUsername());
druidDataSource.setPassword(getPassword()); druidDataSource.setMaxActive(getMaxActive());
druidDataSource.setInitialSize(getInitialSize());
druidDataSource.setMinIdle(getMinIdle());
druidDataSource.setMaxWait(getMaxWait());
druidDataSource.setMinEvictableIdleTimeMillis(getMinEvictableIdleTimeMillis());
druidDataSource.setValidationQuery(getValidationQuery());
druidDataSource.setTestWhileIdle(isTestWhileIdle());
druidDataSource.setTestOnBorrow(isTestOnBorrow());
druidDataSource.setTestOnReturn(isTestOnReturn());
druidDataSource.setConnectionProperties(getConnectionProperties());
druidDataSource.setFilters(getFilters());
druidDataSource.setTimeBetweenEvictionRunsMillis(getTimeBetweenEvictionRunsMillis());
druidDataSource.setPoolPreparedStatements(isPoolPreparedStatements());
druidDataSource.setMaxOpenPreparedStatements(getMaxOpenPreparedStatementConnectionSize());
return druidDataSource;
} @Bean(name = "dataBase1TransactionManager")
@Primary
public DataSourceTransactionManager transactionManager()throws Exception {
return new DataSourceTransactionManager(dataBase1PrimaryDataSource());
} @Bean(name = "dataBase1SqlSessionFactory")
@Primary
public SqlSessionFactory sqlSessionFactory(@Qualifier("dataBase1DataSource") DataSource dataBase1DataSource)
throws Exception {
final SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
sessionFactory.setDataSource(dataBase1DataSource);
sessionFactory.setMapperLocations(new PathMatchingResourcePatternResolver().getResources(getMapperLocations()));
sessionFactory.setTypeAliasesPackage(typeAliasesPackage);
return sessionFactory.getObject();
} @Bean
@RefreshScope
public ServletRegistrationBean druidServlet() {
log.info("---------------开始初始化 ServletRegistrationBean!!");
ServletRegistrationBean reg = new ServletRegistrationBean();
reg.setServlet(new StatViewServlet());
reg.addUrlMappings("/druid/*");
reg.addInitParameter("loginUsername", "hello");
reg.addInitParameter("loginPassword", "hello123");
return reg;
} @Bean
@RefreshScope
public FilterRegistrationBean filterRegistrationBean() {
log.info("---------------开始初始化 FilterRegistrationBean!!");
FilterRegistrationBean filterRegistrationBean = new FilterRegistrationBean();
filterRegistrationBean.setFilter(new WebStatFilter());
filterRegistrationBean.addUrlPatterns("/*");
filterRegistrationBean.addInitParameter("exclusions", "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*");
filterRegistrationBean.addInitParameter("profileEnable", "true");
filterRegistrationBean.addInitParameter("principalCookieName", "USER_COOKIE");
filterRegistrationBean.addInitParameter("principalSessionName", "USER_SESSION");
return filterRegistrationBean;
} }
从数据源配置
package so.dian.device.common.config; import java.sql.SQLException; import javax.sql.DataSource; import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.annotation.MapperScan;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.boot.web.servlet.FilterRegistrationBean;
import org.springframework.boot.web.servlet.ServletRegistrationBean;
import org.springframework.dataBase2.context.config.annotation.RefreshScope;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.io.support.PathMatchingResourcePatternResolver;
import org.springframework.jdbc.datasource.DataSourceTransactionManager; import com.alibaba.druid.pool.DruidDataSource;
import com.alibaba.druid.support.http.StatViewServlet;
import com.alibaba.druid.support.http.WebStatFilter; @Configuration
@ConfigurationProperties(prefix = "spring.datasource")
@MapperScan(basePackages="so.dian.device.dao.dataBase2",sqlSessionFactoryRef = "dataBase2SqlSessionFactory")
public classdataBase2DruidDBConfig extends AbstractDBConfig { private static Logger log = LoggerFactory.getLogger(dataBase2DruidDBConfig.class); private String url;
public String userName;
public String passWord;
private String mapperLocations;
private String typeAliasesPackage; public String getTypeAliasesPackage() {
return typeAliasesPackage;
} @Value("${mybatis.type-aliases-package.dataBase2}")
public void setTypeAliasesPackage(String typeAliasesPackage) {
this.typeAliasesPackage = typeAliasesPackage;
} public String getUserName() {
return userName;
} @Value("${spring.datasource.username.dataBase2}")
public void setUserName(String userName) {
this.userName = userName;
} public String getPassWord() {
return passWord;
} @Value("${spring.datasource.password.dataBase2}")
public void setPassWord(String passWord) {
this.passWord = passWord;
} public String getUrl() {
return url;
} @Value("${spring.datasource.url.dataBase2}")
public void setUrl(String url) {
this.url = url;
} public String getMapperLocations() {
return mapperLocations;
} @Value("${mybatis.mapper-locations.dataBase2}")
public void setMapperLocations(String mapperLocations) {
this.mapperLocations = mapperLocations;
} @Bean(name = "dataBase2DataSource")
public DataSourcedataBase2 dataSource() throws SQLException {
log.info("---------------开始初始化dataBase2DataSource!!");
DruidDataSource druidDataSource = new DruidDataSource();
log.info("driver -->:" + getDriver() + ", url -->:" + url);
druidDataSource.setDriverClassName(getDriver());
druidDataSource.setUrl(url);
druidDataSource.setUsername(userName);
druidDataSource.setPassword(passWord); druidDataSource.setMaxActive(getMaxActive());
druidDataSource.setInitialSize(getInitialSize());
druidDataSource.setMinIdle(getMinIdle());
druidDataSource.setMaxWait(getMaxWait());
druidDataSource.setMinEvictableIdleTimeMillis(getMinEvictableIdleTimeMillis());
druidDataSource.setValidationQuery(getValidationQuery());
druidDataSource.setTestWhileIdle(isTestWhileIdle());
druidDataSource.setTestOnBorrow(isTestOnBorrow());
druidDataSource.setTestOnReturn(isTestOnReturn());
druidDataSource.setConnectionProperties(getConnectionProperties());
druidDataSource.setFilters(getFilters());
druidDataSource.setTimeBetweenEvictionRunsMillis(getTimeBetweenEvictionRunsMillis());
druidDataSource.setPoolPreparedStatements(isPoolPreparedStatements());
druidDataSource.setMaxOpenPreparedStatements(getMaxOpenPreparedStatementConnectionSize());
return druidDataSource;
} @Bean(name = "dataBase2TransactionManager")
public DataSourceTransactionManager transactionManager()throws Exception {
return new DataSourceTransactionManager(dataBase2DataSource());
} @Bean(name = "dataBase2SqlSessionFactory")
public SqlSessionFactory sqlSessionFactory(@Qualifier("dataBase2DataSource") DataSource dataBase2DataSource)
throws Exception {
final SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
sessionFactory.setDataSource(dataBase2DataSource);
sessionFactory.setMapperLocations(new PathMatchingResourcePatternResolver().getResources(mapperLocations));
sessionFactory.setTypeAliasesPackage(getTypeAliasesPackage());
return sessionFactory.getObject();
} @Bean
@RefreshScope
public ServletRegistrationBean druidServlet() {
log.info("---------------开始初始化 ServletRegistrationBean!!");
ServletRegistrationBean reg = new ServletRegistrationBean();
reg.setServlet(new StatViewServlet());
reg.addUrlMappings("/druid/*");
reg.addInitParameter("loginUsername", "fac");
reg.addInitParameter("loginPassword", "r5bk2fey");
return reg;
} @Bean
@RefreshScope
public FilterRegistrationBean filterRegistrationBean() {
log.info("---------------开始初始化 FilterRegistrationBean!!");
FilterRegistrationBean filterRegistrationBean = new FilterRegistrationBean();
filterRegistrationBean.setFilter(new WebStatFilter());
filterRegistrationBean.addUrlPatterns("/*");
filterRegistrationBean.addInitParameter("exclusions", "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*");
filterRegistrationBean.addInitParameter("profileEnable", "true");
filterRegistrationBean.addInitParameter("principalCookieName", "USER_COOKIE");
filterRegistrationBean.addInitParameter("principalSessionName", "USER_SESSION");
return filterRegistrationBean;
}
}
ok 启动工程
[INFO] - ---------------开始初始化 dataBase1DataSource!!
2018-01-22 16:48:34.830 [main] [config.DataBase1DruidDBConfig.dataBase1PrimaryDataSource] [INFO] - driver -->:com.mysql.jdbc.Driver, url -->:jdbc:mysql://192.168.166.66:3306/dataBase1
2018-01-22 16:48:36.462 [main] [org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$3.doWith] [WARN] - Autowired annotation should only be used on methods with parameters: public int config.AbstractDBConfig.getMaxOpenPreparedStatementConnectionSize()
2018-01-22 16:48:36.541 [main] [config.DataBase1DruidDBConfig.dataBase1DataSource] [INFO] - ---------------开始初始化 dataBase2DataSource!!
2018-01-22 16:48:36.542 [main] [config.DataBase2DruidDBConfig.dataBase2DataSource] [INFO] - driver -->:com.mysql.jdbc.Driver, url -->:jdbc:mysql://192.168.166.67:3306/dataBase2?useUnicode=true&characterEncoding=utf-8&allowMultiQueries=true
2018-01-22 16:48:37.706 [main] [com.netflix.config.sources.URLConfigurationSource.<init>] [WARN] - No URLs will be polled as dynamic configuration sources.
2018-01-22 16:48:37.706 [main] [com.netflix.config.sources.URLConfigurationSource.<init>] [INFO] - To enable URLs as dynamic configuration sources, define Sy
druid 页面
|
* 用户名 |
dataBase1 |
指定建立连接时使用的用户名 |
|
* 连接地址 |
jdbc:mysql://jdbc:mysql://192.168.166.66:3306/dataBase1 |
jdbc连接字符串 |
|
* 数据库类型 |
mysql |
数据库类型 |
|
* 驱动类名 |
com.mysql.jdbc.Driver |
jdbc驱动的类名 |
|
* filter类名 |
com.alibaba.druid.filter.stat.StatFilter,com.alibaba.druid.wall.WallFilter,com.alibaba.druid.filter.logging.Log4jFilter |
|
* 用户名 |
dataBase2 |
指定建立连接时使用的用户名 |
|
* 连接地址 |
jdbc:mysql://192.168.166.67:3306/dataBase2?useUnicode=true&characterEncoding=utf-8&allowMultiQueries=true |
jdbc连接字符串 |
|
* 数据库类型 |
mysql |
数据库类型 |
|
* 驱动类名 |
com.mysql.jdbc.Driver |
jdbc驱动的类名 |
|
* filter类名 |
com.alibaba.druid.filter.stat.StatFilter,com.alibaba.druid.wall.WallFilter,com.alibaba.druid.filter.logging.Log4jFilter |
spring boot +mybatis+druid 多数据源配置的更多相关文章
- spring boot + mybatis + druid配置实践
最近开始搭建spring boot工程,将自身实践分享出来,本文将讲述spring boot + mybatis + druid的配置方案. pom.xml需要引入mybatis 启动依赖: < ...
- Spring Boot 2.x 多数据源配置之 MyBatis 篇
场景假设:现有电商业务,商品和库存分别放在不同的库 配置数据库连接 app: datasource: first: driver-class-name: com.mysql.cj.jdbc.Drive ...
- Spring Boot + MyBatis + Druid + Redis + Thymeleaf 整合小结
Spring Boot + MyBatis + Druid + Redis + Thymeleaf 整合小结 这两天闲着没事想利用**Spring Boot**加上阿里的开源数据连接池**Druid* ...
- 13、Spring Boot 2.x 多数据源配置
1.13 Spring Boot 2.x 多数据源配置 完整源码: Spring-Boot-Demos
- Spring Boot + Mybatis + Druid 动态切换多数据源
在大型应用程序中,配置主从数据库并使用读写分离是常见的设计模式. 在Spring应用程序中,要实现读写分离,最好不要对现有代码进行改动,而是在底层透明地支持. 这样,就需要我们再一个项目中,配置两个, ...
- spring boot + mybatis + druid
因为在用到spring boot + mybatis的项目时候,经常发生访问接口卡,服务器项目用了几天就很卡的甚至不能访问的情况,而我们的项目和数据库都是好了,考虑到可能时数据库连接的问题,所以我打算 ...
- (15)Spring Boot使用Druid和监控配置【从零开始学Spring Boot】
Spring Boot 系列博客] 更多查看博客:http://412887952-qq-com.iteye.com/blog Spring Boot默认的数据源是:org.apache.tomcat ...
- Spring Boot + Mybatis 实现动态数据源
动态数据源 在很多具体应用场景的时候,我们需要用到动态数据源的情况,比如多租户的场景,系统登录时需要根据用户信息切换到用户对应的数据库.又比如业务A要访问A数据库,业务B要访问B数据库等,都可以使用动 ...
- Mybatis+Druid多数据源配置
在日常开发中我们可能会用到多数据源开发,什么是多数据源? 简单来讲的话,就是一个项目连接多个数据库.当然只是可能会用到,我暂时没见过应用场景,但是还是了解学习一下 此项目可以基于上一个简单集成项目进行 ...
随机推荐
- iOS:quartz2D绘图(在PDF文件上绘制图片)
quartz2D还可以在PDF文件上绘制图片,它有自己的PDF Graphics Context上下文,通过UIGraphicsBeginPDFContextToFile方法开始上下文后就可以绘制图片 ...
- 完美解决“find: 路径必须在表达式之前:”
使用find命令查找文件的时候会有如题的提示,只需略作修改即可.两种方法: ①可cd到其它目录再查找(当前目录下存在要查找的目标文件时会出现此类错误,换到其它目录下再执行相同的命令即可): ②如果目标 ...
- flask上传文件时request.files为空的解决办法
在做上传文件的时候遇到request.files是空 原因在于html中的表单form没有指明 enctype="multipart/form-data" <form met ...
- java发送http的get和post请求
import java.io.*; import java.net.URL; import java.util.Map; import java.net.HttpURLConnection;; pub ...
- unity mipmap 糊
unity 开miapmap会糊很多 尤其在editor里面 我估计和editor的 tempRT resolution 957x380有关 -----确实是这样 手机上糊的程度低很多 中间rt我用的 ...
- 摄像头模组 PDAF对焦(Phase Detection Auto Focus)
本文主要是最近看的两个文档的总结,相对零散的笔记,包括<imx298 software reference PDAF>与<PDAF Truly>. 1.PDAF功能的实现需要使 ...
- 项目部署问题:xftp无法连接服务器、Nginx403 Forbidden解决、nginx反向代理解决前端跨域问题
一.xftp无法连接服务器 在xftp中配置正确的ip,用户名和密码后,居然无法连接 解决方案:将协议里面的FTP换成SFTP,注意换成SFTP后端口就默认换成22,要还是原来的21就还是连不上的哈 ...
- Python自然语言处理资料库
1.LTP [1]- 语言技术平台(LTP) 提供包括中文分词.词性标注.命名实体识别.依存句法分析.语义角色标注等丰富. 高效.精准的自然语言处理技术.经过哈工大社会计算与信息检索研究中心 11 年 ...
- TreeView 类 事件
名称 说明 AfterCheck 在选中树节点复选框后发生. AfterCollapse 在折叠树节点后发生. AfterExpand 在展开树节点后发生. AfterLabelEdit 在编辑树节点 ...
- ANDROID颜色设置
Android中的颜色设置 1.在android中经常看到设置的颜色为八位的十六进制的颜色值,例如: public static final class color { public static ...