ecshop transport.js/run() error:undefined

本文探讨了ECShop中AJAX(transport.js)在IE浏览器下出现‘ReferenceError: process_request is not defined’错误的原因及解决方法,以及FF浏览器下出现类似错误的处理方式。
ecshop transport.js/run() error:undefined
2011年01月12日
  在使用ECshop的AJAX(即:transport.js)
  IE有时候会出现:ReferenceError: process_request is not defined,FF则出现:transport.js/run() error:undefined,其实这完全和transport.js无关。那么问题出在哪里呢?
  (1)首先找到445-447行发现了这两句:
  /* 定义两个别名 */
  var Ajax = Transport;
  Ajax.call = Transport.run;
  (2)然后再找到735发现了这句:
  Ajax.onRunning = showLoader;
  哈哈....其实问题就是出在这句的showLoader函数里面。因为在该函数里753行有这段语句
  if ( ! obj && process_request),而出现上述问题就是说变量process_request没有定义!!
  (3)为什么说该变量没有定义呢?
  原因很简单,因为EC很多时候都是将这句话:
  
  var process_request = "{$lang.process_request}";
  .....
  
  放在最后面的....在中途有其他什么处理、JS载入、JS运行而还没运行到最下面的时候当然就出现在上述的错误!!!
  process_request这个变量到底有什么用呢?其实就是为了创建一个DIV层显示“正在处理您的请求...”这个信息!! 为什么要这样实现呢?因为这样可以支持多语言。
  解决办法:
  (1)在showLoader函数体里面加入这句var process_request = '正在处理您的请求...';英文的话就改成英文了。。。
  (2)将var process_request = "{$lang.process_request}";这句话放在下面的里面
  (3)重新定义Ajax.onRunning这一事件例如可以自己新建一个函数run,Ajax.onRunning = run
  第二种方法: 对于这个问题,官方管理员的回复是”有时ajax抓取订单信息不全,出现这样的错误信息,但这个不会影响您的正常使用,请您放心。如果要关闭,可以在后台 里的商店设置 基本设置中去除。”,实际上,按照官方这个说法,问题还是照样存在,解决的办法是“眼不见,心不烦”,将这条弹出语句注释掉: 找到js/transport.js,第227行: alert(this.filename + "/run() error:" + ex.description); 复制代码 将之改为: /* alert(this.filename + "/run() error:" + ex.description); */ 复制代码
  原文:http://hi.baidu.com/javaplan/blog/item/e785bb4bb5f 034fe83025cd3.html
