首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

挖洞经验 | 发现Lucee 0day漏洞RCE掉三个苹果公司网站

失败尝试 imgProcess.cfm文件中的远程代码执行漏洞(RCE) 为了模拟苹果网站中的运行环境,我们在本地安装了相同版本的Lucee。...所以,上述方法函数在传递文件file=/../../../context/pwn.cfm的同时,就会创建目录,可以对网站webroot根目录进行遍历,就形成了一个简单的RCE漏洞通道。...然而,即使我们可以在服务器中任意位置创建任意内容(如.txt)的文件,但是,之后的测试证明,我们可以在其文件名上做点手脚,形成漏洞利用。...那也就是说,之后,我们就可以在dataDir参数帮助下,通过在服务器任意位置目录下,实现对searchindex.cfm file文件中的CFML标签(类似PHP标签)的控制,那也即,我们就可能通过控制网站服务器的根目录...一旦我们的zip压缩格式文件创建在了网站服务器中,那么就能利用luceeArchiveZipPath变量中的zip://协议去请求其中包含..cfm文件的ZIP格式存档了。

92110

在Koa.js中实现文件上传的接口

文件上传是一个基本的功能,每个系统几乎都会有,比如上传图片、上传Excel等。那么在Node Koa应用中如何实现一个支持文件上传的接口呢?...npm install koa koa-router 设置图片上传目录,把图片上传到指定的目录中,在 app 路径下新建 public 文件夹,目录结构如下: koa-upload/ --app ---...使用 koa-static 中间件生成图片链接 直接返回图片的本地路径在实际上是没什么用的,我们应该返回一个http链接的图片地址,点击地址就可以查看图片。...安装:npm install koa-static 并注册到 app 上,我们把他注册在 koaBody 中间件的前面,把 public 设置为静态文件目录。...,我们实际工作中这样的代码可能已经不常见了,action 就是我们的提交到的接口,enctype="multipart/form-data" 就是指定上传文件格式。

