解决ios不支持按钮:active方法

:active伪类是在类似’mousedown’事件触发的时机生效的,而手机上并没有’mousedown’事件,取而代之的只有’touchstart’和’touchend’。

只需要给这个a链接的touch系列的任意事件touchstart/touchend绑定一个空的匿名方法即可

var a = document.getElementsByTagName('button');
for(var i = 0; i < a.length; i++) {
    a[i].addEventListener('touchstart',function(){},false);
}

 

添加以上代码,touch按下去后,发现a的active效果生效了

理解OAuth 2.0

在详细讲解OAuth 2.0之前,需要了解几个专用名词。它们对读懂后面的讲解,尤其是几张图,至关重要。

(1) Third-party application:第三方应用程序,本文中又称”客户端”(client),即上一节例子中的”云冲印”。

(2)HTTP service:HTTP服务提供商,本文中简称”服务提供商”,即上一节例子中的Google。

(3)Resource Owner:资源所有者,本文中又称”用户”(user)。

(4)User Agent:用户代理,本文中就是指浏览器。

(5)Authorization server:认证服务器,即服务提供商专门用来处理认证的服务器。

(6)Resource server:资源服务器,即服务提供商存放用户生成的资源的服务器。它与认证服务器,可以是同一台服务器,也可以是不同的服务器。

知道了上面这些名词,就不难理解,OAuth的作用就是让”客户端”安全可控地获取”用户”的授权,与”服务商提供商”进行互动。

JDK13新特性详解

1、switch优化更新

JDK11以及之前的版本:

switch (day) {
    case MONDAY: 
    case FRIDAY:
    case SUNDAY:
         System.out.println(6); 
         break; 
    case TUESDAY: 
        System.out.println(7); 
        break; case THURSDAY: 
    case SATURDAY: 
        System.out.println(8);
         break; 
    case WEDNESDAY:
         System.out.println(9);
         break; 
}

JDK12版本

switch (day) {
    case MONDAY, FRIDAY, SUNDAY -> System.out.println(6); 
    case TUESDAY -> System.out.println(7); 
    case THURSDAY, SATURDAY -> System.out.println(8); 
    case WEDNESDAY -> System.out.println(9);
 }

JDK13版本

static void howMany(int k) {
    System.out.println(
        switch (k) {
            case  1 -> "one"
            case  2 -> "two"
            default -> "many"
        }
    );}

2、文本块升级

2.1、html例子

JDK13之前

String html = "<html>\n" +
              "    <body>\n" +
              "        <p>Hello, world</p>\n" +
              "    </body>\n" +
              "</html>\n";

JDK13优化的:

String html = """
              <html>
                  <body>
                      <p>Hello, world</p>
                  </body>
              </html>
              """;

2.2、SQL变化

JDK13之前

String query = "SELECT `EMP_ID`, `LAST_NAME` FROM `EMPLOYEE_TB`\n" +
               "WHERE `CITY` = 'INDIANAPOLIS'\n" +
               "ORDER BY `EMP_ID`, `LAST_NAME`;\n";

JDK13

String query = """    
                SELECT `EMP_ID`, `LAST_NAME` FROM `EMPLOYEE_TB`
                WHERE `CITY` = 'INDIANAPOLIS'
                ORDER BY `EMP_ID`, `LAST_NAME`;
               """;

2.3、解释

文本块

"""
line 1
line 2
line 3
"""

相当于字符串文字:

"line 1\nline 2\nline 3\n"

3、动态CDS档案

目标:

提高应用程序类 - 数据共享(AppCDS)的可用性。消除了用户进行试运行以创建每个应用程序的类列表的需要。-Xshare:dump使用类列表由该选项启用的静态归档应继续工作。这包括内置类加载器和用户定义的类加载器的类。

4、取消使用未使用的内存

      摘要:

  增强ZGC以将未使用的堆内存返回给操作系统。

动机:

    ZGC目前没有取消提交并将内存返回给操作系统,即使该内存长时间未使用。对于所有类型的应用程序和环境,此行为并非最佳,
尤其是那些需要关注内存占用的应用程序和环境 例如:通过使用支付资源的容器环境。应用程序可能长时间处于空闲状态并与许多其
他应用程序共享或竞争资源的环境。应用程序在执行期间可能具有非常不同的堆空间要求。
    例如,启动期间所需的堆可能大于稳态执行期间稍后所需的堆。HotSpot中的其他垃圾收集器,如G1和Shenandoah,今天提供
了这种功能,某些类别的用户发现它非常有用。将此功能添加到ZGC将受到同一组用户的欢迎。

5、重新实现旧版套接字API

