摘要: OAuth是一个关于授权(authorization)的开放网络标准,在全世界得到广泛应用,目前的版本是2.0版。 本文对OAuth 2.0的设计思路和运行流程,做一个简明通俗的解释,主要参考材料为RFC 6749。 一、应用场景 为了理解OAuth的适用场合,让我举一个假设的例子。 有一个"云冲印 阅读全文
posted @ 2018-08-20 18:40 kaleidoscopic 阅读(25033) 评论(0) 推荐(2) 编辑
摘要: 网页登陆是微信4.2以后版本提供的一种全新的登陆方式。用户只需要用手机扫一扫微信网页中的二维码,就能马上实现微信网页登陆。 这种登陆方式虽然炫酷,但是多少有些违背直觉: 网页端是怎么知道是哪个微信账号扫它的呢? 前后两个事件是如何联系起来的呢? 这种登陆方式安全么? 为什么微信选择这种验证方式呢? 阅读全文
posted @ 2018-08-20 18:30 kaleidoscopic 阅读(2280) 评论(0) 推荐(0) 编辑
摘要: Java 语言中的 volatile 变量可以被看作是一种 “程度较轻的 synchronized”;与 synchronized 块相比,volatile 变量所需的编码较少,并且运行时开销也较少,但是它所能实现的功能也仅是 synchronized 的一部分。本文介绍了几种有效使用 volati 阅读全文
posted @ 2018-08-20 17:05 kaleidoscopic 阅读(617) 评论(0) 推荐(1) 编辑
摘要: 引言 在多线程并发编程中synchronized和Volatile都扮演着重要的角色,Volatile是轻量级的synchronized,它在多处理器开发中保证了共享变量的“可见性”。可见性的意思是当一个线程修改一个共享变量时,另外一个线程能读到这个修改的值。 它在某些情况下比synchronize 阅读全文
posted @ 2018-08-20 16:05 kaleidoscopic 阅读(520) 评论(0) 推荐(0) 编辑
摘要: volatile和synchronized特点 首先需要理解线程安全的两个方面:执行控制和内存可见。 执行控制的目的是控制代码执行(顺序)及是否可以并发执行。 内存可见控制的是线程执行结果在内存中对其它线程的可见性。根据Java内存模型的实现,线程在具体执行时,会先拷贝主存数据到线程本地(CPU缓存 阅读全文
posted @ 2018-08-20 15:57 kaleidoscopic 阅读(43127) 评论(5) 推荐(12) 编辑
摘要: [原文链接] Java内存模型即Java Memory Model,简称JMM。JMM定义了Java 虚拟机(JVM)在计算机内存(RAM)中的工作方式。JVM是整个计算机虚拟模型,所以JMM是隶属于JVM的。 如果我们要想深入了解Java并发编程,就要先理解好Java内存模型。Java内存模型定义 阅读全文
posted @ 2018-08-20 15:37 kaleidoscopic 阅读(7510) 评论(0) 推荐(0) 编辑
摘要: [原文链接] 什么是Feign Feign是受到Retrofit,JAXRS-2.0和WebSocket的影响,它是一个jav的到http客户端绑定的开源项目。 Feign的主要目标是将Java Http 客户端变得简单。Feign的源码地址:https://github.com/OpenFeign 阅读全文
posted @ 2018-08-20 14:19 kaleidoscopic 阅读(877) 评论(0) 推荐(0) 编辑