项目背景:项目开发中数据库使用了读写分离,所有查询语句走从库,除此之外走主库。

最简单的办法其实就是建两个包,把之前数据源那一套配置copy一份,指向另外的包,但是这样扩展很有限,所有采用下面的办法。

参考了两篇文章如下:

http://blog.csdn.net/zl3450341/article/details/20150687

http://www.blogjava.net/hoojo/archive/2013/10/22/405488.html

这两篇文章都对原理进行了分析,下面只写自己的实现过程其他不再叙述。

实现思路是:

第一步,实现动态切换数据源:配置两个DataSource,配置两个SqlSessionFactory指向两个不同的DataSource,两个SqlSessionFactory都用一个SqlSessionTemplate,同时重写Mybatis提供的SqlSessionTemplate类,最后配置Mybatis自动扫描。

第二步,利用aop切面,拦截dao层所有方法,因为dao层方法命名的特点,比如所有查询sql都是select开头,或者get开头等等,拦截这些方法,并把当前数据源切换至从库。

spring中配置如下:

主库数据源配置:

1 <bean id="masterDataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
2     <property name="driverClass" value="${master_mysql_jdbc_driver}" />
3     <property name="jdbcUrl" value="${master_mysql_jdbc_url}" />
4     <property name="user" value="${master_mysql_jdbc_user}" />
5     <property name="password" value="${master_mysql_jdbc_password}" />
6 </bean>

从库数据源配置:

1 <bean id="masterDataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
2     <property name="driverClass" value="${slave_mysql_jdbc_driver}" />
3     <property name="jdbcUrl" value="${slave_mysql_jdbc_url}" />
4     <property name="user" value="${slave_mysql_jdbc_user}" />
5     <property name="password" value="${slave_mysql_jdbc_password}" />
6 </bean>

主库SqlSessionFactory配置:

1 <bean id="masterSqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
2     <property name="dataSource" ref="masterDataSource" />
3     <property name="mapperLocations"  value="classpath:com/sincetimes/slg/dao/*.xml"/>
4 </bean>

从库SqlSessionFactory配置:

1 <bean id="slaveSqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
2     <property name="dataSource" ref="slaveDataSource" />
3     <property name="mapperLocations"  value="classpath:com/sincetimes/slg/dao/*.xml"/>
4 </bean>

两个SqlSessionFactory使用同一个SqlSessionTemplate配置:

1 <bean id="MasterAndSlaveSqlSessionTemplate" class="com.sincetimes.slg.framework.core.DynamicSqlSessionTemplate">
2     <constructor-arg index="0" ref="masterSqlSessionFactory" />
3     <property name="targetSqlSessionFactorys">
4         <map>  
5             <entry value-ref="masterSqlSessionFactory" key="master"/>  
6             <entry value-ref="slaveSqlSessionFactory" key="slave"/>  
7         </map>  
8     </property>
9 </bean>

配置Mybatis自动扫描dao

1 <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
2     <property name="basePackage" value="com.sincetimes.slg.dao" />
3     <property name="sqlSessionTemplateBeanName" value="MasterAndSlaveSqlSessionTemplate" />
4 </bean>