摘要:

    使用更简单,更现代的实现替换java.net.Socket和java.net.ServerSocketAPI 使用的底层实现,易于维护和调试。新的实
现很容易适应用户模式线程,也就是光纤,目前正在Project Loom中进行探索。

动机:

    在java.net.Socket和java.net.ServerSocketAPI,以及它们的底层实现,可以追溯到JDK 1.0。实现是遗留Java和C代
码的混合,维护和调试很痛苦。该实现使用线程堆栈作为I/O缓冲区,这种方法需要多次增加默认线程堆栈大小。该实现使用本机数据
结构来支持异步关闭,这是多年来微妙可靠性和移植问题的根源。该实现还有几个并发问题,需要进行大修才能正确解决。在未来的光
纤世界环境中,而不是在本机方法中阻塞线程,当前的实现不适用于目的。

6、FileSystems.newFileSystem新方法

      核心库/ java.nio中添加了FileSystems.newFileSystem(Path,Map <String,?>)方法

添加了三种新方法java.nio.file.FileSystems,以便更轻松地使用将文件内容视为文件系统的文件系统提供程序。

1、newFileSystem(Path)
2、newFileSystem(Path, Map<String, ?>)
3、newFileSystem(Path, Map<String, ?>, ClassLoader)    添加为newFileSystem(Path, Map<String, ?>) 已使用现有2-arg newFileSystem(Path, ClassLoader)并指定类加载器
的代码创建源(但不是二进制)兼容性问题。null.例如,由于引用newFileSystem不明确,因此无法编译以下内容:    FileSystem fs = FileSystems.newFileSystem(path, null);为了避免模糊引用,需要修改此代码以将第二个参数强制转换为java.lang.ClassLoader。

7、nio新方法

      核心库/ java.nio中新的java.nio.ByteBuffer批量获取/放置方法转移字节而不考虑缓冲区位置。
    java.nio.ByteBufferjava.nio现在,其他缓冲区类型定义绝对批量getput传输连续字节序列的方法,而不考虑或影响缓冲
区位置。

8、核心库/ java.time

    新日本时代名称Reiwa,此更新中添加了代表新Reiwa时代的实例。与其他时代不同,这个时代没有公共领域。它可以通过调用
JapaneseEra.of(3)或获得JapaneseEra.valueOf("Reiwa")。JDK13及更高版本将有一个新的公共领域来代表这个时代。
    NewEra从2019年5月1日开始的日本时代的占位符名称“ ”已被新的官方名称取代。依赖占位符名称(请参阅JDK-8202088)获
取新时代单例(JapaneseEra.valueOf("NewEra"))的应用程序将不再起作用。请参阅JDK-8205432

9、核心库/ java.util中:I18N

      支持Unicode 12.1,此版本将Unicode支持升级到12.1,其中包括以下内容:

    java.lang.Character支持12.1级的Unicode字符数据库,其中12.0从11.0开始增加554个字符,总共137,928个
字符。这些新增内容包括4个新脚本,总共150个脚本,以及61个新的表情符号字符。U+32FF SQUARE ERA NAME REIWA从
12.0开始,12.1只添加一个字符。java.text.Bidi和java.text.Normalizer类分别支持12.0级的Unicode标准附件,
#9和#15。java.util.regexpackage支持基于12.0级Unicode标准附件#29的扩展字形集群。

10、热点/ GC

    10.1 JEP 351 ZGC取消提交未使用的存储器 
    10.2 添加了-XXSoftMaxHeapSize标志
    10.3 ZGC支持的最大堆大小从4TB增加到16TB

11、安全库/ java.security

    11.1 该com.sun.security.crl.readtimeout系统属性设置为CRL检索的最大读取超时,单位为秒。如果尚未设置该属性,
或者其值为负,则将其设置为默认值15秒。值0表示无限超时。
    11.2 新的keytool -showinfo -tls用于显示TLS配置信息的命令keytool -showinfo -tls添加了一个显示TLS配置信
息的新命令。
    11.3 SunMSCAPI提供程序现在支持以下一代加密(CNG)格式读取私钥。这意味着CNG格式的RSA和EC密钥可从Windows密钥
库加载,例如“Windows-MY”。与EC(签名算法SHA1withECDSA,SHA256withECDSA等等)也支持。

12、删除功能

删除的部分功能:

    12.1 核心库/java.net中,不再支持Pre-JDK 1.4 SocketImpl实现java.net.SocketImpl此版本已删除对为