4.8K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    ColdFusion - Getting Started

    关于变量名称 特殊: 关于井号#的使用 Loop Basic Loop Syntax 关于变量名称 不能用数字开始 不能包含空格 不能使用除去下滑线以外的特殊符号 大小写不敏感 特殊: 关于井号...#的使用 标记函数和变量的时候需要用到井号 输入两个连续的井号(##)就表示一个单个井号(#) Loop Basic Loop Syntax <cfloop index="parameter name...query name" startRow = "row number" endRow = "row number"> Example 从 cc_TEST 表中搜索前十个数据..., 放到 TEST 的 之中 几个需要注意的地方: 循环里面直接使用对应的列名就可以 在 的 query 属性中不需要添加井号 在 <cfloop...逻辑运算符 AND PR XOR: 异或, 其一为 true 而不能同时为 true EQV: 等价, 两个条件相同时返回 true IMP: 蕴含, 第一个条件为 true, 第二个条件为 false

    47560

    如何使用FindFunc在IDA Pro中寻找包含指定代码模式的函数代码

    关于FindFunc  FindFunc是一款功能强大的IDA Pro插件,可以帮助广大研究人员轻松查找包含了特定程序集、代码字节模式、特定命名、字符串或符合其他各种约束条件的代码函数。...简而言之,FindFunc的主要目的就是在二进制文件中寻找已知函数。  使用规则过滤  FindFunc的主要功能是让用户指定IDA Pro中的代码函数必须满足的一组“规则”或约束。...FindFunc随后将查找并列出满足所有规则的所有函数。...格式将规则存储/加载到文件; 6、提供了用于实验的单独选项页; 7、通过剪贴板在选项页之间复制规则(格式与文件格式相同); 8、将整个会话(所有选项页)保存到文件; 9、指令字节的高级复制;  工具要求...文件拷贝到IDA Pro的插件目录中即可。

    4.2K30

    如何解决在DLL的入口函数中创建或结束线程时卡死

    可在工程文件中做如下处理: ?...其中 DllProc 是SysInit中的全局变量,可简单理解为保存DLL Entry Point入口函数的地址(实际上RTL内部还有InitLib 和StartLib函数,由编译器自动处理)。...以上都是题外话,本文主要说明在DLL入口函数里面创建和退出线程为什么卡死和如何解决的问题。...1)在 DLL_PROCESS_ATTACH 事件中 创建线程 出现卡死的问题 通常情况下在这事件中仅仅是创建并唤醒线程,是不会卡死的,但如果同时有等待线程正式执行的代码,则会卡死,因为在该事件中...解决办法同样是避免在 DLL_PROCESS_DETACH事件中结束线程,那么我们可以在该事件中,创建并唤醒另外一个线程,在该新的线程里,结束需要结束的线程,并在完成后结束自身即可。

    3.8K10

    在 TypeScript 中,如何导入一个默认导出的变量、函数或类?

    在 TypeScript 中,如何导入一个默认导出的变量、函数或类?...在 TypeScript 中,如果要导入一个默认导出的变量、函数或类,可以使用 import 关键字结合 default 关键字来引用默认导出的成员。.../file'; customFunction(); // 调用默认导出的函数 在上述代码中,import 语句使用 default 关键字引入了 file.ts 文件中的默认导出的函数。...在 TypeScript 中,如何在一个文件中同时导出多个变量或函数? 在 TypeScript 中,使用 export 关键字来同时导出多个变量或函数。有几种常见的方式可以实现这一点。...方式一:逐个导出 在一个文件中逐个使用 export 关键字导出每个变量或函数。

    1.1K30

    如何使用Mantra在JS文件或Web页面中搜索泄漏的API密钥

    关于Mantra Mantra是一款功能强大的API密钥扫描与提取工具,该工具基于Go语言开发,其主要目标就是帮助广大研究人员在JavaScript文件或HTML页面中搜索泄漏的API密钥。...Mantra可以通过检查网页和脚本文件的源代码来查找与API密钥相同或相似的字符串。这些密钥通常用于对第三方API等在线服务进行身份验证,而且这些密钥属于机密/高度敏感信息,不应公开共享。...除此之外,该工具对安全研究人员也很有用,他们可以使用该工具来验证使用外部API的应用程序和网站是否充分保护了其密钥的安全。...总而言之,Mantra是一个高效而准确的解决方案,有助于保护你的API密钥并防止敏感信息泄露。 工具下载 由于该工具基于Go语言开发,因此我们首先需要在本地设备上安装并配置好Go语言环境。

    31120

    如何使用EvilTree在文件中搜索正则或关键字匹配的内容

    但EvilTree还增加了在文件中搜索用户提供的关键字或正则表达式的额外功能,而且还支持突出高亮显示包含匹配项的关键字/内容。  ...工具特性  1、当在嵌套目录结构的文件中搜索敏感信息时,能够可视化哪些文件包含用户提供的关键字/正则表达式模式以及这些文件在文件夹层次结构中的位置,这是EvilTree的一个非常显著的优势; 2、“tree...”命令本身就是分析目录结构的一个神奇工具,而提供一个单独的替代命令用于后渗透测试是非常方便的,因为它并不是每一个Linux发行版都会预安装的,而且在Windows操作系统上功能还会有部分受限制。  ...工具下载  由于该工具基于Python 3开发,因此广大研究人员首先需要在本地设备上安装并配置好Python 3环境。...var/www中寻找匹配“password = something”的字符串: 样例二-使用逗号分隔的关键字搜索敏感信息: 样例三-使用“-i”参数只显示匹配的关键字/正则式内容(减少输出内容长度)

    4K10

    关于MATLAB中M文件如何解决“未定义函数或变量”的若干办法

    脚本文件很简单,就是由一堆命令构成的,里面第一行不是 function 开头,这种文件比如是encrypt.m编写好后直接点F5或者运行键运行就行,不存在出现诸如“未定义函数或变量”的问题; 函数文件就相对复杂一些...目录 问题提出 解决办法 情况一:文件路径与系统当前路径不匹配 情况二:函数名与文件名不一致 情况三:命令窗口中直接写函数名 问题提出 在函数文件中,很可能会出现如下图这样的问题: ?...这张图就是文件名与函数名不一致的情况,这也会导致“未定义函数或变量’encrypt’”这种问题的出现,解决办法就是把文件名改成“encrypt.m”或者将函数名改为hello(n)即可。...这种情况除非已经在函数文件中定义了函数名才会避免。否则没有函数文件直接写这条命令语句肯定是不可行的。 最后,给出排除了所有报错可能,正确得到运行结果: ? OK!...以上就是关于MATLAB中M文件如何解决“未定义函数或变量”的若干办法的总结。希望能帮助到更多小伙伴! 大家有什么想法或者发现新的问题及解决办法别忘了在评论区告诉我哦! 欢迎评论,感谢阅读! END

    12.3K41

    python接口测试:在一个用例文件中调用另一个用例文件中定义的方法

    简单说明 在进行接口测试时,经常会遇到不同接口间传递参数的情况,即一个接口的某个参数需要取另一个接口的返回值; 在平常写脚本过程中,我经常会在同一个py文件中,把相关接口的调用方法都写好,这样在同一个文件中能够很方便的进行调用...; 后来随着功能增多,在写其他py文件时,有时也会先调用某个相同的接口来获取参数; 如果在每个py文件中都写一遍调用某个接口的方法,会显得很啰嗦,也不好维护,并且以后万一提供数据的那个接口发生变化...,需要调整很多地方; 所以,当我们在一个用例py文件中写好某个接口调用方法,后续如果在其他py文件中也要用到这个接口的返回值,则直接引用先前py文件中定义好的接口调用方法即可。...:CreateActivity, 继承自unittest.TestCase 然后在setUp方法中进行了一些必要的初始化工作 最后创建了一个名为push_file_download的方法,它的作用就是调某个接口...id,这个id就是由test_A.py文件中CreateActivity类下的 push_file_download 方法生成的; 所以这里要先调用push_file_download方法,对应第

    2.9K40

    Linux的环境变量配置在etcprofile或etcprofile.d*.sh文件中的区别是什么?

    @ 目录 login shell non-login shell 它们的区别 Linux的环境变量可在多个文件中配置,如/etc/profile,/etc/profile.d/*.sh,~/.bashrc...等,下面说明上述几个文件之间的关系和区别。...它们的区别 这两种shell的主要区别在于,它们启动时会加载不同的配置文件。 login shell启动时会加载/etc/profile。...但是无论在加载~/.bashrc(实际上是加载了~/.bashrc中的/etc/bashrc)或/etc/profile时,都会执行如下代码片段: ?...所以,无论在login shell或non-login shell环境中,都会加载/etc/profile.d/*.sh文件,这样我们为什么不自定义一个my_env.sh文件用来存放java或者其他的环境变量

    2.5K10

    【DB笔试面试785】在Oracle中,RMAN中关于备份或归档文件状态OBSOLETE和EXPIRED的区别是什么?

    ♣ 题目部分 在Oracle中,RMAN中关于备份或归档文件状态OBSOLETE和EXPIRED的区别是什么? ♣ 答案部分 OBSOLETE:是指根据保留策略来确定该备份是否在恢复的时候需要。...若不再需要或有更新的备份来替代,则该备份集被置为OBSOLETE,即废弃的备份集或镜像副本。OBSOLETE可以理解为过期的备份集。...EXPIRED:是指执行CROSSCHECK时,根据恢复目录或控制文件中记录的备份信息来定位备份集或镜像副本,若找不到对应的文件,则这些文件的状态被置为EXPIRED。...EXPIRED可以理解为失效的备份集,即物理文件丢失。 如果在备份过程中,归档文件被手动通过rm命令删除,那么会报错:RMAN-06059。...解决办法就是在RMAN中校验归档文件后再删除失效的归档文件,如下所示: CROSSCHECK ARCHIVELOG ALL; LIST EXPIRED ARCHIVELOG ALL; DELETE EXPIRED

    1.2K10

    Linux之ack命令

    ,比如.svn,.git,CSV等目录 忽略二进制文件(比如pdf,image,coredumps)和备份文件(比如foo~,*.swp) 在搜索结果中打印行号,有助于找到目标代码 能搜索特定文件类型(...相比于搜索速度,ack总体上比grep更快。ack的速度只要表现在它的内置的文件类型过滤器。在搜索过程中,ack维持着认可的文件类型的列表,同时跳过未知或不必要的文件类型。...-h, 不显示名称 -v, 显示不匹配 在当前目录递归搜索单词”eat”,不匹配类似于”feature”或”eating”的字符串: > ack -w eat 搜索有特殊字符的字符串’$path=.’.../etc 除了temp目录,在所有目录搜索use单词 > ack use --ignore-dir=temp 只搜索包含'main'单词的Python文件,然后通过文件名把搜索结果整合在一起,打印每个文件对应的搜索结果...xml/ --[no]yaml .yaml .yml 获取包含CFLAG关键字的Makefile的文件名 > ack --make CFLAG ack查找my.cnf文件 > ack

    1.2K00

    只需在Vim或Neovim编辑器中打开文件,您的Linux就会被黑客攻击

    如果您最近没有更新Linux操作系统,尤其是命令行文本编辑器实用程序,甚至不要尝试使用Vim或Neovim查看文件的内容。...在Linux系统上,Vim编辑器允许用户创建,查看或编辑任何文件,包括文本,编程脚本和文档。...虽然编辑器只允许模型中的一部分选项(出于安全原因),并且如果它包含不安全的表达式,则使用沙盒保护,但Razmjou透露使用“:source!” 命令(使用bang [!]修饰符)可用于绕过沙箱。...因此,只需使用Vim或Neovim打开一个看起来无辜的特制文件,攻击者就可以在Linux系统上秘密执行命令并对其进行远程控制。...Vim的维护者(补丁8.1.1365)和Neovim(在v0.3.6中发布)已经发布了两个实用程序的更新以解决问题,用户应该尽快安装。

    1.7K20

    Linux之ack命令

    忽略二进制文件(比如pdf,image,coredumps)和备份文件(比如foo~,*.swp) 在搜索结果中打印行号,有助于找到目标代码 能搜索特定文件类型(比如Perl,C++,Makefile...相比于搜索速度,ack总体上比grep更快。ack的速度只要表现在它的内置的文件类型过滤器。在搜索过程中,ack维持着认可的文件类型的列表,同时跳过未知或不必要的文件类型。...-h, 不显示名称 -v, 显示不匹配 在当前目录递归搜索单词”eat”,不匹配类似于”feature”或”eating”的字符串: > ack -w eat image.png > ack -Q '.../etc 除了temp目录,在所有目录搜索use单词 > ack use --ignore-dir=temp 只搜索包含'main'单词的Python文件,然后通过文件名把搜索结果整合在一起,打印每个文件对应的搜索结果...xml/ --[no]yaml .yaml .yml 获取包含CFLAG关键字的Makefile的文件名 > ack --make CFLAG ack查找my.cnf文件 >

    1.2K20

    Linux之ack命令

    忽略二进制文件(比如pdf,image,coredumps)和备份文件(比如foo~,*.swp) 在搜索结果中打印行号,有助于找到目标代码 能搜索特定文件类型(比如Perl,C++,Makefile)...相比于搜索速度,ack总体上比grep更快。ack的速度只要表现在它的内置的文件类型过滤器。在搜索过程中,ack维持着认可的文件类型的列表,同时跳过未知或不必要的文件类型。...-h, 不显示名称 -v, 显示不匹配 在当前目录递归搜索单词”eat”,不匹配类似于”feature”或”eating”的字符串: > ack -w eat 搜索有特殊字符的字符串’$path=.’.../etc 除了temp目录,在所有目录搜索use单词 > ack use --ignore-dir=temp 只搜索包含'main'单词的Python文件,然后通过文件名把搜索结果整合在一起,打印每个文件对应的搜索结果...xml/ --[no]yaml .yaml .yml 获取包含CFLAG关键字的Makefile的文件名 > ack --make CFLAG ack查找my.cnf文件 > ack

    1.8K00

    将包含数字形式的文本文件导入Excel中时保留文本格式的VBA自定义函数

    标签:VBA Q:有一个文本文件,其内容包含很多以0开头的数字,如下图1所示,当将该文件导入Excel中时,Excel会将这些值解析为数字,删除了开头的“0”。...A:我们使用一个VBA自定义函数来解决。...WorksheetFunction.Transpose(arrayList.ToArray())) arrayList.Clear Set arrayList = Nothing End Function 该函数中...,参数strPath是要导入的文本文件所在路径及文件名,参数strDelim是文本文件中用于分隔值的分隔符。...假设一个名为“myFile.txt”的文件存储在路径“C:\test\”中,可以使用下面的过程来调用这个自定义函数: Sub test() Dim var As Variant '根据实际修改为相应的文件路径和分隔符

    26910
    领券