自己重写了SqlSessionTemplate代码如下:

  1 package com.sincetimes.slg.framework.core;
  2 
  3 import static java.lang.reflect.Proxy.newProxyInstance;
  4 import static org.apache.ibatis.reflection.ExceptionUtil.unwrapThrowable;
  5 import static org.mybatis.spring.SqlSessionUtils.closeSqlSession;
  6 import static org.mybatis.spring.SqlSessionUtils.getSqlSession;
  7 import static org.mybatis.spring.SqlSessionUtils.isSqlSessionTransactional;
  8  
  9 import java.lang.reflect.InvocationHandler;
 10 import java.lang.reflect.Method;
 11 import java.sql.Connection;
 12 import java.util.List;
 13 import java.util.Map;
 14 
 15 import org.apache.ibatis.exceptions.PersistenceException;
 16 import org.apache.ibatis.executor.BatchResult;
 17 import org.apache.ibatis.session.Configuration;
 18 import org.apache.ibatis.session.ExecutorType;
 19 import org.apache.ibatis.session.ResultHandler;
 20 import org.apache.ibatis.session.RowBounds;
 21 import org.apache.ibatis.session.SqlSession;
 22 import org.apache.ibatis.session.SqlSessionFactory;
 23 import org.mybatis.spring.MyBatisExceptionTranslator;
 24 import org.mybatis.spring.SqlSessionTemplate;
 25 import org.springframework.dao.support.PersistenceExceptionTranslator;
 26 import org.springframework.util.Assert;
 27 
 28 import com.sincetimes.slg.framework.util.SqlSessionContentHolder;
 29 
 30 
 31 /**
 32  * 
 33  * TODO         重写SqlSessionTemplate
 34  * @author      ccg
 35  * @version        1.0
 36  * Created        2017年4月21日 下午3:15:15
 37  */
 38 public class DynamicSqlSessionTemplate extends SqlSessionTemplate {
 39  
 40     private final SqlSessionFactory sqlSessionFactory;
 41     private final ExecutorType executorType;
 42     private final SqlSession sqlSessionProxy;
 43     private final PersistenceExceptionTranslator exceptionTranslator;
 44  
 45     private Map<Object, SqlSessionFactory> targetSqlSessionFactorys;
 46     private SqlSessionFactory defaultTargetSqlSessionFactory;
 47  
 48     public void setTargetSqlSessionFactorys(Map<Object, SqlSessionFactory> targetSqlSessionFactorys) {
 49         this.targetSqlSessionFactorys = targetSqlSessionFactorys;
 50     }
 51     
 52     public Map<Object, SqlSessionFactory> getTargetSqlSessionFactorys(){
 53         return targetSqlSessionFactorys;
 54     }
 55  
 56     public void setDefaultTargetSqlSessionFactory(SqlSessionFactory defaultTargetSqlSessionFactory) {
 57         this.defaultTargetSqlSessionFactory = defaultTargetSqlSessionFactory;
 58     }
 59  
 60     public DynamicSqlSessionTemplate(SqlSessionFactory sqlSessionFactory) {
 61         this(sqlSessionFactory, sqlSessionFactory.getConfiguration().getDefaultExecutorType());
 62     }
 63  
 64     public DynamicSqlSessionTemplate(SqlSessionFactory sqlSessionFactory, ExecutorType executorType) {
 65         this(sqlSessionFactory, executorType, new MyBatisExceptionTranslator(sqlSessionFactory.getConfiguration()
 66                 .getEnvironment().getDataSource(), true));
 67     }
 68  
 69     public DynamicSqlSessionTemplate(SqlSessionFactory sqlSessionFactory, ExecutorType executorType,
 70             PersistenceExceptionTranslator exceptionTranslator) {
 71  
 72         super(sqlSessionFactory, executorType, exceptionTranslator);
 73  
 74         this.sqlSessionFactory = sqlSessionFactory;
 75         this.executorType = executorType;
 76         this.exceptionTranslator = exceptionTranslator;
 77         
 78         this.sqlSessionProxy = (SqlSession) newProxyInstance(
 79                 SqlSessionFactory.class.getClassLoader(),
 80                 new Class[] { SqlSession.class }, 
 81                 new SqlSessionInterceptor());
 82  
 83         this.defaultTargetSqlSessionFactory = sqlSessionFactory;
 84     }
 85  
 86     @Override
 87     public SqlSessionFactory getSqlSessionFactory() {
 88  
 89         SqlSessionFactory targetSqlSessionFactory = targetSqlSessionFactorys.get(SqlSessionContentHolder.getContextType());
 90         if (targetSqlSessionFactory != null) {
 91             return targetSqlSessionFactory;
 92         } else if (defaultTargetSqlSessionFactory != null) {
 93             return defaultTargetSqlSessionFactory;
 94         } else {
 95             Assert.notNull(targetSqlSessionFactorys, "Property 'targetSqlSessionFactorys' or 'defaultTargetSqlSessionFactory' are required");
 96             Assert.notNull(defaultTargetSqlSessionFactory, "Property 'defaultTargetSqlSessionFactory' or 'targetSqlSessionFactorys' are required");
 97         }
 98         return this.sqlSessionFactory;
 99     }
100  
101     @Override
102     public Configuration getConfiguration() {
103         return this.getSqlSessionFactory().getConfiguration();
104     }
105  
106     public ExecutorType getExecutorType() {
107         return this.executorType;
108     }
109  
110     public PersistenceExceptionTranslator getPersistenceExceptionTranslator() {
111         return this.exceptionTranslator;
112     }
113  
114     /**
115      * {@inheritDoc}
116      */
117     public <T> T selectOne(String statement) {
118         return this.sqlSessionProxy.<T> selectOne(statement);
119     }
120  
121     /**
122      * {@inheritDoc}
123      */
124     public <T> T selectOne(String statement, Object parameter) {
125         return this.sqlSessionProxy.<T> selectOne(statement, parameter);
126     }
127  
128     /**
129      * {@inheritDoc}
130      */
131     public <K, V> Map<K, V> selectMap(String statement, String mapKey) {
132         return this.sqlSessionProxy.<K, V> selectMap(statement, mapKey);
133     }
134  
135     /**
136      * {@inheritDoc}
137      */
138     public <K, V> Map<K, V> selectMap(String statement, Object parameter, String mapKey) {
139         return this.sqlSessionProxy.<K, V> selectMap(statement, parameter, mapKey);
140     }
141  
142     /**
143      * {@inheritDoc}
144      */
145     public <K, V> Map<K, V> selectMap(String statement, Object parameter, String mapKey, RowBounds rowBounds) {
146         return this.sqlSessionProxy.<K, V> selectMap(statement, parameter, mapKey, rowBounds);
147     }
148  
149     /**
150      * {@inheritDoc}
151      */
152     public <E> List<E> selectList(String statement) {
153         return this.sqlSessionProxy.<E> selectList(statement);
154     }
155  
156     /**
157      * {@inheritDoc}
158      */
159     public <E> List<E> selectList(String statement, Object parameter) {
160         return this.sqlSessionProxy.<E> selectList(statement, parameter);
161     }
162  
163     /**
164      * {@inheritDoc}
165      */
166     public <E> List<E> selectList(String statement, Object parameter, RowBounds rowBounds) {
167         return this.sqlSessionProxy.<E> selectList(statement, parameter, rowBounds);
168     }
169  
170     /**
171      * {@inheritDoc}
172      */
173     public void select(String statement, ResultHandler handler) {
174         this.sqlSessionProxy.select(statement, handler);
175     }
176  
177     /**
178      * {@inheritDoc}
179      */
180     public void select(String statement, Object parameter, ResultHandler handler) {
181         this.sqlSessionProxy.select(statement, parameter, handler);
182     }
183  
184     /**
185      * {@inheritDoc}
186      */
187     public void select(String statement, Object parameter, RowBounds rowBounds, ResultHandler handler) {
188         this.sqlSessionProxy.select(statement, parameter, rowBounds, handler);
189     }
190  
191     /**
192      * {@inheritDoc}
193      */
194     public int insert(String statement) {
195         return this.sqlSessionProxy.insert(statement);
196     }
197  
198     /**
199      * {@inheritDoc}
200      */
201     public int insert(String statement, Object parameter) {
202         return this.sqlSessionProxy.insert(statement, parameter);
203     }
204  
205     /**
206      * {@inheritDoc}
207      */
208     public int update(String statement) {
209         return this.sqlSessionProxy.update(statement);
210     }
211  
212     /**
213      * {@inheritDoc}
214      */
215     public int update(String statement, Object parameter) {
216         return this.sqlSessionProxy.update(statement, parameter);
217     }
218  
219     /**
220      * {@inheritDoc}
221      */
222     public int delete(String statement) {
223         return this.sqlSessionProxy.delete(statement);
224     }
225  
226     /**
227      * {@inheritDoc}
228      */
229     public int delete(String statement, Object parameter) {
230         return this.sqlSessionProxy.delete(statement, parameter);
231     }
232  
233     /**
234      * {@inheritDoc}
235      */
236     public <T> T getMapper(Class<T> type) {
237         return getConfiguration().getMapper(type, this);
238     }
239  
240     /**
241      * {@inheritDoc}
242      */
243     public void commit() {
244         throw new UnsupportedOperationException("Manual commit is not allowed over a Spring managed SqlSession");
245     }
246  
247     /**
248      * {@inheritDoc}
249      */
250     public void commit(boolean force) {
251         throw new UnsupportedOperationException("Manual commit is not allowed over a Spring managed SqlSession");
252     }
253  
254     /**
255      * {@inheritDoc}
256      */
257     public void rollback() {
258         throw new UnsupportedOperationException("Manual rollback is not allowed over a Spring managed SqlSession");
259     }
260  
261     /**
262      * {@inheritDoc}
263      */
264     public void rollback(boolean force) {
265         throw new UnsupportedOperationException("Manual rollback is not allowed over a Spring managed SqlSession");
266     }
267  
268     /**
269      * {@inheritDoc}
270      */
271     public void close() {
272         throw new UnsupportedOperationException("Manual close is not allowed over a Spring managed SqlSession");
273     }
274  
275     /**
276      * {@inheritDoc}
277      */
278     public void clearCache() {
279         this.sqlSessionProxy.clearCache();
280     }
281  
282     /**
283      * {@inheritDoc}
284      */
285     public Connection getConnection() {
286         return this.sqlSessionProxy.getConnection();
287     }
288  
289     /**
290      * {@inheritDoc}
291      * @since 1.0.2
292      */
293     public List<BatchResult> flushStatements() {
294         return this.sqlSessionProxy.flushStatements();
295     }
296  
297     /**
298      * Proxy needed to route MyBatis method calls to the proper SqlSession got from Spring's Transaction Manager It also
299      * unwraps exceptions thrown by {@code Method#invoke(Object, Object...)} to pass a {@code PersistenceException} to
300      * the {@code PersistenceExceptionTranslator}.
301      */
302     private class SqlSessionInterceptor implements InvocationHandler {
303         public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
304             final SqlSession sqlSession = getSqlSession(
305                     DynamicSqlSessionTemplate.this.getSqlSessionFactory(),
306                     DynamicSqlSessionTemplate.this.executorType, 
307                     DynamicSqlSessionTemplate.this.exceptionTranslator);
308             try {
309                 Object result = method.invoke(sqlSession, args);
310                 if (!isSqlSessionTransactional(sqlSession, DynamicSqlSessionTemplate.this.getSqlSessionFactory())) {
311                     // force commit even on non-dirty sessions because some databases require
312                     // a commit/rollback before calling close()
313                     sqlSession.commit(true);
314                 }
315                 return result;
316             } catch (Throwable t) {
317                 Throwable unwrapped = unwrapThrowable(t);
318                 if (DynamicSqlSessionTemplate.this.exceptionTranslator != null && unwrapped instanceof PersistenceException) {
319                     Throwable translated = DynamicSqlSessionTemplate.this.exceptionTranslator
320                         .translateExceptionIfPossible((PersistenceException) unwrapped);
321                     if (translated != null) {
322                         unwrapped = translated;
323                     }
324                 }
325                 throw unwrapped;
326             } finally {
327                 closeSqlSession(sqlSession, DynamicSqlSessionTemplate.this.getSqlSessionFactory());
328             }
329         }
330     }
331  
332 }