JavaSE1.3及更早版本编译的自定义实现的支持。此更改对SocketImpl为Java SE 1.4(2002年发布)或更新版本编译
的实现没有影响。
    12.2 核心库/java.lang中,删除运行时跟踪方法,过时的方法traceInstructions(boolean),并
traceMethodCalls(boolean)已经从删除java.lang.Runtime类。这些方法对许多版本都不起作用,它们
的预期功能由Java虚拟机工具接口(JVMTI)提供。

SpringBoot配置属性之Security

spring security是springboot支持的权限控制系统。

  • security.basic.authorize-mode
    要使用权限控制模式.
  • security.basic.enabled
    是否开启基本的鉴权,默认为true
  • security.basic.path
    需要鉴权的path,多个的话以逗号分隔,默认为[/**]
  • security.basic.realm
    HTTP basic realm 的名字,默认为Spring
  • security.enable-csrf
    是否开启cross-site request forgery校验,默认为false.
  • security.filter-order
    Security filter chain的order,默认为0
  • security.headers.cache
    是否开启http头部的cache控制,默认为false.
  • security.headers.content-type
    是否开启X-Content-Type-Options头部,默认为false.
  • security.headers.frame
    是否开启X-Frame-Options头部,默认为false.
  • security.headers.hsts
    指定HTTP Strict Transport Security (HSTS)模式(none, domain, all).
  • security.headers.xss
    是否开启cross-site scripting (XSS) 保护,默认为false.
  • security.ignored
    指定不鉴权的路径,多个的话以逗号分隔.
  • security.oauth2.client.access-token-uri
    指定获取access token的URI.
  • security.oauth2.client.access-token-validity-seconds
    指定access token失效时长.
  • security.oauth2.client.additional-information.[key]
    设定要添加的额外信息.
  • security.oauth2.client.authentication-scheme
    指定传输不记名令牌(bearer token)的方式(form, header, none,query),默认为header
  • security.oauth2.client.authorities
    指定授予客户端的权限.
  • security.oauth2.client.authorized-grant-types
    指定客户端允许的grant types.
  • security.oauth2.client.auto-approve-scopes
    对客户端自动授权的scope.
  • security.oauth2.client.client-authentication-scheme
    传输authentication credentials的方式(form, header, none, query),默认为header方式
  • security.oauth2.client.client-id
    指定OAuth2 client ID.
  • security.oauth2.client.client-secret
    指定OAuth2 client secret. 默认是一个随机的secret.
  • security.oauth2.client.grant-type
    指定获取资源的access token的授权类型.
  • security.oauth2.client.id
    指定应用的client ID.
  • security.oauth2.client.pre-established-redirect-uri
    服务端pre-established的跳转URI.
  • security.oauth2.client.refresh-token-validity-seconds
    指定refresh token的有效期.
  • security.oauth2.client.registered-redirect-uri
    指定客户端跳转URI,多个以逗号分隔.
  • security.oauth2.client.resource-ids
    指定客户端相关的资源id,多个以逗号分隔.
  • security.oauth2.client.scope
    client的scope
  • security.oauth2.client.token-name
    指定token的名称
  • security.oauth2.client.use-current-uri
    是否优先使用请求中URI,再使用pre-established的跳转URI. 默认为true
  • security.oauth2.client.user-authorization-uri
    用户跳转去获取access token的URI.
  • security.oauth2.resource.id
    指定resource的唯一标识.
  • security.oauth2.resource.jwt.key-uri
    JWT token的URI. 当key为公钥时,或者value不指定时指定.
  • security.oauth2.resource.jwt.key-value
    JWT token验证的value. 可以是对称加密或者PEMencoded RSA公钥. 可以使用URI作为value.
  • security.oauth2.resource.prefer-token-info
    是否使用token info,默认为true
  • security.oauth2.resource.service-id
    指定service ID,默认为resource.
  • security.oauth2.resource.token-info-uri
    token解码的URI.
  • security.oauth2.resource.token-type
    指定当使用userInfoUri时,发送的token类型.
  • security.oauth2.resource.user-info-uri
    指定user info的URI
  • security.oauth2.sso.filter-order
    如果没有显示提供WebSecurityConfigurerAdapter时指定的Filter order.
  • security.oauth2.sso.login-path
    跳转到SSO的登录路径默认为/login.
  • security.require-ssl
    是否对所有请求开启SSL,默认为false.
  • security.sessions
    指定Session的创建策略(always, never, if_required, stateless).
  • security.user.name
    指定默认的用户名,默认为user.
  • security.user.password
    默认的用户密码.
  • security.user.role
    默认用户的授权角色.

 

转自https://segmentfault.com/a/1190000004309242

linux命令du查看目录和文件大小

du -ah –max-depth=1 这个是我想要的结果 a表示显示目录下所有的文件和文件夹(不含子目录),h表示以人类能看懂的方式,max-depth表示目录的深度。

du命令用来查看目录或文件所占用磁盘空间的大小。常用选项组合为:du -sh

一、du的功能:`du` reports the amount of disk space used by the specified files and for each subdirectory (of directory arguments). with no arguments,`du` reports the disk space for the current directory。

很明显,与df不同,它用来查看文件或目录所占用的磁盘空间的大小。

二、du常用的选项:

-h:以人类可读的方式显示

-a:显示目录占用的磁盘空间大小,还要显示其下目录和文件占用磁盘空间的大小

-s:显示目录占用的磁盘空间大小,不要显示其下子目录和文件占用的磁盘空间大小

-c:显示几个目录或文件占用的磁盘空间大小,还要统计它们的总和

–apparent-size:显示目录或文件自身的大小

-l :统计硬链接占用磁盘空间的大小

-L:统计符号链接所指向的文件占用的磁盘空间大小

一、du -h:这个就不多说了。

二、du -a:使用此选项时,显示目录和目录下子目录和文件占用磁盘空间的大小。

可以看出,默认情况下du只显示download目录占用磁盘空间的大小,而使用-a选项后,它不仅显示了目录(最后一行),而且显示了目录下各个文件占用磁盘空间的大小。

三、du -s:使用此选项时,du只显示目录所占用磁盘空间的大小,而不显示其下子目录和文件占用磁盘空间的信息。

默认情况下,du不显示目录下文件占用磁盘空间的信息,但它会显示其下子目录占用磁盘空间的信息;而使用-s选项以后,只显示xx目录占用磁盘空间的大小。

四、du –apparent-size:显示文件或目录自身大小,而不是它们占用的磁盘空间大小。文件或目录占用磁盘空间的大小与它们自身大小有时候并非完全一致;这种现象非linux所独有,windows里也是如此。我们看这个选项的帮助文档的解释:The apparent size of a file is the number of bytes reported by `wc –c` regular files ,or more generally, `ls –l –block-size=1` or `stat –format=%s`.For example, a file containing the word `zoo` with no newline would, of course, have an apparent size of 3. Such a small file may require anywhere from 0 to 16 kib or more of disk space, depending on the type and configuration of the file system on which the file resides.

这段话给出了文件或目录自身大小与占用磁盘空间大小的区别。他下面举出了一个更加夸张的例子,这里就不把它写出来了。我们知道了:wc或ls –block-size显示的是其自身大小,而du给出的则是占用的磁盘空间的大小。

五、du -c:使用此选项时,不仅显示几个文件或目录各自占用磁盘空间的大小,还统计它们的总和。

如图所示,加上-c选项后,du不仅显示两个目录各自占用磁盘空间的大小,还在最后一行统计它们的总和。

六、du -l:这个选项主要是针对硬链接。在统计目录占用磁盘空间大小时,-l选项会把硬链接也统计进来。帮助文档是这样解释的:Count the size of all files,even if they have appeared already(as a hard link)。

我们在download目录下建立一个硬链接,指向本目录下的一个文件。不使用-l选项时,du发现硬链接指向本目录下的文件,于是自动忽略该链接文件,以免造成重复统计;使用-l选项,du才会把硬链接文件也统计进来。

七、du -L:这个选项主要是针对符号链接。它会把符号链接所指向的文件占用磁盘空间的大小也统计进来。帮助文档是这样解释的:Dereference symbolic links(show the disk space used by the file or directory that the link points to instead of the space used by the link)。

我们在download目录下创建一个符号链接,指向本目录下的一个文件。我们看到上面图片中显示的操作结果,当使用-L选项时,du会把符号链接所指向的文件的大小也统计到目录里来。

另外我们看du -lh的结果,与du -h相同,好像没有统计出符号链接的大小;其实并非如此。从实际操作来看,符号链接本身似乎并不占用磁盘空间,所以才出现上述情况。

最后,du命令在统计目录占用磁盘空间时,默认不统计链接文件(无论是硬链接或是符号链接),所以要用-l和-L选项特地指出来;此外,du命令默认不显示目录下文件占用磁盘空间的信息,但是却默认显示其下子目录所占用磁盘空间的信息。怪哉。

du -sh : 查看当前目录总共占的容量。而不单独列出各子项占用的容量

du -lh –max-depth=1 : 查看当前目录下一级子文件和子目录占用的磁盘容量。

11819202122114
 
Copyright © 2008-2021 lanxinbase.com Rights Reserved. | 粤ICP备14086738号-3 |