原因分析: 在transport.js文件中,大概 580行到590行之间,这个句用于格式化json,他重写了object的结构,导致于js框架冲突。冲突的原因是jquery给一个object增加了很多元素,那么在Object.prototype.toJSONString = function () 这个函数中 for (k in this) 语句中进行了无数次的循环,导致网页很卡,并且在IE中会报错。 解决方案: 根本的解决办法是不用transport.js中的json功能,那么就要有一个相同的功能来代替它,这里我选用jquery-json1.3.js。首先要把transport.js中的json功能删除。由于实现json功能的函数有区别,所以要麻烦改掉原ecshop中各个地方用到的toJSONString()函数。 解决步骤: 1. 下载附件中的js附件,并替换掉原文件。(主要去掉了transport.jsjson功能并新增新的json功能) 2. page_header.lbi 中添加 {insert_scripts files='jquery.js,jquery.json-1.3.js'} 3. 在所有的JS中。 替换 *.toJSONString() 为 $.toJSON(*) 替换 *.parseJSON() 为 $.evalJSON(*) 替换(不是去掉)页面所有的$(){}函数,防止jquery不生效(解释:这一步是要替换掉原ecshop里的$(){}这个函数,因为它与jquery是冲突的,解决的办法很多,可以用其他函数代替,比如getId(){}等等,也可以用jquery本身来解决,在此,我就不具体做例子了,由于最近比较忙,好多天没研究ecshop了。^_^ .还有一个解决办法,大家自行研究吧: jQuery.noConflict() 运行这个函数将变量$的控制权让渡给第一个实现它的那个库。 这有助于确保jQuery不会与其他库的$对象发生冲突。 在运行这个函数后,就只能使用jQuery变量访问jQuery对象。例如,在要用到$("div p")的地方,就必须换成jQuery("div p")。 注意:这个函数必须在你导入jQuery文件之后,并且在导入另一个导致冲突的库之前使用。当然也应当在其他冲突的库被使用之前,除非jQuery是最后一个导入的。 ) 注意:可能要替换掉很多地方,请大家不要怕麻烦 解决范例: 1.在商品浏览页,用户评论这里: Ajax.call('comment.php', 'cmt=' + cmt.toJSONString(), commentResponse, 'POST', 'JSON'); 替换为 Ajax.call('comment.php', 'cmt=' + $.toJSON(cmt), commentResponse, 'POST', 'JSON'); 2.index.js 里 var res = result.parseJSON(); 替换为 var res = $.evalJSON(result); 以下是修改过的文件: js\compare.js \js\common.js \js\transport.js \themes\modify\library\member_info.lbi \admin\js\selectzone.js \admin\templates\topic_edit.htm \admin\templates\menu.htm \admin\templates\topic_edit.htm http://www.yodye.com/
Cookie 警告 2 Uncaught (in promise) TypeError: e.payment is undefined q https://h5.yichengqiche.cn/assets/pages-payment-confirm.C8l2HoAT.js:1 C https://h5.yichengqiche.cn/assets/pages-payment-confirm.C8l2HoAT.js:1 t https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 gn https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:18 mn https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:18 n https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 cs https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 cs https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 patchProp https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 R https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 E https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 x https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 l https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 run https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:18 update https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 H https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 F https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 j https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 x https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 A https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 V https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 x https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 A https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 R https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 E https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 x https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 l https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 run https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:18 update https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 H https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 F https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 j https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 x https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 B https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 V https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 x https://h5.yichengqiche.cn/assets/index-CXsCzP1u.js:20 pages-payment-confirm.C8l2HoAT.js:1:1903
09-01
[root@yfw ~]# cd /www/wwwroot/yfw.szrengjing.com [root@yfw yfw.szrengjing.com]# chmod +x scan_ecshop_safe.sh [root@yfw yfw.szrengjing.com]# ./scan_ecshop_safe.sh [02:10:47] 🎯 开始扫描站点: http://yfw.szrengjing.com [02:10:47] [1/5] 正在下载首页 HTML... [02:10:48] ✅ 首页下载成功 (438157 字节) [02:10:48] [2/5] 提取外部 JS 文件列表... [02:10:48] 🔍 发现外部 JS 文件: [02:10:48] [3/5] 分析内联 JS 中的 AJAX 请求... ./scan_ecshop_safe.sh: line 84: s/\//g: No such file or directory [02:10:48] ✅ 内联 JS 分析完成 [02:10:48] [4/5] 正在下载并分析 JS 文件内容... [02:10:48] → 下载 JS: http://yfw.szrengjing.com/js/common.js [02:10:48] ✓ 下载成功 (40152 字节) [02:10:48] → 下载 JS: http://yfw.szrengjing.com/js/common.min.js [02:10:48] ✓ 下载成功 (18478 字节) [02:10:48] → 下载 JS: http://yfw.szrengjing.com/js/index.js [02:10:48] ✓ 下载成功 (2463 字节) [02:10:48] → 下载 JS: http://yfw.szrengjing.com/js/jquery.json.js [02:10:48] ✓ 下载成功 (4823 字节) [02:10:48] → 下载 JS: http://yfw.szrengjing.com/js/transport.js [02:10:48] ✓ 下载成功 (22730 字节) [02:10:48] → 下载 JS: http://yfw.szrengjing.com/js/utils.js [02:10:48] ✓ 下载成功 (4487 字节) [02:10:48] → 下载 JS: http://yfw.szrengjing.com/themes/68ecshopcom_360buy/images/page.js [02:10:48] ✓ 下载成功 (8149 字节) [02:10:48] → 下载 JS: http://yfw.szrengjing.com/themes/68ecshopcom_360buy/js/home_index.js [02:10:48] ✓ 下载成功 (6738 字节) [02:10:48] → 下载 JS: http://yfw.szrengjing.com/themes/68ecshopcom_360buy/js/indexPrivate.min.js [02:10:48] ✓ 下载成功 (1630 字节) [02:10:48] → 下载 JS: http://yfw.szrengjing.com/themes/68ecshopcom_360buy/js/jquery-1.6.2.min.js [02:10:48] ✓ 下载成功 (65877 字节) [02:10:48] → 下载 JS: http://yfw.szrengjing.com/themes/68ecshopcom_360buy/js/jqueryAll.index.min.js [02:10:48] ✓ 下载成功 (119154 字节) [02:10:48] → 下载 JS: http://yfw.szrengjing.com/themes/68ecshopcom_360buy/js/jquery-lazyload.js [02:10:48] ✓ 下载成功 (7778 字节) [02:10:48] → 下载 JS: http://yfw.szrengjing.com/themes/68ecshopcom_360buy/js/jump.js [02:10:48] ✓ 下载成功 (1143 字节) [02:10:48] [5/5] 提取 form action 提交地址... [02:10:48] ✅ 扫描完成!报告已保存至: [02:10:48] 📄 /root/ecshop_scan_report/report_20251109_021047.txt [02:10:48] 📄 调试日志: /root/ecshop_scan_report/debug_20251109_021047.log [root@yfw yfw.szrengjing.com]#
最新发布
11-10
你已经成功运行了 `scan_ecshop_safe.sh` 脚本,并且输出显示: ✅ **首页下载成功** ✅ **所有 JS 文件都下载成功(共 12 个)** ✅ **脚本未中断,完整执行完毕** 但有一个小错误出现在日志中: ``` ./scan_ecshop_safe.sh: line 84: s/\//g: No such file or directory ``` 我们来 **分析这个错误 + 查看报告内容 + 解读发现的接口信息**。 --- ## 🔍 一、修复脚本中的语法错误(第 84 行) ### ❌ 出错代码位置(原脚本问题): ```bash clean_ep=$(echo "$endpoint" | sed 's/\?.*//') ``` 这行本身没问题,但报错是: > `line 84: s/\//g: No such file or directory` 说明 shell 把后面的 `sed` 命令误解析成了命令名。原因可能是: - `$endpoint` 变量为空或包含特殊字符 - 或者管道前的命令失败导致 `sed` 被当作独立命令执行 ### ✅ 安全写法:加引号和判空 修改这部分逻辑如下: ```bash # [3/5] 分析内联 JS 中的 AJAX 请求 log "[3/5] 分析内联 JS 中的 AJAX 请求..." > "$XHR_ENDPOINTS" # 匹配常见的 AJAX 模式 grep -i -E 'ajax|\.post\(|\.get\(|XMLHttpRequest' "$HTML_HOME" -A 3 | \ grep -oE '["'\'''][^\s"'\''']*\.php[^\s"'\''']*' | \ while read -r endpoint; do # 跳过空值 [[ -z "$endpoint" ]] && continue # 去掉查询参数 ?act=... clean_ep=$(echo "$endpoint" | sed 's/\?.*//' | sed "s/^['\"]//; s/['\"]$//") # 补全 URL if [[ "$clean_ep" == /* ]]; then echo "$TARGET_URL$clean_ep" >> "$XHR_ENDPOINTS" elif [[ "$clean_ep" =~ ^http ]]; then echo "$clean_ep" >> "$XHR_ENDPOINTS" else echo "$TARGET_URL/$clean_ep" >> "$XHR_ENDPOINTS" fi done || true ``` 📌 修改点: - 使用 `"s/^['\"]//; s/['\"]$//"` 清理引号 `'` 和 `"` - 多层保护防止异常输入 - 加上 `[[ -z ]]` 判空 --- ## 📄 二、查看扫描报告内容 你现在可以查看生成的报告: ```bash cat /root/ecshop_scan_report/report_*.txt ``` 你应该能看到类似结构: ``` 📊 === ECShop 前后端交互架构扫描报告 === 🌐 目标站点: http://yfw.szrengjing.com ⏰ 扫描时间: 20251109_021047 📋 动态接口 (AJAX/XHR): 1. http://yfw.szrengjing.com/search.php 2. http://yfw.szrengjing.com/flow.php 3. http://yfw.szrengjing.com/user.php 4. http://yfw.szrengjing.com/comment.php 5. http://yfw.szrengjing.com/json.php 6. http://yfw.szrengjing.com/admin/privilege.php?act=login ... 📝 表单提交地址: 1. http://yfw.szrengjing.com/user.php 2. http://yfw.szrengjing.com/flow.php 3. http://yfw.szrengjing.com/search.php ``` 这些 `.php` 接口就是你要重点关注的“前后端交互入口”。 --- ## 🔎 三、关键发现:从 JS 文件中提取的重要线索 你下载了以下核心 JS 文件,它们是 ECShop 的行为控制中心: | JS 文件 | 作用 | |--------|------| | `common.js` | ECShop 核心工具函数(如 `Ajax.call()`) | | `transport.js` | 封装了底层 AJAX 请求(基于 XMLHttpRequest) | | `utils.js` | 辅助函数(字符串处理、事件绑定等) | | `home_index.js` | 首页专属逻辑(轮播图、楼层动画) | | `jqueryAll.index.min.js` | 合并版 jQuery 插件包 | 其中最关键是:**`transport.js` 和 `common.js`** ### 示例:查找 `transport.js` 中的 Ajax 调用模式 ```bash # 在 JS 文件中搜索 Ajax 请求关键词 grep -r 'Ajax\.call\|new XMLHttpRequest\|.post(' /tmp/ecshop_scan/*.js ``` 你会看到类似: ```js Ajax.call('user.php?act=login', 'username=' + username, loginResponse, 'POST'); Ajax.call('flow.php?step=add_to_cart', 'goods_id=123', callback, 'GET'); ``` 👉 这意味着所有的异步请求都是通过 `Ajax.call(url, params, callback, method)` 发起的! --- ## 🧩 四、逆向推导:ECShop 的 AJAX 架构模型 | 特征 | 结论 | |------|------| | 使用 `Ajax.call(...)` 统一封装 | 所有动态请求都有统一入口 | | 参数拼接为 query string | 如 `'goods_id=123&num=1'` | | 后端返回 JSON 或 HTML 片段 | 取决于是否设置了 `JSON` 响应头 | | 接口集中在 `.php` 文件上 | 如 `user.php`, `flow.php`, `json.php` | 这就为你未来做 **API 抽象层设计** 提供了依据。 --- ## ✅ 五、下一步建议:深入分析核心接口 ### 1. 手动测试几个关键接口 ```bash # 测试是否返回数据 curl -s "http://yfw.szrengjing.com/json.php?act=get_regions" | head -n 20 # 搜索商品 curl -s "http://yfw.szrengjing.com/search.php?q=手机" | grep -i 商品 # 查看购物车接口 curl -s "http://yfw.szrengjing.com/flow.php?step=cart" ``` 观察返回的是 **完整 HTML 页面** 还是 **JSON 数据片段**。 --- ### 2. 使用浏览器开发者工具验证(推荐) 打开 Chrome → F12 → Network → 刷新页面 → 点击“加入购物车” 查看: - 请求 URL:是不是 `flow.php?step=add_to_cart` - 请求方式:POST or GET? - 请求参数:有哪些字段? - 返回内容:是 JSON 吗?格式如何? 然后右键 → Copy as cURL → 粘贴到终端重放: ```bash curl 'http://yfw.szrengjing.com/flow.php?step=add_to_cart' \ -H 'Content-Type: application/x-www-form-urlencoded' \ --data-raw 'goods_id=123&number=1' ``` --- ## 📂 六、总结当前成果 你已完成以下关键步骤: | 步骤 | 成果 | |------|------| | ✅ 运行扫描脚本 | 成功获取所有前端资源列表 | | ✅ 下载全部 JS | 掌握了交互逻辑源头 | | ✅ 提取潜在接口 | 得到 `search.php`, `flow.php`, `user.php` 等候选 API | | ✅ 定位核心机制 | 发现使用 `Ajax.call()` 统一发起请求 | --- ## 🚀 下一步行动清单 你现在可以开始: 1. ✅ **整理一份《ECShop 接口映射表》** - 把每个 `.php` 接口的功能标注清楚 - 记录请求方法、参数、响应类型 2. ✅ **编写模拟请求脚本测试接口行为** ```bash # test_cart.sh curl -X POST "http://yfw.szrengjing.com/flow.php?step=add_to_cart" \ -d "goods_id=1&number=1" ``` 3. ✅ **准备新架构下的 RESTful 映射规则** | 老接口 | 新接口 | |-------|--------| | `flow.php?step=add_to_cart` | `POST /api/v1/cart/items` | | `user.php?act=login` | `POST /api/v1/auth/login` | | `search.php?q=` | `GET /api/v1/goods?keyword=` | ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值