SqlSessionContentHolder类代码如下:

 1 package com.sincetimes.slg.framework.util;
 2 
 3 public abstract class SqlSessionContentHolder {
 4 
 5     public final static String SESSION_FACTORY_MASTER = "master";
 6     public final static String SESSION_FACTORY_SLAVE = "slave";
 7     
 8     private static final ThreadLocal<String> contextHolder = new ThreadLocal<String>();  
 9     
10     public static void setContextType(String contextType) {  
11         contextHolder.set(contextType);  
12     }  
13       
14     public static String getContextType() {  
15         return contextHolder.get();  
16     }  
17       
18     public static void clearContextType() {  
19         contextHolder.remove();  
20     } 
21 }

最后就是写切面去对dao所有方法进行处理了,代码很简单如下:

 1 package com.sincetimes.slg.framework.core;
 2 
 3 import org.aspectj.lang.JoinPoint;
 4 import org.aspectj.lang.annotation.Aspect;
 5 import org.aspectj.lang.annotation.Before;
 6 import org.aspectj.lang.annotation.Pointcut;
 7 
 8 import com.sincetimes.slg.framework.util.SqlSessionContentHolder;
 9 
10 @Aspect
11 public class DynamicDataSourceAspect {
12 
13     @Pointcut("execution( * com.sincetimes.slg.dao.*.*(..))")
14     public void pointCut(){
15         
16     }
17     @Before("pointCut()")
18     public void before(JoinPoint jp){
19         String methodName = jp.getSignature().getName();  
20         //dao方法查询走从库
21         if(methodName.startsWith("query") || methodName.startsWith("get") || methodName.startsWith("count") || methodName.startsWith("list")){
22             SqlSessionContentHolder.setContextType(SqlSessionContentHolder.SESSION_FACTORY_SLAVE);
23         }else{
24             SqlSessionContentHolder.setContextType(SqlSessionContentHolder.SESSION_FACTORY_MASTER);
25         }
26     }
27     
28 }

 

