- 在Android开发中,如何获取到手机设备的PIN码?
西瓜本瓜@
android智能手机
在Android开发中,无法直接获取用户设置的PIN码(锁屏密码),无论是否有Root权限。这是Android系统层面的隐私和安全机制保护,即使是系统应用或使用了Xposed模块,也无法直接访问用户设置的锁屏PIN、图案、密码。✅原因:Android系统保护机制锁屏密码(包括PIN、图案、密码)是加密保存在系统中,例如/data/system/locksettings.db,而且即使你访问这个数据
- 第二十八:Fiddler抓包-抓取Android7.0以上的Https包(三)-夜神模拟器+Xposed+JustTrustMe
卢卡平头哥
Fiddlerfiddlerhttpsandroid
一.简介1.二次加密:有的APP,在涉及到关键数据通信时,会将正文二次加密后才通过HTTPS发送1.1.抓包抓到的是一堆二进制base642.自带HTTPClient:像支付宝那样的变态,自己带一个基于so的HTTPClient库2.1.对于关键数据,都不走URLConnection和OkHttp,而是走自己的HTTPClient库2.2.甚至一些
- 基于Xposed的高级数据爬取实战:突破APP反爬机制的企业级解决方案
Python×CATIA工业智造
人工智能大数据网络爬虫pycharm
引言:移动端数据采集的技术困境在App数据价值日益凸显的时代,传统爬取方案面临三大核心挑战:协议加密壁垒:金融类App采用非标准加密方案比例高达92%(来源:2023年移动安全年报)动态防护升级:行为分析技术识别异常请求准确率达85%法律合规风险:违反《数据安全法》最高罚款可达年营收5%行业数据显示:主流电商平台单用户画像价值1.2-5.3传统爬虫方案识别率超过75%数据采集综合成本增长120%X
- Android xposed 安装教程
口袋安少
android
AndroidXposed安装教程Xposed框架是一个强大的工具,它可以让开发者和高级用户在Android设备上进程地修改应用程序而不需要修改APK文件。本文将教你如何在Android设备上安装Xposed框架。我们将详细介绍整个过程,并提供每一步需使用的代码及其解释。安装流程概览安装Xposed框架的步骤如下:步骤描述步骤1确认设备已root步骤2下载并安装XposedInstaller应用步
- Qt中opengl使用swapBuffers()函数报错解决办法
啊 哈
QTOPENGL
swapBuffers():qt文档中方的翻译:用屏幕外缓冲区交换屏幕内容。仅当窗口小部件的格式指定双缓冲模式时,此方法才有效。通常,不需要显式调用此函数,因为它是在每个小部件重新绘制后(即每次执行paintGL()之后)自动完成的。我是在线程中使用swapBuffers时候报下面这个错。报错:QOpenGLContext::swapBuffers()calledwithnon-exposedwi
- 微信ipad协议/个人微信协议/个微协议
ylianxin
微信
目前微信社群比较火,市面上社群管理工具也是有各式各样的,但是最终都不开微信的协议,协议样式也有很多,例如web、PCHook、模拟机、Xposed等。但是目前各类协议的稳定性有待考究。目前稳定不封号,安全性好,功能满足,行业占有率高。已将8037协议封装为统一的框架服务,用户可一次性完成所有对接,省去了频繁更新接口的烦恼。功能如下:登录:扫码登录,获取数据,登录,自动心跳好友管理:添加好友、删除好
- 太极APP:免Root,畅享Xposed模块的神奇魅力
非凡ghost
linux运维服务器软件需求android智能手机
在安卓系统中,Xposed框架一直以其强大的功能和高度的自定义能力受到众多用户的喜爱。然而,传统的Xposed框架需要Root权限和复杂的刷机操作,这使得许多普通用户望而却步。太极APP的出现,打破了这一限制,它为用户提供了一个免Root、免解锁、免刷机的Xposed模块运行环境,让每一位用户都能轻松体验Xposed模块带来的强大功能。软件简介太极APP是一款专为安卓用户设计的免RootXpose
- docker dockerfile开启2375端口
棠十一
docker容器运维
windows中dockerdesktop设置中dockerengine中增加2375的配置“hosts”:[“unix:///var/run/docker.sock”,“tcp://127.0.0.1:2375”],其次在General设置中勾选Exposedaemonontcp://localhost:2375withoutTLS
- xposed 入门之修改手机 IMEI
去哪儿网技术沙龙
androidimei安全经验分享安卓
吕元江2019年1月加入去哪儿网,现负责app的分析和设备指纹反爬事项,对app脱壳,java/nativec层加解密算法分析还原有丰富经验。1.背景xposed对于很多安卓安全和逆向人员来说并不陌生,在对app的函数功能分析和拦截时经常会用到。本文以xposed修改某个应用的IMEI为例,作为一个简单入门介绍。供新手了解如何使用xposed编写自己所需的hook模块,以及简单介绍xposed在其
- 安卓逆向篇&LSP 模块&HOOK 添加技术&绕过检测&算法解密&逻辑验证
我最厉害。,。
android里氏替换原则
前置解释:0、Magisk:是当前Android社区用来获取root权限的主流方式开源工具1、LSP框架:XPosed框架因只支持安卓8及以下,故高版本应使用Magisk+LSPosed2、HOOK技术:钩子技术,本质就是劫持调用,将自身的代码“融入”被勾住(Hook)的程序的进程中3、算法助手:LSPosed下的模块,集成常见功能外加自定义HOOK方便逆向调试安装使用:见上次(88-1天内容环境
- 记录一次抓包实战,全局代理+xposed+frida绕过各种坑点
韭零后程序猿
python黑科技抓包fridaxposed全局代理postern
遇到的问题apk使用了360加固,无法反编译apk没有走系统代理,导致设置wifi代理抓不到包问题1解决办法:使用FRIDA-DEXDump工具直接从内存dump出dex包,然后使用jadx-gui-1.1.0-with-jre-windows工具打开dex文件查看代码FRIDA-DEXDUMPgithub链接jadx-gui网上比较多,自行百度下载需要先按照frida,自行百度下载安装问题2解决
- Lspatch的使用原理及机制
王景程
智能手机vscodetypescript
很多搞机佬们在玩机的时候都会偏向于给系统装上LSposed框架,这对于有root的小伙伴来说那可是刚需。但是在手机没有root的情况下或者是bootloader未解锁的时候,想要玩机那就得用LSpatch啦!下面给大家讲一讲其工作原理LSPatch的工作原理可以从以下几个关键方面来分析,包括XposedHook机制、补丁注入方式、代码修改方式、运行时加载机制、签名与安全机制。1.LSPatch的核
- 360加固一键脱壳工具2020_Android逆向之路---脱壳360加固原理解析
weixin_39870132
360加固一键脱壳工具2020android二维码解析原理
需要的环境无,看文章就可以了解大致了(当然你要是想编译下dumpDex项目,需要如下工具)AndroidStudiosdkndk入口所有的程序执行的时候都是有个入口的,dumpDex工程也不例外。由于是个xposed插件,所以我们先看com.wrbug.dumpdex.XposedInit类。publicclassXposedInitimplementsIXposedHookLoadPackage
- Frida零基础入门教程
疯人院的院长大人
安卓应用优化专题javalinux开发语言
阅读这篇文章,不仅能了解frida是什么,还能知道如何搭建Frida运行换以及学会用frida进行简单的java/nativehook实战。Xposed大家不陌生,在手机上运行的Hook框架,Xposed插件编写完成并在手机上通过hook框架加载,打开指定应用就能实现代码注入,也就是说Xposed插件的代码是编写在手机上的,每次运行都需要更新Xposed上的插件并重启应用,否则hook不会生效。在
- 安卓逆向(Xposed-Hook)
奶龙牛牛
android前端javascript
关于参数问题如果方法是这样publicintaddNumbers(inta,intb){returna+b;}Hook代码XposedHelpers.findAndHookMethod("com.example.app.Calculator",lpparam.classLoader,"addNumbers",int.class,int.class,//两个参数,都是intnewXC_MethodH
- python抖音接口_「docker实战篇」python的docker-抖音分析接口数据分析(21)
weixin_39890633
python抖音接口
上节xposed已经安装完毕,设置对应的android的版本和代理服务器。准备工作1.xposed和JustTruestMe的安装2.抖音安装完毕启动fildder点击进入指定的粉丝界面查看数据GEThttps://api.amemv.com/aweme/v1/user/follower/list/?user_id=108719454702&max_time=1549012794&count=20
- Android逆向(Xposed配置)
奶龙牛牛
android
settings.gradle1.settings.gradlevs.build.gradle文件作用settings.gradle管理整个Gradle项目(包括多模块)build.gradle管理单个模块的构建(比如依赖、插件)重点:settings.gradle负责全局配置,比如项目名称、多模块、仓库地址等。build.gradle负责每个模块的构建配置,比如Java版本、依赖项等。//Gra
- Android逆向学习知识体系(三)
zhangjianming2018
Androidkotlinandroid
第二阶段:Android逆向进阶学习:Android系统结构深入分析,自定义ClassLoader,自定义注解和元注解原理分析;了解AndroidNDK,静态注册,动态注册,SO加载分析,App保护策略去除霸哥磁力搜素APK签名验证,一键去除签名验证,静态代理,动态代理HookActivity启动函数,Hook签名验证函数介绍xposed框架:Xposed框架:绕过验证码注册Xposed框架:登陆
- 【转】android安全与逆向进阶路线
Synioe
androidandroid
【转自论坛热帖】此篇整理了最完整的--Android逆向学习线路知识体系。希望给迷糊的入门者指出一个明确的方向。真心建议:先正向开发几年再搞逆向吧……正向都不会破解的是啥?不看代码只会脱壳?只会xposed?远远不够,hook只是很小一部分技术,xposed是hook功能众多框架中的一个而已。相对于任何程序的开发来说,逆向知识点很少很少了,关键是基础知识,基础就是正向开发经验。学习Android逆
- Gallery2 视频静音功能 闪退 exposed beyond app through Intent.getData()
wxx2150
BUGandroidgallerymutecrash
具体的错误log如下---------beginningofcrash03-2219:19:17.950E/AndroidRuntime(5809):FATALEXCEPTION:main03-2219:19:17.950E/AndroidRuntime(5809):Process:com.android.gallery3d,PID:580903-2219:19:17.950E/AndroidRu
- exposed beyond app through Intent.getData()
秋天的春
Androidandroid
调用相册打开图片startActivity时报了个错startActivityForResulterror:file:///storage/emulated/0/Android/data/xxx.jpgexposedbeyondappthroughIntent.getData()调查发现是AndroidStudio7.0之后官方对这权限做了调整:官方解答:出于用户隐私安全考虑,对于面向Androi
- Android Hook与简单的xposed模块开发实例
Hook是一种在特定事件或操作发生时插入自定义代码的编程技术。在前端开发中,例如Vue和Angular的生命周期钩子,体现了Hook的机制,允许开发者在组件的不同阶段执行代码,提升代码的模块化和可重用性。AndroidHook与此类似,允许开发者在Android应用程序运行时修改或扩展现有功能。通过拦截方法调用、修改参数或返回值,Hook可用于调试、测试和逆向工程,例如监控应用程序行为、捕获API
- Xposed模块 -- Hook函数参数
web安全工具库
安卓逆向Xposed模块安卓逆向
安卓系统7.1搭建Xposed环境安卓逆向--Xposed模块编写安卓逆向--Jeb动态调试一、根据以前的课程,我们通过抓包分析,知道了如下的关键函数packagecom.dodonew.online.http;importandroid.text.TextUtils;importandroid.util.Log;importcom.dodonew.online.util.DesSecurity;
- xposed中hook的用法
socketyc
android
1.普通的类中方法;XposedHelpers.findAndHookMethod(clazz,//类"test",//方法名String::class.java,//参数object:XC_MethodHook(){@Throws(Throwable::class)overridefunbeforeHookedMethod(param:MethodHookParam){Log.i(TAG,"正在
- xposed-hook-反射
aπ
文章
xposedhook反射不介绍介绍hook经验如何找怎么写有时间再写(想想怎么深入的写,找几个app,hook一下,写写过程,谈谈经验…)
- xposed 03 - hook字段与一般方法
二手的程序员
xposed逆向前端java
本文主要讨论一下如何hook字段与方法hook字段有两种方式:使用反射使用xposedapi由于xposed模块也运行在app进程中,所以我们可以将app的代码当作自己的,直接反射访问。Hook静态字段与成员字段测试代码:package com.example.hooktargeclass HookTarget2 { private var str: String = "hello"
- Xposed-Hook
奶龙牛牛
android
配置Xposed模块的AndroidManifest.xml:在app/src/main/assets创建一个xposed_init文件。xposed_init文件是Xposed模块必需的一个配置文件,它用来指定模块的入口类。这个文件需要包含你的Xposed模块的主类的完整类名(包含包名):your.package.name.MainHookapp/build.gradle配置一下:depende
- 【Vue3】defineExpose
正宗咸豆花
vue.jsjavascript前端
【Vue3】defineExposedefineExpose是Vue3.2引入的一个新API,它是的配套API之一。在中,所有定义的变量和函数默认是私有的,不能从组件外部访问。如果你想让外部组件访问到内定义的属性或方法,你需要使用defineExpose显式地暴露它们。这是defineExpose的基本用法:import{defineExpose}from'vue'//...定义响应式数据、函数等
- 什么是Xposed和LSPosed框架?
王景程
githubgit
1.什么是Xposed框架?Xposed框架是一个面向Android平台的模块化框架,允许开发者和用户通过加载模块来修改应用程序或系统行为,而无需修改应用程序的APK文件或系统文件。工作原理:Xposed框架通过挂钩(Hook)Android系统的方法或类,来改变这些方法或类的运行行为。它的核心是通过动态加载用户编写的模块代码,在系统或应用运行时注入代码。主要特性:可以修改应用的行为而不需要重新编
- 避免检测:安卓模拟器/安卓虚拟机/root环境
圣道寺
日常使用android
目录标题可选方案问题解决XposedInstallermagisk安装报错:Unabletodetecttargetimage如何避免模拟器被检测可选方案如果你想要避免某些安卓应用检测到你正在使用安卓虚拟机,你可以尝试以下方法。但请注意,这些操作可能违反了应用的使用条款,因此请在遵守相关法规和条款的前提下进行操作。修改虚拟机设备信息:一些应用会检查设备的制造商、型号等信息。你可以使用一些工具来修改
- java类加载顺序
3213213333332132
java
package com.demo;
/**
* @Description 类加载顺序
* @author FuJianyong
* 2015-2-6上午11:21:37
*/
public class ClassLoaderSequence {
String s1 = "成员属性";
static String s2 = "
- Hibernate与mybitas的比较
BlueSkator
sqlHibernate框架ibatisorm
第一章 Hibernate与MyBatis
Hibernate 是当前最流行的O/R mapping框架,它出身于sf.net,现在已经成为Jboss的一部分。 Mybatis 是另外一种优秀的O/R mapping框架。目前属于apache的一个子项目。
MyBatis 参考资料官网:http:
- php多维数组排序以及实际工作中的应用
dcj3sjt126com
PHPusortuasort
自定义排序函数返回false或负数意味着第一个参数应该排在第二个参数的前面, 正数或true反之, 0相等usort不保存键名uasort 键名会保存下来uksort 排序是对键名进行的
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8&q
- DOM改变字体大小
周华华
前端
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml&q
- c3p0的配置
g21121
c3p0
c3p0是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展。c3p0的下载地址是:http://sourceforge.net/projects/c3p0/这里可以下载到c3p0最新版本。
以在spring中配置dataSource为例:
<!-- spring加载资源文件 -->
<bean name="prope
- Java获取工程路径的几种方法
510888780
java
第一种:
File f = new File(this.getClass().getResource("/").getPath());
System.out.println(f);
结果:
C:\Documents%20and%20Settings\Administrator\workspace\projectName\bin
获取当前类的所在工程路径;
如果不加“
- 在类Unix系统下实现SSH免密码登录服务器
Harry642
免密ssh
1.客户机
(1)执行ssh-keygen -t rsa -C "
[email protected]"生成公钥,xxx为自定义大email地址
(2)执行scp ~/.ssh/id_rsa.pub root@xxxxxxxxx:/tmp将公钥拷贝到服务器上,xxx为服务器地址
(3)执行cat
- Java新手入门的30个基本概念一
aijuans
javajava 入门新手
在我们学习Java的过程中,掌握其中的基本概念对我们的学习无论是J2SE,J2EE,J2ME都是很重要的,J2SE是Java的基础,所以有必要对其中的基本概念做以归纳,以便大家在以后的学习过程中更好的理解java的精髓,在此我总结了30条基本的概念。 Java概述: 目前Java主要应用于中间件的开发(middleware)---处理客户机于服务器之间的通信技术,早期的实践证明,Java不适合
- Memcached for windows 简单介绍
antlove
javaWebwindowscachememcached
1. 安装memcached server
a. 下载memcached-1.2.6-win32-bin.zip
b. 解压缩,dos 窗口切换到 memcached.exe所在目录,运行memcached.exe -d install
c.启动memcached Server,直接在dos窗口键入 net start "memcached Server&quo
- 数据库对象的视图和索引
百合不是茶
索引oeacle数据库视图
视图
视图是从一个表或视图导出的表,也可以是从多个表或视图导出的表。视图是一个虚表,数据库不对视图所对应的数据进行实际存储,只存储视图的定义,对视图的数据进行操作时,只能将字段定义为视图,不能将具体的数据定义为视图
为什么oracle需要视图;
&
- Mockito(一) --入门篇
bijian1013
持续集成mockito单元测试
Mockito是一个针对Java的mocking框架,它与EasyMock和jMock很相似,但是通过在执行后校验什么已经被调用,它消除了对期望 行为(expectations)的需要。其它的mocking库需要你在执行前记录期望行为(expectations),而这导致了丑陋的初始化代码。
&nb
- 精通Oracle10编程SQL(5)SQL函数
bijian1013
oracle数据库plsql
/*
* SQL函数
*/
--数字函数
--ABS(n):返回数字n的绝对值
declare
v_abs number(6,2);
begin
v_abs:=abs(&no);
dbms_output.put_line('绝对值:'||v_abs);
end;
--ACOS(n):返回数字n的反余弦值,输入值的范围是-1~1,输出值的单位为弧度
- 【Log4j一】Log4j总体介绍
bit1129
log4j
Log4j组件:Logger、Appender、Layout
Log4j核心包含三个组件:logger、appender和layout。这三个组件协作提供日志功能:
日志的输出目标
日志的输出格式
日志的输出级别(是否抑制日志的输出)
logger继承特性
A logger is said to be an ancestor of anothe
- Java IO笔记
白糖_
java
public static void main(String[] args) throws IOException {
//输入流
InputStream in = Test.class.getResourceAsStream("/test");
InputStreamReader isr = new InputStreamReader(in);
Bu
- Docker 监控
ronin47
docker监控
目前项目内部署了docker,于是涉及到关于监控的事情,参考一些经典实例以及一些自己的想法,总结一下思路。 1、关于监控的内容 监控宿主机本身
监控宿主机本身还是比较简单的,同其他服务器监控类似,对cpu、network、io、disk等做通用的检查,这里不再细说。
额外的,因为是docker的
- java-顺时针打印图形
bylijinnan
java
一个画图程序 要求打印出:
1.int i=5;
2.1 2 3 4 5
3.16 17 18 19 6
4.15 24 25 20 7
5.14 23 22 21 8
6.13 12 11 10 9
7.
8.int i=6
9.1 2 3 4 5 6
10.20 21 22 23 24 7
11.19
- 关于iReport汉化版强制使用英文的配置方法
Kai_Ge
iReport汉化英文版
对于那些具有强迫症的工程师来说,软件汉化固然好用,但是汉化不完整却极为头疼,本方法针对iReport汉化不完整的情况,强制使用英文版,方法如下:
在 iReport 安装路径下的 etc/ireport.conf 里增加红色部分启动参数,即可变为英文版。
# ${HOME} will be replaced by user home directory accordin
- [并行计算]论宇宙的可计算性
comsci
并行计算
现在我们知道,一个涡旋系统具有并行计算能力.按照自然运动理论,这个系统也同时具有存储能力,同时具备计算和存储能力的系统,在某种条件下一般都会产生意识......
那么,这种概念让我们推论出一个结论
&nb
- 用OpenGL实现无限循环的coverflow
dai_lm
androidcoverflow
网上找了很久,都是用Gallery实现的,效果不是很满意,结果发现这个用OpenGL实现的,稍微修改了一下源码,实现了无限循环功能
源码地址:
https://github.com/jackfengji/glcoverflow
public class CoverFlowOpenGL extends GLSurfaceView implements
GLSurfaceV
- JAVA数据计算的几个解决方案1
datamachine
javaHibernate计算
老大丢过来的软件跑了10天,摸到点门道,正好跟以前攒的私房有关联,整理存档。
-----------------------------华丽的分割线-------------------------------------
数据计算层是指介于数据存储和应用程序之间,负责计算数据存储层的数据,并将计算结果返回应用程序的层次。J
&nbs
- 简单的用户授权系统,利用给user表添加一个字段标识管理员的方式
dcj3sjt126com
yii
怎么创建一个简单的(非 RBAC)用户授权系统
通过查看论坛,我发现这是一个常见的问题,所以我决定写这篇文章。
本文只包括授权系统.假设你已经知道怎么创建身份验证系统(登录)。 数据库
首先在 user 表创建一个新的字段(integer 类型),字段名 'accessLevel',它定义了用户的访问权限 扩展 CWebUser 类
在配置文件(一般为 protecte
- 未选之路
dcj3sjt126com
诗
作者:罗伯特*费罗斯特
黄色的树林里分出两条路,
可惜我不能同时去涉足,
我在那路口久久伫立,
我向着一条路极目望去,
直到它消失在丛林深处.
但我却选了另外一条路,
它荒草萋萋,十分幽寂;
显得更诱人,更美丽,
虽然在这两条小路上,
都很少留下旅人的足迹.
那天清晨落叶满地,
两条路都未见脚印痕迹.
呵,留下一条路等改日再
- Java处理15位身份证变18位
蕃薯耀
18位身份证变15位15位身份证变18位身份证转换
15位身份证变18位,18位身份证变15位
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
蕃薯耀 201
- SpringMVC4零配置--应用上下文配置【AppConfig】
hanqunfeng
springmvc4
从spring3.0开始,Spring将JavaConfig整合到核心模块,普通的POJO只需要标注@Configuration注解,就可以成为spring配置类,并通过在方法上标注@Bean注解的方式注入bean。
Xml配置和Java类配置对比如下:
applicationContext-AppConfig.xml
<!-- 激活自动代理功能 参看:
- Android中webview跟JAVASCRIPT中的交互
jackyrong
JavaScripthtmlandroid脚本
在android的应用程序中,可以直接调用webview中的javascript代码,而webview中的javascript代码,也可以去调用ANDROID应用程序(也就是JAVA部分的代码).下面举例说明之:
1 JAVASCRIPT脚本调用android程序
要在webview中,调用addJavascriptInterface(OBJ,int
- 8个最佳Web开发资源推荐
lampcy
编程Web程序员
Web开发对程序员来说是一项较为复杂的工作,程序员需要快速地满足用户需求。如今很多的在线资源可以给程序员提供帮助,比如指导手册、在线课程和一些参考资料,而且这些资源基本都是免费和适合初学者的。无论你是需要选择一门新的编程语言,或是了解最新的标准,还是需要从其他地方找到一些灵感,我们这里为你整理了一些很好的Web开发资源,帮助你更成功地进行Web开发。
这里列出10个最佳Web开发资源,它们都是受
- 架构师之面试------jdk的hashMap实现
nannan408
HashMap
1.前言。
如题。
2.详述。
(1)hashMap算法就是数组链表。数组存放的元素是键值对。jdk通过移位算法(其实也就是简单的加乘算法),如下代码来生成数组下标(生成后indexFor一下就成下标了)。
static int hash(int h)
{
h ^= (h >>> 20) ^ (h >>>
- html禁止清除input文本输入缓存
Rainbow702
html缓存input输入框change
多数浏览器默认会缓存input的值,只有使用ctl+F5强制刷新的才可以清除缓存记录。
如果不想让浏览器缓存input的值,有2种方法:
方法一: 在不想使用缓存的input中添加 autocomplete="off";
<input type="text" autocomplete="off" n
- POJO和JavaBean的区别和联系
tjmljw
POJOjava beans
POJO 和JavaBean是我们常见的两个关键字,一般容易混淆,POJO全称是Plain Ordinary Java Object / Pure Old Java Object,中文可以翻译成:普通Java类,具有一部分getter/setter方法的那种类就可以称作POJO,但是JavaBean则比 POJO复杂很多, Java Bean 是可复用的组件,对 Java Bean 并没有严格的规
- java中单例的五种写法
liuxiaoling
java单例
/**
* 单例模式的五种写法:
* 1、懒汉
* 2、恶汉
* 3、静态内部类
* 4、枚举
* 5、双重校验锁
*/
/**
* 五、 双重校验锁,在当前的内存模型中无效
*/
class LockSingleton
{
private volatile static LockSingleton singleton;
pri