反涉网犯罪研究 | 电商平台自动收货代码审计

news2024/11/30 8:39:23

0x00 免责声明

        本文仅限于学习讨论与反诈知识的分享,不得违反当地国家的法律法规。对于传播、利用文章中提供的信息而造成的任何直接或者间接的后果及损失,均由使用者本人负责,本文作者不为此承担任何责任,一旦造成后果请自行承担!

        

        

0x01 前言

        最近在某社交平台上看到一个求助帖,大致内容是:一名博主在电商平台下单了一个电子产品,卖家谎称快递员上门取件需要对这个电子产品设置保价,在平台的聊天窗口给博主发送了一个顺丰的二维码。博主无法通过电脑点击链接,于是使用手机点击二维码后,弹出了一个平台的快递保价二维码。如果快递员上门取件要设置保价似乎也很合理,并且这个链接确实是快递平台官网的保价系统。结果,刚支付完保价金额 5 元后,发现刚买的电子产品还没到手却被系统提示收货成功。这时博主才意识到事情的不对劲,试图退款时发现卖家已消失。

        

        

0x02 行为分析

        为了帮助读者今后可以更好地判断和预防新型网络诈骗手段。以下通过详细的行为分析,对电商平台自动收货的诈骗行为深入了解,让读者对新型网络诈骗起到防范意识。

        

        网络钓鱼(Phishing)是社会工程学的一种。类似于现实中的钓鱼,攻击者伪装成可信任的发件人,向受害者发送具有欺骗性质的消息,设下“诱饵”,诱导受害者点击恶意链接,并在攻击者仿冒的网页上提供敏感数据。利用获取到的信息,攻击者可以直接通过交易受害者的个人数据牟取经济利益,或借此发动下一步网络攻击。攻击者也有可能在钓鱼信息中附有恶意软件,在受害者在打开钓鱼信息的恶意附件后,攻击者的恶意软件就可趁虚而入,在受害者的系统中运行。除此之外,攻击者也可能误导受害者将资金或资产错误地转移给他人。

        

       博主就是被诈骗分子发送的恶意链接诱导点击,从而被骗。查看诈骗手段行为流程图可以看到受害者行为。先进行下单,下单成功后会向电商平台返回支付数据 。这时电商平台接到数据后会向卖家(诈骗分子)发送下单成功的订单号。诈骗分子通过获取待发货的订单号,发送到诈骗系统后台,生成一个链接或者二维码。访问这个链接或者二维码便会跳转到诈骗分子伪造的快递平台的商品保价程序。

诈骗手段行为流程图

        

        这种传播方式十分广泛,一个诈骗分子可以教唆或诱导多名潜在违法者。通过诈骗程序后台生成一个钓鱼链接或者是钓鱼二维码,组织犯罪传播给潜在违法者以及有犯罪意图的人。这些人在电商平台上发布价格远低于同类产品的商品,以引诱买家贪图低成本购买的心理。使用一些看似合理的话术诱导买家点击钓鱼链接或者二维码。这时,如果买家点击链接支付了保价金额,那么就会提示收货成功。

诈骗传播方式树结构图

        

        

0x03 代码分析

         分析不法分子发送的链接,检查源代码中发现一段 JS 代码,使用了自执行函数,这个方法可以立即执行函数中的内容。在 JS 代码中,函数可以作为参数传递给其他函数。代码中添加了 ready 函数可以让买家点击钓鱼链接或者钓鱼二维码后可以自动执行其中的代码块。

        第三行的代码逻辑就是,伪造快递平台的网页中有一个点击按钮,当买家点击支付按钮时,代码中注册的 CSS 点击事件监听器就会被触发。那么接下来就可以看到代码的核心部分开始运行。​

(function() {
  ready(function() {
    document.querySelector('.tradeno').addEventListener('click', function() {
      AlipayJSBridge.call("tradePay", {
        tradeNO: "0000000000000000000000000000"  //此参数为支付宝交易号
      }, function(result) {
        //处理支付结果
      });
    });
  });
})();

        

        AlipayJSBridgeReady , window.onload 以后,容器会初始化,产生一个全局变量 AlipayJSBridge ,然后触发此事件 AlipayJSBridge 注入是一个异步过程,因此尽可能先监听该事件后再call接口。强烈建议换用 alipayjsapi 来简化 JSAPI 调用。

        这部分便是问题所在,这是支付宝内部的接口调用。我们可以通过查看支付宝的 H5 开放文档,文档中的代码需要确定 JS 代码是否准备就绪。如果 AlipayJSBridge 事件已触发,则直接执行回调;如果尚未触发,则等待注入事件触发后执行回调。

function ready(callback) {
  // 如果jsbridge已经注入则直接调用
  if (window.AlipayJSBridge) {
    callback && callback();
  } else {
    // 如果没有注入则监听注入的事件
    document.addEventListener('AlipayJSBridgeReady', callback, false);
  }
}

        

        

0x04 my.tradePay简介

        在源代码中核心部分有这么一段代码,就是 tradeNO:"..." 。根据官方文档: my.tradePay 是用于发起支付的 API 。此 API 暂仅支持企业支付宝小程序使用。

