但是Instant的官方描述来看,它是一个不可变的且线程安全的类
* @implSpec
* This class is immutable and thread-safe.
* @since 1.8
*/
public final class Instant implements Temporal, TemporalAdjuster, Comparable<Instant>, Serializable {}
有效时间范围是从-1000000000-01-01T00:00Z
~-1000000000-01-01T00:00Z
,可以满足大部分场景下的时刻现实问题。
同时在java8提供了toInsatant()和from()两个方法用于Date和Instant之间的来回转换
System.out.println("toInstant() = "+date.toInstant());
System.out.println("from() = "+Date.from(instant));
输出
toInstant() = 2020-06-10T07:45:42.440Z
from() = Wed Jun 10 15:45:42 CST 2020
可以看到相互转换过程中的时区问题不需要我们考虑,会自动+08:00
或者-08:00
。
比较头疼的一个事情就是java8没有针对Instant提供一个可供自定义的格式化类,所以这边我的解决方法是转换成LocalDateTime
,再使用DateTimeFormatter
来完成格式化。
System.out.println("Instant = " + LocalDateTime.ofInstant(instant, ZoneId.systemDefault())
.format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
输出
Instant = 2020-06-10 16:02:26
这样就比较容易的解决了格式化的问题,当然你也可以自定义一个@config来完成对Instant的格式化,也不失为一种一劳永逸的方案。LocalDateTime和DateTimeFormatter在后面的内容中会做详细的介绍。
在讲解LocalDateTime之前我们先分别介绍一下LocalDate
和LocalTime
,以便于能更深入地理解LocalDateTime
。
LocalDate和LocalTime
LocalDate
LocalDate首先是一个不可变类,默认格式为yyyy-MM-dd
,其次它是一个只获取年月日
的类,侧重点在日历而不是时间(这里我们需要把日历和时间这两个概念区分开)。
使用LocalDate.now()可以获取当前年月日
,也可以使用LocalDate.of(year,month,dayOfMonth)
来指定日期
public static void main(String[] args) {
LocalDate today = LocalDate.now();
System.out.println("LocalDate.now() = "+today);
today = LocalDate.of(2020,06,10);
LocalDate laterDate = today.plusDays(30);
System.out.println("LocalDate.of() = "+today.toString());
System.out.println("plusDays = "+laterDate.toString());
System.out.println("new Date() = "+ new Date());
}
输出
LocalDate.now() = 2020-06-09
LocalDate.of() = 2020-06-10
plusDays = 2020-07-10
new Date() = Tue Jun 09 20:31:22 CST 2020
从这个例子可以对比看出LocalDate
和Date
的不同。
同时作为一个访问器方法,LocalDate每次都是生成一个新的对象
,而不是改变原有的对象的值。
可以从today.plusDays(30)
中轻易地看到。与之类似的就是更改器方法,在java较早的版本中又一个类java.util.GregorianCalendar
public static void main(String[] args) {
GregorianCalendar someDay = new GregorianCalendar(2020,06,9);
System.out.println("before someDay = "+someDay.getTime());
someDay.add(Calendar.DAY_OF_MONTH,30);
System.out.println("after someDay = "+someDay.getTime());
}
输出
before someDay = Thu Jul 09 00:00:00 CST 2020
after someDay = Sat Aug 08 00:00:00 CST 2020
可以看到someDay的值随着函数add的调用一直在变化着,这与LocalDate大不一样,这是需要注意的一个点。
这边还需要注意一个点是localDate.getDayOfWeek().getValue()
,LocalDate对于一周的枚举计数和Calendar有些不一样。
LocalDate一周是从周一开始计数对应的value值为1,周日结束对应的value值为7。
而Calendar一周是从周日开始计数对应的value值为1,周六结束对应的value为7,相比较下个人觉得LocalDate更加合理和好用一些。
LocalDate常用的方法如下:
图片来自java核心技术卷2
LocalTime
LocalTime
与LocalDate
类似同样是一个不可变类,默认格式是HH:mm:ss.zzz,可以看到它所关注的是当前的时刻。
public static void main(String[] args) {
LocalTime localTime = LocalTime.now();
System.out.println("LocalTime.now() = "+localTime);
localTime = LocalTime.of(8,8,8,888);
System.out.println("LocalTime.of() = "+localTime);
LocalTime laterTime = localTime.plusHours(2);
System.out.println("localTime.plusHours() = "+laterTime);
//根据时区获取当前时刻,同理适用与LocalDate
LocalTime newlocalTime = LocalTime.now(ZoneId.of("America/New_York"));
System.out.println("America/New_York Time = "+newlocalTime);
}
输出
LocalTime.now() = 20:58:54.941
LocalTime.of() = 08:08:08.000000888
localTime.plusHours() = 10:08:08.000000888
America/New_York Time = 08:58:54.944
这里我们会发现,尽管LocalTime
默认的格式为HH:mm:ss.zzz
,但是纳秒级别的精度它也是能支持的08:08:08.000000888
。LocalTime常用的方法如下:
java核心技术卷2
LocalDateTime
经过对LocalDate和LocalTime的介绍,LocalDateTime
相信大家也已经知道如何使用了。
LocalDateTime也是一个不可变类
且线程安全
,它的默认格式为yyyy-MM-ddTHH:mm:ss.zzz
,显然在日常的web开发过程中我们都会对这样的日期格式进行格式化,这就是我这边特别要提的一点了。
之前我们讲过java.text.SimpleDateFormat可以自定义格式化时间格式,但是他并不是线程安全的类
,所以java8开始配合LocalDateTime提供了java.time.format.DateTimeFormatter
来搞定这个问题。
* @implSpec
* This class is immutable and thread-safe.
*
* @since 1.8
*/
public final class DateTimeFormatter
这是官方对他的介绍,这个类是不可变并且是线程安全的。所以我们可以放心地用了。
但是友情提醒下线程安全+线程安全不一定线程安全
,不要误解了,这里就不展开讨论了。下面我们和SimpleDateFormat一起对比着来使用一下。
// LocalDateTime
LocalDateTime localDateTime = LocalDateTime.now();
String newLocalDateTime = localDateTime.format(DateTimeFormatter.ofPattern("yyy-MM-dd HH:mm:ss"));
System.out.println("LocalDateTime = "+localDateTime);
System.out.println("DateTimeFormatter 格式化后的时间 = "+newLocalDateTime);
//Date
SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
Date date = new Date();
System.out.println("new Date() = "+date);
String s = simpleDateFormat.format(date);
System.out.println("SimpleDateFormat 格式化Date后 = "+s);
输出
LocalDateTime = 2020-06-10T14:41:02.546
DateTimeFormatter 格式化后的时间 = 2020-06-10 14:41:02
new Date() = Wed Jun 10 14:41:02 CST 2020
SimpleDateFormat 格式化Date后 = 2020-06-10 14:41:02
从代码量上就可以看到DateTimeFormatter的优势了,一行搞定
。
相比一下SimpleDateFormat
每次都要new一个对象,在极端情况下就会导致创建很多实例短时间无法回收而浪费很多内存空间,当然我们也可以通过使用静态变量通过添加synchronized来达到目的,但是同步块不可避免的问题就是阻塞。
当然你一定会说我可以使用ThreadLocal来创建副本来解决SimpleDateFormat的线程安全问题。这个是比较好的一个解决方案,如下:
private static ThreadLocal<DateFormat> threadLocal = new ThreadLocal<DateFormat>() {
@Override
protected DateFormat initialValue() {
return new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
}
};
System.out.println("ThreadLocal = "+threadLocal.get().format(date));
输出
如何自学黑客&网络安全
黑客零基础入门学习路线&规划
初级黑客
1、网络安全理论知识(2天)
①了解行业相关背景,前景,确定发展方向。
②学习网络安全相关法律法规。
③网络安全运营的概念。
④等保简介、等保规定、流程和规范。(非常重要)
2、渗透测试基础(一周)
①渗透测试的流程、分类、标准
②信息收集技术:主动/被动信息搜集、Nmap工具、Google Hacking
③漏洞扫描、漏洞利用、原理,利用方法、工具(MSF)、绕过IDS和反病毒侦察
④主机攻防演练:MS17-010、MS08-067、MS10-046、MS12-20等
3、操作系统基础(一周)
①Windows系统常见功能和命令
②Kali Linux系统常见功能和命令
③操作系统安全(系统入侵排查/系统加固基础)
4、计算机网络基础(一周)
①计算机网络基础、协议和架构
②网络通信原理、OSI模型、数据转发流程
③常见协议解析(HTTP、TCP/IP、ARP等)
④网络攻击技术与网络安全防御技术
⑤Web漏洞原理与防御:主动/被动攻击、DDOS攻击、CVE漏洞复现
5、数据库基础操作(2天)
①数据库基础
②SQL语言基础
③数据库安全加固
6、Web渗透(1周)
①HTML、CSS和JavaScript简介
②OWASP Top10
③Web漏洞扫描工具
④Web渗透工具:Nmap、BurpSuite、SQLMap、其他(菜刀、漏扫等)
恭喜你,如果学到这里,你基本可以从事一份网络安全相关的工作,比如渗透测试、Web 渗透、安全服务、安全分析等岗位;如果等保模块学的好,还可以从事等保工程师。薪资区间6k-15k
到此为止,大概1个月的时间。你已经成为了一名“脚本小子”。那么你还想往下探索吗?
如果你想要入坑黑客&网络安全,笔者给大家准备了一份:282G全网最全的网络安全资料包评论区留言即可领取!
7、脚本编程(初级/中级/高级)
在网络安全领域。是否具备编程能力是“脚本小子”和真正黑客的本质区别。在实际的渗透测试过程中,面对复杂多变的网络环境,当常用工具不能满足实际需求的时候,往往需要对现有工具进行扩展,或者编写符合我们要求的工具、自动化脚本,这个时候就需要具备一定的编程能力。在分秒必争的CTF竞赛中,想要高效地使用自制的脚本工具来实现各种目的,更是需要拥有编程能力.
如果你零基础入门,笔者建议选择脚本语言Python/PHP/Go/Java中的一种,对常用库进行编程学习;搭建开发环境和选择IDE,PHP环境推荐Wamp和XAMPP, IDE强烈推荐Sublime;·Python编程学习,学习内容包含:语法、正则、文件、 网络、多线程等常用库,推荐《Python核心编程》,不要看完;·用Python编写漏洞的exp,然后写一个简单的网络爬虫;·PHP基本语法学习并书写一个简单的博客系统;熟悉MVC架构,并试着学习一个PHP框架或者Python框架 (可选);·了解Bootstrap的布局或者CSS。
8、超级黑客
这部分内容对零基础的同学来说还比较遥远,就不展开细说了,附上学习路线。
网络安全工程师企业级学习路线
如图片过大被平台压缩导致看不清的话,评论区点赞和评论区留言获取吧。我都会回复的
视频配套资料&国内外网安书籍、文档&工具
当然除了有配套的视频,同时也为大家整理了各种文档和书籍资料&工具,并且已经帮大家分好类了。
一些笔者自己买的、其他平台白嫖不到的视频教程。
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!