转载于:https://www.cnblogs.com/FlyHeLanMan/p/6744171.html

查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. 如何在淘宝发起知识产权投诉?

    如何发起知识产权侵权投诉?一、关于知识产权淘宝网尊重他人的知识产权,我们也期望我们的用户秉持同样的原则。淘宝网提供的是网络交易服务平台,不参与买卖过程本身,所有商品信息均为会员在其电脑终端自行上传,因此,淘宝网不是侵权主体。淘宝网要求会员保证所发布的商品信…...

    2024/4/30 20:53:20
  2. Android之联系人处理

    联系人处理 Android联系人数据存储框架 联系人数据存储在联系人数据源组件ContactsProvider2中,与一般的数据源存储组件相比,ContactsProvider2更复杂。其中的数据库包含多个表,提供的Uri也更丰富。 联系人数据由3部分组成,联系人基本信息表,如姓名,联系人账号记录表,每…...

    2024/4/17 7:07:00
  3. Randao 可证公平随机数(VRF)白皮书

    Randao 可证公平随机数白皮书 randao.org September 11, 2017Abstract Randao 基于区块链技术,提供开源的、去中心化的、社交化的、可证公平的随机数生成服务。Randao 继承了常用随机数发生器的不可控制性及不可预测性,同时具备其所不具有的可参与性及可证公平性。Randao 通过…...

    2024/4/17 7:06:30
  4. 分库分表是什么?

    分库分表是什么? 分库分表就是将本应该存到一个库的,一个表中的数据分到多个库,多个表进行存储,将一个库分成多个库,将一个表分成多个表 为什么要分库分表? 当数据库存储大量的数据时,(出于性能考虑mysql的单表数据量不要超过一千万),查询的速率会随着数据的增多变慢…...

    2024/4/18 5:37:32
  5. 文件流转换为base64码 和 base64码转换为文件流

    分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴! 例子说明一切先写单元测试吧:单元测试的代码如下:package test.com.cs;import com.cs.Bas…...

    2024/4/17 7:06:36
  6. 网络方面的书籍推荐

    Table of Contents1. 计算机网络,谢希仁版 2. 计算机网络,自顶向下方法 3. TCP/IP 卷详解一 4. UNP 5. 补充材料 – 鸟哥的linux私房菜 5. 结尾还是那句话,我只推荐自己读过的那些好书,其余的不做太多的评价。计算机网络,谢希仁版这本算是我们本科时候的教材,写得确实很好…...

    2024/3/31 20:35:03
  7. Android中获取系统通讯录联系人并解决Android6.0权限问题

    标题 ## Android中获取系统通讯录联系人并显示在EditText 1.需求 一个EditText 点击button的时候转到系统通讯录,选中其中一个通讯录item返回当前界面且把 选中的联系人号码用户名显示在EditText 上。 2.示例3.代码 AddressList.java public class AddressList extends CheckP…...

    2024/4/17 7:07:00
  8. bootStrap高级进阶 表格合并 可编辑 删除添加行 监听事件在onclick $element.blur(function(

    下拉框 https://www.jb51.net/article/119929.htm 一。有框线 class=“table-bordered” <div class="col-sm-12 select-table table-bordered"><table id="bootstrap-table" data-mobile-responsive="true" style="white-space:…...

    2024/4/18 5:30:33
  9. OpenJWeb(v1.2)快速开发平台技术白皮书发布

    OpenJWeb(v1.2版)技术白皮书QQ:29803446 Msn:baozhengw999@hotmail.com Email:baozhengw@netease.com目 录一、 关于OpenJWeb.. 4 二、OpenJWeb的技术选型.... 4 三、 OpenJWeb(v1.2)现有功能.... 6 3.1数据字典类型和数据字典定义... 6 3.2表结构定义及生成工具... 6 3.…...

    2024/4/17 7:06:48
  10. 解决Eclipse中无法直接使用Base64Encoder的问题

    Base64的加密解密都是使用sun.misc包下的BASE64Encoder及BASE64Decoder的sun.misc.BASE64Encoder/BASE64Decoder类。这个类是sun公司的内部方法,并没有在java api中公开过,不属于JDK标准库范畴,但在JDK中包含了该类,可以直接使用。但是在Eclipse和MyEclipse中直接使用,却找…...

    2024/4/17 7:07:06
  11. contacts模块功能分析(较全面)

    联系人功能分析(较全面,比较好) 转载自http://blog.csdn.net/lksodit_yiyi/article/details/7887296 1. 简介 本文基于MTK6516代码进行分析联系人模块的功能及数据库操作的流程。 联系人是手机功能中不可缺少的模块,主要记录用户的联系人数据,方便用户快捷的操作和使用…...

    2024/4/20 18:05:10
  12. 知识图谱概念篇

    随着互联网的发展,网络数据内容呈现爆炸式增长的态势。由于互联网内容的大规模、异质多元、组织结构松散的特点,给人们有效获取信息和知识提出了挑战。知识图谱(Knowledge Graph) 以其强大的语义处理能力和开放组织能力,为互联网时代的知识化组织和智能应用奠定了基础。最近…...

    2024/4/18 16:59:58
  13. 2011年读书年度小结

    今天是大年初七,很多人已经开始回到了自己的工作岗位上,相信大家都会和我一样,每到这个时间都会像以往那样说,唉,时间过得真快啊,春节又结束了。每个长假结束时都是这个感受,无一例外。我今年这个春节过得很充实、很欢乐,第一,是在这短短的几天里,在每天吃喝之外挤出…...

    2024/4/17 7:06:48
  14. 根链平台(RootStock)——基于比特币驱动的智能合约白皮书

    根链平台——基于比特币驱动的智能合约白皮书(第9版)日期:2015年11月19日作者:Sergio DemianLerner译者:黄世亮日期:2016年9月2日目录1.引言2.为什么说根链是比特币经济生态里的重要一部分?2.1 比特币经济里利益相关者和其价值保护2.2 治理模式2.3 保护比特币矿工投资2.…...

    2024/4/4 22:37:05
  15. 人工智能 = 物联网,大数据 + 云计算

    人工智能 = 物联网,大数据 + 云计算 今天想写一下我对人工智能,物联网,大数据,云计算这几个当下比较热门技术关系的理解 首先,是物联网和大数据的关系,按照我的理解。大数据,其实就是其字面的意思,也就是海量的数据。其来源就是各种存储媒介中存储的信息。大数据也可以…...

    2024/4/18 13:14:12
  16. Android 添加同名通讯录自动合并的问题

    在开发添加本地通讯录的过程中发现,同名的联系人信息总会被合并。查阅信息后发现,Android确实是智能合并的情况,而且默认是开启的。 所以要手工修改起模式,修改代码如下: values.put(RawContacts.AGGREGATION_MODE,RawContacts.AGGREGATION_MODE_DISABLED);转载于:https:/…...

    2024/4/17 7:07:42
  17. android Contacts/Acore进程经常被Kill,导致联系人开机后丢失怎么办?

    Contacts/Acore进程,在内存较少和开机进程过多的情况下会经常被 ActivityManager Kill 掉, 导致Sim卡联系人开机后未导入或者只导入一部分,造成联系人丢失的现象,但是重新开机后可以恢复正常。 遇到这样的问题可以采用以下方法提供Contacts/Acore进程的优先级,降低被Activ…...

    2024/4/24 12:26:28
  18. BufferedImage转Base64

    通过获取的文件路径,可以将bufferedImage转成base64来输出public static String getBase64(String path){File file = new File(path);String base64 = null;try {BufferedImage image = ImageIO.read(file);Integer width = image.getWidth();Integer height = image.getHeig…...

    2024/4/17 7:07:42
  19. Java 9版本之后Base64Encoder和Base64Decoder无法继续使用解决办法

    在项目开发过程中,因为重装系统,安装了Java10版本,发现sun.misc.Base64Encoder和sun.misc.Base64Decoder无法使用。原因:查看官网发现,JDK中的/lib/tool.jar和/lib/rt.jar已经从Java SE 9中删除,(我估计是因为java从sun换到oracle导致)。处理办法:直接用 java.util.Ba…...

    2024/4/19 18:35:57
  20. base64合成的图片打不开问题

    昨天写代码的时候,通过base64字符串指定路径合成对应图片,图片能合成。但是无法打开。原因是没有去掉base64字符串的头部:"data:image/png;base64," 。在上面的Data URI中,data表示取得数据的协定名称,image/png 是数据类型名称,base64 是数据的编码方法,逗号…...

    2024/4/19 13:01:42

最新文章

  1. Windows 11 系统安装时如何跳过联网和逃避微软账号登录

    问题描述 Windows 11 是从 22H2 版本之后开始强制联网何登录微软账号的。 这就带来两个问题&#xff1a; 1、如果我的电脑没有网络或者网卡驱动有问题&#xff0c;那就无法继续安装系统了。 2、如果我有强怕症&#xff0c;就是不想登录微软账号&#xff0c;害怕个人信息泄露…...

    2024/5/1 4:33:29
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/3/20 10:50:27
  3. 华为OD机试 - 跳马(Java JS Python C C++)

    须知 哈喽,本题库完全免费,收费是为了防止被爬,大家订阅专栏后可以私信联系退款。感谢支持 文章目录 须知题目描述输入描述输出描述解题思路:题目描述 马是象棋(包括中国象棋和国际象棋)中的棋子,走法是每步直一格再斜一格,即先横着或者直者走一格,然后再斜着走一个…...

    2024/4/30 4:06:08
  4. FreeRTOS学习 -- 再识

    工作中一直使用FreeRTOS进行着开发&#xff0c;但是没有进行过系统的总结过。现在将快速使用几天时间将FreeRTOS相关知识点加以总结。 官网&#xff1a; https://www.freertos.org/zh-cn-cmn-s/ 参看资料&#xff1a; 正点原子 STM32F1 FreeRTOS开发手册_V1.2.pdf The FreeRTOS…...

    2024/4/30 17:20:02
  5. Golang Gin框架

    1、这篇文章我们简要讨论一些Gin框架 主要是给大家一个基本概念 1、Gin主要是分为路由和中间件部分。 Gin底层使用的是net/http的逻辑&#xff0c;net/http主要是说&#xff0c;当来一个网络请求时&#xff0c;go func开启另一个协程去处理后续(类似epoll)。 然后主协程持续…...

    2024/4/30 17:23:41
  6. 【外汇早评】美通胀数据走低,美元调整

    原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...

    2024/4/29 23:16:47
  7. 【原油贵金属周评】原油多头拥挤,价格调整

    原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...

    2024/4/30 18:14:14
  8. 【外汇周评】靓丽非农不及疲软通胀影响

    原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...

    2024/4/29 2:29:43
  9. 【原油贵金属早评】库存继续增加,油价收跌

    原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...

    2024/4/30 18:21:48
  10. 【外汇早评】日本央行会议纪要不改日元强势

    原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...

    2024/4/27 17:58:04
  11. 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响

    原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...

    2024/4/27 14:22:49
  12. 【外汇早评】美欲与伊朗重谈协议

    原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...

    2024/4/28 1:28:33
  13. 【原油贵金属早评】波动率飙升,市场情绪动荡

    原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...

    2024/4/30 9:43:09
  14. 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试

    原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...

    2024/4/27 17:59:30
  15. 【原油贵金属早评】市场情绪继续恶化,黄金上破

    原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...

    2024/4/25 18:39:16
  16. 【外汇早评】美伊僵持,风险情绪继续升温

    原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...

    2024/4/28 1:34:08
  17. 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势

    原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...

    2024/4/26 19:03:37
  18. 氧生福地 玩美北湖(上)——为时光守候两千年

    原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...

    2024/4/29 20:46:55
  19. 氧生福地 玩美北湖(中)——永春梯田里的美与鲜

    原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...

    2024/4/30 22:21:04
  20. 氧生福地 玩美北湖(下)——奔跑吧骚年!

    原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...

    2024/5/1 4:32:01
  21. 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!

    原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...

    2024/4/27 23:24:42
  22. 「发现」铁皮石斛仙草之神奇功效用于医用面膜

    原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...

    2024/4/28 5:48:52
  23. 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者

    原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...

    2024/4/30 9:42:22
  24. 广州械字号面膜生产厂家OEM/ODM4项须知!

    原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...

    2024/4/30 9:43:22
  25. 械字号医用眼膜缓解用眼过度到底有无作用?

    原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...

    2024/4/30 9:42:49
  26. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  27. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  28. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  29. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  30. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  31. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  32. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  33. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  34. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  35. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  36. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  37. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  38. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  39. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  40. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  41. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  42. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  43. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  44. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  45. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57