tradeNO: "0000000000000000000000000000"

        

常见问题 FAQ

Q:web-view 中如何进行支付?

A:web-view 中也可以通过 my.tradePay API 进行支付,不支持 H5 网页支付。

        上述内容为官方文档的常见问题解释说明,这也就可以解释为什么在电脑端无法访问不法分子发送的诈骗链接,使用此 API 调用支付接口时不支持 H5 网页支付。因为 my.tradePay 是支付宝内部定义的一个 API 接口。在任何非支付宝软件内调用 API 都是无效的,通过在支付宝小程序中操作似乎也增加了合理性,让买家用户认为这是支付宝内部的支付程序,并不是第三方的诈骗程序。

        

参数类型:

Object 类型,参数如下:

参数类型必填描述
tradeNOString否(调用小程序支付时必填)接入小程序支付时传入此参数。此参数为支付宝交易号,注意参数有大小写区分。
orderStrString否(调用支付宝预授权时必填)完整的支付参数拼接成的字符串,从服务端获取。
successFunction调用成功的回调函数。
failFunction调用失败的回调函数。
completeFunction调用结束的回调函数(调用成功、失败都会执行)。

表格来源于[支付宝文档中心/my.tradePay]​

        

         也就是说,诈骗分子将用户下单的交易订单号传入此参数中,点击二维码支付保价金额时,就会调用这个支付宝内部的 API 接口。一旦买家支付成功,根据交易订单号就会判定买家已收货,并将钱款打给诈骗分子。

      AlipayJSBridge.call("tradePay", {
        tradeNO: "0000000000000000000000000000"
      }, function(result) {
        //处理支付结果

        

        

0x05 防范措施

需要有警惕心理,不轻信不盲从。对于卖家发送不明来源的信息、链接或要求要时刻警惕。如果实在无法辨别可以联系平台客服确认进行协助辨认。

切记只在平台内交易,不进入第三方沟通,同时可以检查对方身份信用程度,尽量避免购买信用程度较差的卖家产品。

如果发现任何可疑行为或受到钓鱼诈骗的损失,请及时向相关平台报告,并向当地的监管部门提交证据材料报案,申请协助调查。

        

        

0x06 参考文献

[1].朱思邈. 什么是网络钓鱼?[EB/OL]. [2023-05-15]. https://info.support.huawei.com/info-finder/encyclopedia/zh/%E7%BD%91%E7%BB%9C%E9%92%93%E9%B1%BC.html.

[2].Sugobet. 闲鱼/支付宝 自动收货诈骗套路分析[EB/OL]. [2023-05-15]. https://blog.csdn.net/qq_54704239/article/details/130522387.

[3].支付宝H5开放文档. AlipayJSBridgeReady[EB/OL]. [2023-05-15]. https://myjsapi.alipay.com/jsapi/events/alipay-js-bridge-ready.html.

[4].支付宝文档中心. my.tradePay[EB/OL]. [2023-05-15]. https://opendocs.alipay.com/mini/api/openapi-pay#function%20anchor()%20{%20[native%20code]%20}.

        

        

0x07 总结

罪犯无孔不入,警惕不可放松。由于作者水平有限,文中若有错误与不足欢迎留言,便于及时更正。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/527898.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

信息发布系统在医院体检中心的运用

随着生活水平条件的提高,大家的健康意识更加强,重视体检的人数也越来越多,因此体检中心,医院体检门诊中心人流量都很大,健康市场空间前景大,各种医疗健康机构快速发展,市场竞争激烈,…

Linux——互斥和同步(二)

目录 信号量 读写信号量 互斥量 RCU机制 虚拟串口驱动加入互斥 完成量 习题 信号量 前面所讨论的锁机制都有一个限制,那就是在锁获得期间不能调用调度器,即不能引起进程切换。但是内核中有很多函数都可能会触发对调度器的调用(在中断的…

Win10笔记本开机黑屏出现白色错误英文无法启动怎么办?

Win10笔记本开机黑屏出现白色错误英文无法启动怎么办?有用户电脑正常开机之后,出现了问题,系统无法正常的启动,出现一些英文错误代码。那么遇到这个情况怎么去进行解决呢?一起来看看以下的解决方法分享吧。 准备工作&a…

C语言数据结构注意点-线性表

目录 关于指针 LinkList L和LinkList *L的区别 初始化注意点 scanf()的操作 顺序表相关操作符号的确定 关于指针 ①指针和指针变量是两个不同的概念,但要注意的是,通常我们叙述时会把指针变量简称为指针。 ②指针变量其实是一个变量&…

FL Studio21中文完整版All Plugins Edition及切换教程

说到制作电音的软件,coco玛奇朵一定会把FL Studio放到第一个来讲。水果是一款为了电子音乐而生的的宿主软件。水果,独特的节拍音序器组件和通道机架与混音台模块打造的编曲“块”的思路。是极为适合于电子音乐的编排。而且随着水果版本不断地升级&#x…

Vite的基本介绍以及优劣势(一文读懂vite)?

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 一、Vite是什么?二、为什么选Vite?1、现实的问题2、缓慢的服务器启动3、缓慢的更新 三、Vite的优势?四、Vite的劣势?五、Vite以…

深入理解双亲委派机制

一、双亲委派机制委派流程 双亲委派机制,就是JVM虚拟机加载类的时候,会优先委派上级类加载器进行类加载。 1、如果上级类加载器能找到这个类,那就由上级类加载器加载,并且对下级共享,反之不共享。 2、如果上级类加载…

【#ifndef, #define, 和 #endif】

前言 学习AFNetWoring源码的时候,在AFN的h借接口文件又看到了这几个宏定义,学习记录一下。 作用 #ifndef, #define, 和 #endif是C/CPP的预处理指令,常常用来条件编译和防止头文件重复包含。 简介 #ifndef 它是if not define的简写&…

SpringBoot 使用 Sa-Token 完成注解鉴权功能

注解鉴权 —— 优雅的将鉴权与业务代码分离。本篇我们将介绍在 Sa-Token 中如何通过注解完成权限校验。 Sa-Token 是一个轻量级 java 权限认证框架,主要解决登录认证、权限认证、单点登录、OAuth2、微服务网关鉴权 等一系列权限相关问题。 Gitee 开源地址&#xff1…

生信步骤|EffectorP批量预测病原物效应子

EffectorP软件利用机器学习原理,通过事先收集已知的效应子制备训练集,从而实现病原真菌和卵菌的效应子预测[1]。 EffectorP发展史[2]: 1.0版本最初在16年发表于NEW PHYTOLOGIST,实现了机器学习初步预测效应子。 2.0版本在18年发表…

OPPO官宣:哲库解散,哲库是 OPPO 旗下的芯片厂,类似华为海思的角色,有近 3000 名员工

大家好,我是二哥呀。 这两天,互联网最大的声音之一就是,OPPO 将终止芯片业务,相信大多数小伙伴和二哥一样,第一眼看到这则消息的时候,震惊的同时并惋惜! ZEKU 是 OPPO 旗下的芯片厂&#xff0…

Java面试知识点(全)-JVM面试知识点

Java面试知识点(全) 导航: https://nanxiang.blog.csdn.net/article/details/130640392 注:随时更新 JVM内存结构 内存结构 Java虚拟机在运行程序时会把其自动管理的内存划分为以上几个区域,每个区域都有的用途以及创建销毁的时机&#xf…

【JavaScript】手写Promise

🐱 个人主页:不叫猫先生 🙋‍♂️ 作者简介:2022年度博客之星前端领域TOP 2,前端领域优质作者、阿里云专家博主,专注于前端各领域技术,共同学习共同进步,一起加油呀! &am…

五. AMS实践,Hook启动未注册的Activity

Activity任务栈解析 正常情况下我们的app中的所有Activity都是运行在同一个任务栈(ActivityStack)里面的,也就是我们app的build.gradle文件中的applicationId那个任务栈. 如何实现Activity运行在不同的任务栈呢? 需要在Intent启动这个Activity的时候,给这个intent赋值,设置代…

【KVM虚拟化】· 存储池、存储卷

目录 🍁虚拟磁盘文件 🍂基于文件系统的KVM存储 🍂基于设备的KVM存储 🍁使用KVM存储池 🍂存储池概念 🍁virsh中存储池命令 🍁virsh中存储卷命令 🍁命令实例 🍂创建存储池 …

一个开源的即时通讯应用 Tailchat

今天给大家介绍一款即时通讯应用,这个开源项目是:Tailchat,它是一个基于 React Typescript 的现代开源 noIM 应用程序。 简单介绍 相信大家都或多或少了解过 Discord / Slack 这样大火的即时通讯应用。两者分别在各自的领域有很大的成就。…

http强缓存和协商缓存的介绍和应用案例,简介明了

http强缓存和协商缓存的介绍和应用案例,简介明了 http缓存方式简介缓存机制案例1. Expires老版本的方式:2. cache-control新版本的方式:3.Etag和If-None-Match http缓存方式简介 强缓存:强缓存使用Expires(老版本&…

el-table实现可编辑表格的思路;el-table删除不正确:表格中的el-select下拉数据项有值,但输入框中value值不显示

目录 一、问题 二、原因及解决方法 三、总结 tips:如嫌繁琐,直接看总结即可! 一、问题 el-table实现可编辑表格的思路: 1.要写一个可编辑的表格:表格中的一列是下拉框。实现方法很简单:在el-table-column(elemen提…

PMP课堂模拟题目及解析(第9期)

81. 一位经验丰富的项目经理在到达一个重大开发里程碑之前识别到一个问题,项目经理采取相应的行动,并能够按时解决问题。两周后,发起人通知项目经理,客户发出了处罚费。若要避免这个问题,项目经理应该事先做什么&…

FGX Native 1.4.1.1 For Delphi Crack

FGX Native 1.4.1.1 For Delphi Crack FGX Native Network Frame是制造跨平台和现代移动设备的强大工具。FG开发团队的主要目标是简化移动应用程序的开发,使大多数人都能以各种技能开发应用程序。此外,这种形式的网络最重要的功能可以在100%的用户界面中…