ECshop 所有系统通用 多货币解决方案
ECShop功能介绍
![ECShop功能介绍](https://img.taocdn.com/s3/m/bd71ce335727a5e9856a614f.png)
指导老师:黄华毕业学校:清远职业技术学院ECShop简介是Comsenz公司推出的一款B2C独立网店系统,现已出售给ShopEX的开发商上海商派网络科技有限公司。
适合企业及个人快速构建个性化网上商店。
系统是基于PHP语言及MYSQL数据库构架开发的跨平台开源程序。
ECShop悉心听取每一位商家的需求与建议,不仅设计了人性化的网店管理系统帮助商家快速上手,还根据中国人的购物习惯改进了购物流程,实现更好的用户购物体验。
经过近两年的发展,ECShop网店系统无论在产品功能、稳定性、执行效率、负载能力、安全性和SEO支持(搜索引擎优化)等方面都居国内同类产品领先地位,成为国内最流行的购物系统之一。
ECShop功能介绍1. 灵活的模版机制ECShop开发了独有的高效模板引擎(2.15以前版本使用smarty模板引擎),并结合了Dreamweaver的模板和库功能,使得编辑制作模板变得更简单。
2. 开放的插件机制支付、配送,会员整合都是以插件形式实现。
商家可以随时增加或变更的支付方式和配送体系。
ecshop支持大部分php开发的论坛系统,包括discuz,phpwind 等,只需在后台做简单参数配置,即可完成会员整合。
3. 功能 AJAX 化ECSHOP 使用目前流行的 AJAX 技术,批量数据编辑变得更迅速,方便。
4. 促销功能ECSHOP提供了积分、红包、赠品,夺宝奇兵等多种促销方法。
5. 高效率的代码和执行性能通过优化代码与数据库结构,配合ecshop独家设计的缓存机制,在不考虑网速的情况下,网店动态页面与纯静态页面访问速度相当。
6. 常规功能的更完善实现针对常规功能尤其是后台管理和购物流程,ECShop进行了更简洁的设计,实现更好的用户体验。
7. 搜索引擎优化在 SEO (搜索引擎优化)上,ECShop独家支持两种 URL 重写方式,并且是同类软件中第一家支持 google/ yahoo / microsoft 三家共同发布的 sitemaps 0.9 网站索引规范,能够为站点被搜索引擎收录做到最大限度的支持和帮助。
5_多货币解方案的开发
![5_多货币解方案的开发](https://img.taocdn.com/s3/m/24c575320b4c2e3f572763da.png)
ecshop多货币解决方案的开发在shop_config表中加入记录INSERT INTO `ecs_shop_config` (`id` ,`parent_id` ,`code` ,`type` ,`store_range` ,`store_dir` ,`value` ,`sort_order`)VALUES (NULL , '1', 'rate', 'text', '', '', '1,0.71,0.69,6.85,1.45', '1'), (NULL , '1', 'ybprice_format', 'text', '', '', '&%s', '1'),(NULL , '1', 'aprice_format', 'text', '', '', 'EUR%s', '1'),(NULL , '1', 'cprice_format', 'text', '', '', '¥%s', '1'),(NULL , '1', 'aoprice_format', 'text', '', '', 'AU%s', '1');修改\languages\zh_cn\admin\shop_config.php文件$_LANG['cfg_name']['rate'] = '货币汇率';$_LANG['cfg_name']['ybprice_format'] = '英镑格式';$_LANG['cfg_name']['aprice_format'] = '欧元格式';$_LANG['cfg_name']['cprice_format'] = '人民币格式';$_LANG['cfg_name']['aoprice_format'] = '澳元格式';$_LANG['cfg_desc']['rate'] = '输入规则按照和美元的汇率进行输入US,EUR,BritishPound,China,Austrilian';$_LANG['cfg_desc']['ybprice_format'] = '显示英镑格式,%s将被替换为相应的价格'; $_LANG['cfg_desc']['aprice_format'] = '显示欧元格式,%s将被替换为相应的价格'; $_LANG['cfg_desc']['cprice_format'] = '显示人民币格式,%s将被替换为相应的价格'; $_LANG['cfg_desc']['aoprice_format'] = '显示澳元格式,%s将被替换为相应的价格';在init.php文件最后插入以下代码$url_this="http://".$_SERVER['HTTP_HOST'].$_SERVER['PHP_SELF']."?id=".@$_GET['id'];//echo $url_this;$smarty->assign("url_head",$url_this);$currency=@$_GET['currency'];if ($currency!=""){$_SESSION['currency']=$currency;}if ($_SESSION['currency']==''){$_SESSION['currency']='USD';}echo $_SESSION['currency'];修改\inlucdes\lib_common.php里的price_format函数/*** 格式化商品价格** @access public* @param float $price 商品价格* @return string*/function price_format($price, $change_price = true){$currency=$_SESSION['currency'];$rate=explode(',',$GLOBALS['_CFG']['rate']);if($currency=='USD'){$price=$price*$rate[0];}if($currency=='CNY'){$price=$price*$rate[3];}if($currency=='EUR'){$price=$price*$rate[1];}if($currency=='GBP'){$price=$price*$rate[2];}if ($change_price && defined('ECS_ADMIN') === false){switch ($GLOBALS['_CFG']['price_format']){case 0:$price = number_format($price, 2, '.', '');break;case 1: // 保留不为 0 的尾数$price = preg_replace('/(.*)(\\.)([0-9]*?)0+$/', '\1\2\3', number_format($price, 2, '.', ''));if (substr($price, -1) == '.'){$price = substr($price, 0, -1);}break;case 2: // 不四舍五入,保留1位$price = substr(number_format($price, 2, '.', ''), 0, -1); break;case 3: // 直接取整$price = intval($price);break;case 4: // 四舍五入,保留 1 位$price = number_format($price, 1, '.', '');break;case 5: // 先四舍五入,不保留小数$price = round($price);break;}}else{$price = number_format($price, 2, '.', '');}switch($currency){case 'USD':return sprintf($GLOBALS['_CFG']['currency_format'], $price); break;case 'EUR':return sprintf($GLOBALS['_CFG']['aprice_format'], $price); break;case 'GBP':return sprintf($GLOBALS['_CFG']['ybprice_format'], $price); break;case 'AUD':return sprintf($GLOBALS['_CFG']['aoprice_format'], $price); break;case 'CNY':return sprintf($GLOBALS['_CFG']['cprice_format'], $price); break;}//return sprintf($GLOBALS['_CFG']['currency_format'], $price);}修改表order_infoALTER TABLE `ecs_order_info` ADD `currency` VARCHAR( 10 ) NOT NULL , ADD `new_money` DECIMAL( 10, 2 ) NOT NULL修改flow.php文件中{//分成功能关闭$parent_id = 0;}$order['parent_id'] = $parent_id;大约1608行左右插入以下代码$order['currency']=$_SESSION['currency'];$order['new_money']=price_format_hs($order['order_amount']);同时修改\inlucdes\lib_common.php在里面新增加price_format_hs函数/*** 用于支付换算** @access public* @param float $price 商品价格* @return string*/function price_format_hs($price, $change_price = true){$currency=$_SESSION['currency'];$rate=explode(',',$GLOBALS['_CFG']['rate']);if($currency=='USD'){$price=$price*$rate[0];}if($currency=='CNY'){$price=$price*$rate[3];}if($currency=='EUR'){$price=$price*$rate[1];}if($currency=='GBP'){$price=$price*$rate[2];}if($currency=='AUD'){$price=$price*$rate[4];}if ($change_price && defined('ECS_ADMIN') === false){switch ($GLOBALS['_CFG']['price_format']){case 0:$price = number_format($price, 2, '.', '');break;case 1: // 保留不为 0 的尾数$price = preg_replace('/(.*)(\\.)([0-9]*?)0+$/', '\1\2\3', number_format($price, 2, '.', ''));if (substr($price, -1) == '.'){$price = substr($price, 0, -1);}break;case 2: // 不四舍五入,保留1位$price = substr(number_format($price, 2, '.', ''), 0, -1); break;case 3: // 直接取整$price = intval($price);break;case 4: // 四舍五入,保留 1 位$price = number_format($price, 1, '.', '');break;case 5: // 先四舍五入,不保留小数$price = round($price);break;}}else{$price = number_format($price, 2, '.', '');}return $price;}在\includes\modules\payment\paypal.php大约92行一个get_code函数,function get_code($order, $payment){$paypal_currency=$_SESSION["currency"]; //新增加的$data_order_id = $order['log_id'];$data_amount = $order['order_amount'];$data_return_url = return_url(basename(__FILE__, '.php'));$data_pay_account = $payment['paypal_account'];$currency_code = $paypal_currency; //把下一行复制出来,并下行注掉,修改为这一行//$currency_code = $payment['paypal_currency'];在/admin/order.php文件里的select语句中加入o.currency,o.new_money,在/admin/templetes/order_list.htm加入相关的内容。
使用ECSHOP软件总结
![使用ECSHOP软件总结](https://img.taocdn.com/s3/m/339d8c595bcfa1c7aa00b52acfc789eb172d9eab.png)
使用ECSHOP软件总结第一篇:使用ECSHOP软件总结工作总结通过在这3天的试用期学习中,我逐步了解了对ECShop软件的使用。
这是一款开源免费的网上商店系统。
ECShop网店系统的优点很多,例如可免费下载、免费使用、免费升级,无使用时间与功能限制。
无论在稳定性、代码优化、运行效率、负载能力、安全等级、功能可操控性和权限严密性等方面都居国内外同类产品领先地位。
ECShop网店系统支持多种类型商品销售,实物商品销售及虚拟商品(如电话卡,游戏点卡等)可在同一个网店中进行管理。
ECShop网店系统提供了灵活强大的模板机制,内置多套免费精美模板,同时可在后台任意更换,让您即刻快速建立不同的网店外观。
同时您可以对网店模板自定义设计,建立个性化网店形象。
ECShop网店系统强大的站内商品搜索引擎,结合Ecshop独有的商品属性可搜索功能,买家在您的网店可以轻松找到所需商品。
ECShop 网店系统整合了现今市面上几乎所有主流第三方支付网关。
等等。
软件的功能强大就意味着熟悉他需要更多的时间和精力,以前在学校里面学习过Dreamweaver的网页制作,但是ECSHOP 和D还是有本质的区别,很多功能找不到,从官网下载的模板也不知道怎么用上去,客户订阅的邮件也发不出去,愿意也找不到,这让我非常的心烦意乱,还好可以和同事交流,上网找资料,才能找到问题解决的办法。
3天的试用期很快就过去了,虽然上班的时间很长,但是学到的东西也很多,我最大的收获就是一万个为什么,要不停的问问题,解决问题。
我不会轻易放弃,虚心的向同事学习,积极的做好分配下来的认为,在工作中学习,在学习中工作,做个称职的创富员工。
第二篇:ECSHOP项目总结ECSHOP项目总结(面试技巧部分)NO1:ECSHOP是一个什么样的系统?(该系统是做什么的,系统架构是怎么样的)ECSHOP是一个基于B/S架构的B2C电子商务系统。
ECSHOP的环境支持Linux和Windows跨平台操作,我们是部署在Windows上的:WindowsServer2003+PHP+Apache+MySQL。
ECSHOP 支付接口
![ECSHOP 支付接口](https://img.taocdn.com/s3/m/7c1284d6c1c708a1284a4473.png)
支付方式名称支付方式描述插件版本插件作者费用排序操作快钱人民币网关快钱是国内领先的独立第三方支付企业,旨在为各类企业及个人提供安全、便捷和保密的支付清算与账务服务,其推出的支付产品包括但不限于人民币支付,外卡支付,神州行卡支付,联通充值卡支付,VPOS支付等众多支付产品, 支持互联网、手机、电话和POS等多种终端, 以满足各类企业和个人的不同支付需求。
截至2009年6月30日,快钱已拥有4100万注册用户和逾31万商业合作伙伴,并荣获中国信息安全产品测评认证中心颁发的“支付清算系统安全技术保障级一级”认证证书和国际PCI安全认证。
点此链接在线签约快钱1.2 ECSHOPTEAM0 安装深发银行-快钱通过快钱帐户,用户可以直接用深发网银支付。
1.0.0 ECSHOPTEAM0 安装工商银行-快钱通过快钱帐户,用户可以直接用工行网银支付。
1.0.0 ECSHOPTEAM0 安装民生银行-快钱通过快钱帐户,用户可以直接用民生网银支付。
1.0.0 ECSHOPTEAM0 安装招商银行-快钱通过快钱帐户,用户可以直接用招商网银支付。
1.0.0 ECSHOPTEAM0 安装建设银行-快钱通过快钱帐户,用户可以直接用建设网银支付。
1.0.0 ECSHOPTEAM0 安装中国银行-快钱通过快钱帐户,用户可以直接用中国网银支付。
1.0.0 ECSHOPTEAM0 安装北京银行-快钱通过快钱帐户,用户可以直接用北京网银支付。
1.0.0 ECSHOPTEAM0 安装交通银行-快钱通过快钱帐户,用户可以直接用交通网银支付。
1.0.0 ECSHOPTEAM0 安装农业银行-快钱通过快钱帐户,用户可以直接用农业网银支付。
1.0.0 ECSHOPTEAM0 安装财付通财付通()- 腾讯旗下在线支付平台,通过国家权威安全认证,支持各大银行网上支付,免支付手续2.0.0 ECSHOPTEAM0 安装即时到账费。
立即免费申请:单笔费率1%立即购买包量套餐:折算后单笔费率0.6-1% 安装中介担保支付宝支付宝网站() 是国内先进的网上支付平台。
ecshop商城系统的100个小问题
![ecshop商城系统的100个小问题](https://img.taocdn.com/s3/m/02b8cb275901020207409c84.png)
查看完整版本: [-- ecshop商城系统的100个小问题--]慈溪论坛-> 『凡人牧场』-> ecshop商城系统的100个小问题[打印本页]登录-> 注册-> 回复主题-> 发表主题hzbjp2009-07-09 20:20 ecshop商城系统的100个小问题自己从事B4C电子商务开发一段时间了,特别对ecshop深有体会,刚接触的时候不容易理解,下面将根据自己的经验,来总结100条关于操作ecshop电子商务系统的小问题。
1:如何修改网站"欢迎光临本店"回答:languages\zh_cn\common.php文件中,$_LANG['welcome'] = '欢迎光临本店';将他修改成你需要的字样。
2:如何修改首页"热门搜索关键字"回答:后台->系统设置->网店设置->显示设置->首页搜索关键字,修改他的内容,然后保存3:如何修改首页标题"Powered by ECShop"回答:includes/lib_main.php,找到$page_title =$GLOBALS['_CFG']['shop_title'] . ' - ' . 'Powered by ECShop';修改成$page_title = $GLOBALS['_CFG']['shop_title']就可以了。
4:如何去除cshop底部查询信息的显示回答:library/page_footer.lbi中,删除 {insert name='query_info'}5:如何发布首页公告回答:后台->系统设置->商店设置->网店信息->商店公告.填写你需要的公告就可以了.6:如何发布站内新闻7:如何修改网站logo回答:用你的logo图片替换/themes/default/images/logo.gif中图片就可以了8:如何修改产品图片的大小回答:在ecshop/themes/default/style.css中,找到.goodsItem .goodsimg{width:100px; height:100px; border:4px solid #eef8ff; margin-bottom:4px;}就可以控制产品图片的大小.9:如何管理首页flash播放器回答:后台-> flash播放器管理-> 增加自定义,你就可以上传和控制图片的位置10:如何修改首页"精品推荐"栏目的more小图片回答:模板文件中library/recommend_best.lbi中,<div class="more"><ahref="../search.php?intro=best"><img src="images/more.gif" /></a></div> 中more.gif图片换成你要的图片,或者将图片换成你需要的文字.hzbjp2009-07-09 20:21 11:如何修改首页"新品上市"栏目的more小图片回答:模板文件library/recommend_new.lbi中,<div class="more"><ahref="../search.php?intro=new"><img src="images/more.gif" /></a></div> more.gif修改成你需要的图片或者是换成你需要的文字.12:如何手动修改支付方式排列顺序回答:数据库表中,找到payment表,pay_order字段就是用来控制顺序的,你如果想让A支付方式排在第一,那么你需要修改该字段的值稍微大一些。
ECSHOP 3.0 系统功能列表
![ECSHOP 3.0 系统功能列表](https://img.taocdn.com/s3/m/121898f3aeaad1f346933fec.png)
管理员可以看到会员在前台进行的一些充值提现操作。可以对用户的申请进行操作,也可以在后 台添加申请。 管理员可以查看会员的信息,可根据日期查看所有用户的总的资金体现。 管理员可以编辑网店的管理员,并可对这些管理员的管理权限进行设置。 该模块记录了管理员在后台的操作记录。可以在这里查看及清楚管理员日志,也可以勾选需要清 除的管理员日志。 角色管理方便了后台管理员权限的设置,如设置一个角色为供货商,分配权限给查看发货单和查 看退货单。 实际生活中开店都需要有办事处,系统可以在后台为自己的网店添加一个个的办事处,并可设置 负责该办事处的管理员。 管理员可以添加供货商,供货商的具体体现在添加新商品的时候会有选择供货商。 管理员在这里可以完成商店的几乎所有的设置,包括的设置有网店信息基本设置、显示设置、购 物流程、商品显示设置、短信设置、WAP 设置等,这个部分可以说是网店系统的核心配置。 管理员可以在后台设置会员注册项的显示隐藏,也可以增加会员注册项。 用户在前台购物过程中点击结算中心后,会进入购物流程中,购物流程中会有支付方式,比如支 付宝,银行转账汇款等。 管理员可以设置配送方式,后台内置申通快递、顺丰速运、中通快递等多种配送方式。 支持二种邮件发送方式:1、采用服务器内置的 Mail 服务(推荐此方式),2、采用其他的 SMTP 服务(支持 SMTP 验证)。 管理员可以自定义地区列表,根据网店的性质自定义区域名称等。 计划任务,就是在适当的时候,让计算机执行适当地程序,以满足用户的需求。计划任务分系统 计划任务和网站计划任务。系统计划任务包括 Windows 操作系统计划任务和 Linux 操作系统计 划任务。 友情链接是在网站首页帮助中心的下面显示,增加友情链接有助于提高网站的外链,对网店的优 化起到了辅助作用。 管理员可以设置在某个模块对用户行为进行需要输入验证码,验证码可以有效防止批量注册、灌 水等恶意行为。 目录文件权限检测。 文件校验是针对官方发布的文件为基础对您现在的文件进行核对,以便发现有没有文件被做过修 改,用来恢复误修改的文件。 管理员可以采用后台系统默认设置,也可使用自定义,方法和广告的的方法一样,里面可以设置 图片、flash、代码、文字类型的广告。 管理员可以自定义导航栏并可以对其设置显示、隐藏、是否新窗口打开、显示位置等,维护方 便,操作简单。 证书是您享受软件服务的唯一标识,它记录了您的网店的授权信息、购买官方服务记录、短信帐 户等重要信息。 网站地图可以帮助搜索引擎建立索引范围和索引的行为习惯,有利于网店优化。Google SiteMap Protocol是Google自己推出的一种站点地图协议,此协议文件基于早期的robots.txt文件协 议,并有所升级。在Google官方指南中指出加入了Google SiteMap文件的网站将更有利于Google 网页爬行机器人的爬行索引,这样将提高索引网站内容的效率和准确度。 第三方登录插件管理 后台支持多套模板存放,管理员可任意切换网店模板,一键轻松改变网店风格。 管理员可以设置页面各个模块的显示位置,可以在后台根据自己的要求调整模板模块的显示位置 。 管理员可以编辑每一个模块的样式,通过下拉菜单轻松的选择您需要修改的模块,修改完后确定 提交即可生效。 修改系统中的某些碎片文件,如欢迎语、提示信息等。 在这里管理员可以看到备份模版设置的选项,此功能主要用来备份和还原自定义模板
Ecshop使用说明流程图
![Ecshop使用说明流程图](https://img.taocdn.com/s3/m/c6530310b7360b4c2e3f64b3.png)
Ecshop 使用说明流程图及分析一、功能模块概述电子商务商品管理订单管理会员管理管理员管理文章管理系统设置商品列表添加商品商品分类商品品牌商品回收站订单列表订单查询订单状态变更删除订单会员列表添加新会员会员等级会员评论资金管理管理员列表管理员权限文章分类文章列表商店设置配送方式地区列表友情链接验证码管理自定义导航栏商品类型二、商品管理2.1商品列表通过查询数据库中的商品信息,将相关信息显示在页面上,并提供相应操作连接。
添加编辑复制 放入回收站搜索查看2.1.1商品列表所含功能说明商品列表商品列表添加商品商品编辑商品复制商品回收站商品查询2.1.2商品列表流程商品列表查询未放入回收站的商品信息输出数组至页面根据页面布局输出商品列表组合SQL语句,查询未放入回收站的商品获取返回的数组,传递到模版按规则显示数据简述:本功能主要实现显示出商品信息的功能,通过点击商品列表的链接,使用PHP查询没有放入回收站的商品信息,将返回值存储到数组中,通过模版引擎将数组传送到视图,利用模版引擎的格式输出查询到的数据。
2.1.3添加商品流程添加商品填写商品信息提交至处理页面保存到数据库并跳转至列表页添加商品填写表单信息提交到处理页面接收数据并存储到数组中组合插入数据的SQL语句将数据存储到相应的数据表中跳转到商品列表页面简述:本功能主要描述添加一件商品的过程。
点击添加商品按钮,调出需要填写的表单,表单填写完成后,通过提交,将数据提交到处理页面,由处理页面负责设置数组接收提交的数据,组合成插入的SQL语句,将数据写入到数据库表中,确认添加完成后跳转到商品列表页面,完成数据插入。
2.1.4商品编辑编辑商品修改商品信息提交至处理页面保存到数据库并跳转至列表页编辑商品修改表单信息提交到处理页面接收数据并存储到数组中组合更新数据的SQL语句将数据存储到相应的数据表中跳转到商品列表页面获取指定的商品信息获取商品ID根据商品ID查询出需要修改的商品信息按照规定的表单位置显示商品信息简述:本功能主要描述修改一件商品信息的过程。
ECSHOP数据库结构详细说明
![ECSHOP数据库结构详细说明](https://img.taocdn.com/s3/m/0e0c0976bf23482fb4daa58da0116c175e0e1e50.png)
ECSHOP数据库结构详细说明ECSHOP数据库结构详细说明(1)表的结构`ecs_account_log`==用户账目日志表CREATE TABLE IF NOT EXISTS `ecs_account_log` (`log_id` mediumint(8) unsigned NOT NULL AUTO_INCREMENT COMMENT '自增ID号',`user_id` mediumint(8) unsigned NOT NULL COMMENT '用户登录后保存在session中的id号,跟users表中的user_id对应', `user_money` decimal(10,2) NOT NULL COMMENT '用户该笔记录的余额',`frozen_money` decimal(10,2) NOT NULL COMMENT '被冻结的资金',`rank_points` mediumint(9) NOT NULL COMMENT '等级积分,跟消费积分是分开的',`pay_points` mediumint(9) NOT NULL COMMENT '消费积分,跟等级积分是分开的',`change_time` int(10) unsigned NOT NULL COMMENT '该笔操作发生的时间',`change_desc` varchar(255) NOT NULL COMMENT '该笔操作的备注,一般是,充值或者提现。
也可是是管理员后台写的任何在备注',`change_type` tinyint(3) unsigned NOT NULL COMMENT '操作类型,0为充值,1为提现,2为管理员调节,99为其他类型', PRIMARY KEY (`log_id`),KEY `user_id` (`user_id`)) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='用户帐号情况记录表,包括资金和积分等' AUTO_INCREMENT=42 ;-- --------------------------------------------------------------------------------------------------------------------------------------------------------------------表的结构`ecs_ad` 广告表(位置,类型,名称,链接,图片,开始,结束,广告主相关信息,点击,是否显示)CREATE TABLE IF NOT EXISTS `ecs_ad` (`ad_id` smallint(5) unsigned NOT NULL AUTO_INCREMENT COMMENT '自增ID号',`position_id` smallint(5) unsigned NOT NULL DEFAULT '0' COMMENT '0,站外广告;从1开始代表的是该广告所处的广告位,同表ad_position中的字段position_id的值',`media_type` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '广告类型,0,图片;1,flash;2,代码;3,文字', `ad_name` varchar(60) NOT NULL COMMENT '该条广告记录的广告名称',`ad_link` varchar(255) NOT NULL COMMENT '广告链接地址', `ad_code` text NOT NULL COMMENT '广告链接的表现,文字广告就是文字或图片和flash就是它们的地址,代码广告就是代码内容',`start_time` int(11) NOT NULL DEFAULT '0' COMMENT '广告开始时间',`end_time` int(11) NOT NULL DEFAULT '0' COMMENT '广告结束时间',`link_man` varchar(60) NOT NULL COMMENT '广告联系人',`link_email` varchar(60) NOT NULL COMMENT '广告联系人的邮箱',`link_phone` varchar(60) NOT NULL COMMENT '广告联系人的电话',`click_count` mediumint(8) unsigned NOT NULL DEFAULT '0' COMMENT '该广告点击数',`enabled` tinyint(3) unsigned NOT NULL DEFAULT '1'COMMENT '该广告是否关闭,1,开启;0,关闭;关闭后广告将不再有效,直至重新开启',PRIMARY KEY (`ad_id`),KEY `position_id` (`position_id`),KEY `enabled` (`enabled`)) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='广告列表配置表,包括站内站外的图片,文字,flash,代码广告' AUTO_INCREMENT=6 ;-- ------------------------------------------------------------------------------------------------------------------------------------------------------------------------表的结构`ecs_admin_action`==管理权限分配(父类ID,权限代码)CREATE TABLE IF NOT EXISTS `ecs_admin_action` (`action_id` tinyint(3) unsigned NOT NULL AUTO_INCREMENT COMMENT '自增ID号',`parent_id` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '该id项的父id,对应本表的action_id字段', `action_code` varchar(20) NOT NULL COMMENT '代表权限的英文字符串,对应汉文在语言文件中,如果该字段有某个字符串,就表示有该权限',PRIMARY KEY (`action_id`),KEY `parent_id` (`parent_id`)) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='管理员权限列表树' AUTO_INCREMENT=104 ;-- ----------------------------------------------------------------------------------------------------------------------------------------------------------------------表的结构`ecs_admin_log`==管理日志(登陆时间,登陆管理员ID,操作描述,IP)CREATE TABLE IF NOT EXISTS `ecs_admin_log` (`log_id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '自增ID号',`log_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '写日志时间',`user_id` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '该日志所记录的操作者id,同ecs_admin_user的user_id',`log_info` varchar(255) NOT NULL COMMENT '管理操作内容', `ip_address` varchar(15) NOT NULL COMMENT '管理者登录ip', PRIMARY KEY (`log_id`),KEY `log_time` (`log_time`),KEY `user_id` (`user_id`)) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='管理员操作日志表' AUTO_INCREMENT=158 ;-- -----------------------------------------------------------------------------------------------------------------------------------------------------------------------表的结构`ecs_admin_message`==管理员留言(发送者ID,接收者ID,发送日期,阅读日期,是否已读,是否删除,标题,内CREATE TABLE IF NOT EXISTS `ecs_admin_message` (`message_id` smallint(5) unsigned NOT NULL AUTO_INCREMENT COMMENT '自增ID号',`sender_id` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '发送该留言的管理员id,同ecs_admin_user的user_id', `receiver_id` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '接收消息的管理员id,同ecs_admin_user的user_id,如果是给多个管理员发送,则同一个消息给每个管理员id发送一条',`sent_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '留言发送时间',`read_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '留言阅读时间',`readed` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '留言是否阅读,1,已阅读;0,未阅读',`deleted` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '留言是否已经是否已经被删除,1,已删除;0,未删除', `title` varchar(150) NOT NULL COMMENT '留言的主题',`message` text NOT NULL COMMENT '留言的内容',PRIMARY KEY (`message_id`),KEY `sender_id` (`sender_id`,`receiver_id`),KEY `receiver_id` (`receiver_id`)) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='管理员留言记录表' AUTO_INCREMENT=7 ;-- -------------------------------------------------------- 表的结构`ecs_admin_user`==管理员管理(用户名,email ,密码,加入时间,最后登陆时间,最后登陆IP,权限等)CREATE TABLE IF NOT EXISTS `ecs_admin_user` (`user_id` smallint(5) unsigned NOT NULL AUTO_INCREMENT COMMENT '自增ID号,管理员代号',`user_name` varchar(60) NOT NULL COMMENT '管理员登录名',`email` varchar(60) NOT NULL COMMENT '管理员邮箱',`password` varchar(32) NOT NULL COMMENT '管理员登录秘密加密串',`add_time` int(11) NOT NULL DEFAULT '0' COMMENT '管理员添加时间',`last_login` int(11) NOT NULL DEFAULT '0' COMMENT '管理员最后一次登录时间',`last_ip` varchar(15) NOT NULL COMMENT '管理员最后一次登录ip',`action_list` text NOT NULL COMMENT '管理员管理权限列表', `nav_list` text NOT NULL COMMENT '管理员导航栏配置项',`lang_type` varchar(50) NOT NULL,`agency_id` smallint(5) unsigned NOT NULL COMMENT '该管理员负责的办事处的id,同ecs_agency的agency_id字段。
ECShop电子商务平台(网上商城)功能介绍
![ECShop电子商务平台(网上商城)功能介绍](https://img.taocdn.com/s3/m/9413b6928bd63186bdebbc2b.png)
电子商务平台(网上商城)系统特色功能介绍目录1. 系统特点 (4)1.1. 技术架构 (4)1.2. 开放的插件机制 (4)1.3. 功能Ajax化 (5)1.4. 安全高效 (5)1.5. 搜索引擎友好性 (6)2. 商品展示 (7)2.1. 商品分类与品牌 (7)2.2. 商品类型与属性 (7)2.3. 推荐商品 (9)2.4. 商品详情页 (10)2.4.1. 相关商品 (10)2.4.2. 配件 (11)2.4.3. 关联文章 (11)2.4.4. 购买过该商品的人还买过的商品 (11)2.5. RSS Feeds和T ag (11)3. 购物流程 (12)3.1. 智能化的购物流程 (12)3.2. 聪明的配送方式 (13)4. 推广促销 (13)4.1. 拍卖 (13)4.2. 夺宝奇兵 (14)4.3. 团购 (14)4.4. 灵活多样的优惠活动 (14)4.5. 推荐提成 (15)4.6. 会员信用额度 (15)4.7. 销售专题 (16)5. 会员系统 (16)5.1. 会员数据整合 (16)5.2. 积分兑换 (16)6. 网店管理 (17)6.1. 报表统计 (17)6.2. 办事处 (20)6.3. 短信 (20)6.4. 计划任务 (20)7. 结束语 (21)1.系统特点1.1.技术架构采用PHP、Ajax技术开发,系统可运行于Linux、Windows等多种操作系统平台。
系统采用MVC(Module, View Controller)三层架构设计,从根本上保证了系统的健壮性与可扩展性。
图表11.2.开放的插件机制对于电子商务网站来说支付与配送是业务流程中至关重要的一个环节,也正是网上支付与各物流公司的兴起促使了电子商务快速的发展。
抛弃了传统的固定公式,由用户来设置各种参数的方式,而是采用了一个开放式的插件机制来管理各种支付和配送方式。
对于网上商店网站的站长来说,建立一个社区是一种提高网店的用户黏度的有效手段,这样也就带来了一个问题,如何将社区的用户与网店的用户进行整合。
ecshop可以使用多个红包插件
![ecshop可以使用多个红包插件](https://img.taocdn.com/s3/m/b8fd4c2f2f60ddccda38a0bd.png)
Ecshop可以使用更多个红包插件ECSHOP开发中心()ecshop 添加可多次使用的红包步骤1) 添加一种新的红包类型4 ,文件 admin/templates/bonus_type_info.htm找到 <input type="radio" name="send_type" value="0" {if $bonus_arr.send_type eq 0} c hecked="true" {/if} onClick="showunit(0)" />{$lang.send_by[0]}<input type="radio" name="send_type" value="1" {if $bonus_arr.send_type eq 1} c hecked="true" {/if} onClick="showunit(1)" />{$lang.send_by[1]}<input type="radio" name="send_type" value="2" {if $bonus_arr.send_type eq 2} c hecked="true" {/if} onClick="showunit(2)" />{$lang.send_by[2]}<input type="radio" name="send_type" value="3" {if $bonus_arr.send_type eq 3} c hecked="true" {/if} onClick="showunit(3)" />{$lang.send_by[3]}再其后面添加<input type="radio" name="send_type" value="4" {if $bonus_arr.send_type eq 4} check ed="true" {/if} onClick="showunit(4)" />通用红包多次使用2) 生成这类红包字符串增加文件 admin/templates/bonus_by_print_phpsir.htm修改文件 admin/bonus.php 找到elseif ($_REQUEST['send_by'] == SEND_BY_PRINT){$smarty->assign('type_list', get_bonus_type());$smarty->display('bonus_by_print.htm');}再其后添加elseif ($_REQUEST['send_by'] == 4){$smarty->assign('type_list', get_bonus_type_phpsir());$smarty->display('bonus_by_print_phpsir.htm');}3) 增加 get_bonus_type_phpsir 函数文件 admin/includes/lib_main.phpfunction get_bonus_type_phpsir(){$bonus = array();$sql = 'SELECT type_id, type_name, type_money FROM ' . $GLOBALS['ecs']->table('b onus_type') .' WHERE send_type = 4';$res = $GLOBALS['db']->query($sql);while ($row = $GLOBALS['db']->fetchRow($res)){$bonus[$row['type_id']] = $row['type_name'].' [' .sprintf($GLOBALS['_CFG']['curren cy_format'], $row['type_money']).']';}return $bonus;}4) 在 bonus.php 里面找到if ($_REQUEST['act'] == 'send_by_print'){...........................}再其后面添加,处理增加这类红包时候生成方法if ($_REQUEST['act'] == 'send_by_print_phpsir'){@set_time_limit(0);/* 红下红包的类型ID和生成的数量的处理 */$bonus_typeid = !empty($_POST['bonus_type_id']) ? $_POST['bonus_type_id'] : 0; $bonus_sum = !empty($_POST['bonus_sum']) ? $_POST['bonus_sum'] : 1; /* 生成红包序列号 */for ($i = 0, $j = 0; $i < $bonus_sum; $i++){$bonus_sn = $_POST['bonus_txt'];$db->query("INSERT INTO ".$ecs->table('user_bonus')." (bonus_type_id, bonus_s n) VALUES('$bonus_typeid', '$bonus_sn')");$j++;}/* 记录管理员操作 */admin_log($bonus_sn, 'add', 'userbonus');/* 清除缓存 */clear_cache_files();/* 提示信息 */$link[0]['text'] = $_LANG['back_bonus_list'];$link[0]['href'] = 'bonus.php?act=bonus_list&bonus_type=' . $bonus_typeid;sys_msg($_LANG['creat_bonus'] . $j . $_LANG['creat_bonus_num'], 0, $link);}5) 修改 bonus.php 让后台显示红包内容if ($_REQUEST['act'] == 'bonus_list'){...........................}和if ($_REQUEST['act'] == 'query_bonus'){...........................}里面增加if ($bonus_type['send_type'] == 4){$smarty->assign('show_bonus_sn', 1);}至此后台部分完成前台部分修改includes/lib_order.phpfunction bonus_info($bonus_id, $bonus_sn = ''){$sql = "SELECT t.*, b.* " ."FROM " . $GLOBALS['ecs']->table('bonus_type') . " AS t," .$GLOBALS['ecs']->table('user_bonus') . " AS b " ."WHERE t.type_id = b.bonus_type_id ";if ($bonus_id > 0){$sql .= " AND b.bonus_id = '$bonus_id'";$row = $GLOBALS['db']->getRow($sql);return $row;}else{$sql .= " AND b.bonus_sn = '$bonus_sn'";$row = $GLOBALS['db']->getRow($sql);}if($row['send_type'] == 4) // phpsir 如果是第4类型红包,那么就找一个未使用的红包,这种红包可被多次使用,不限制每人使用次数{$sess_userid = $_SESSION["user_id"];$sql = "SELECT t.*, b.* " ."FROM " . $GLOBALS['ecs']->table('bonus_type') . " AS t," .$GLOBALS['ecs']->table('user_bonus') . " AS b " ."WHERE t.type_id = b.bonus_type_id and ed_time = 0 ";if ($bonus_id > 0){$sql .= "AND b.bonus_id = '$bonus_id'";}else{$sql .= "AND b.bonus_sn = '$bonus_sn'";}//print $sql;$row = $GLOBALS['db']->getRow($sql);//var_dump($row);return $row;}// 如果想每人只使用N次,请用下面的部分/*if($row['send_type'] == 4) // phpsir 如果是第4类型红包,那么就找一个未使用的红包,这种红包可被多次使用,不限制每人使用次数{$sess_userid = $_SESSION["user_id"];$sql = "SELECT t.*, b.* " ."FROM " . $GLOBALS['ecs']->table('bonus_type') . " AS t," .$GLOBALS['ecs']->table('user_bonus') . " AS b " ."WHERE t.type_id = b.bonus_type_id and er_id = '$sess_userid' and b .bonus_sn = '$bonus_sn' ";$rows = $GLOBALS['db']->getAll($sql);$allow_used_bonus_num = 2; // 最大允许使用次数if(count($rows) >= $allow_used_bonus_num ){return false;}else{$sql = "SELECT t.*, b.* " ."FROM " . $GLOBALS['ecs']->table('bonus_type') . " AS t," .$GLOBALS['ecs']->table('user_bonus') . " AS b " ."WHERE t.type_id = b.bonus_type_id and ed_time = 0 and b.bonus _sn = '$bonus_sn' ";$row = $GLOBALS['db']->getRow($sql);return $row;}}*/return $row;}注意:修改PHP文件时候不要用记事本打开,否则文件编码会出问题导致网站报错,建议用专业的dreamweaver来修改【ECSHOP开发中心】。
ecshop首页修改ECSHOP的模板大全教程
![ecshop首页修改ECSHOP的模板大全教程](https://img.taocdn.com/s3/m/4bcb6e543b3567ec102d8a8f.png)
修改ECSHOP的模板大全ECSHOP的广告链接地址形式为“affiche.php?ad_id=1&uri=http%3A%2F%”它中间用affiche.php 做了一个过渡,目的在于统计广告效果等。
有些站长觉得这种链接地址看上去很别扭,而且不利于SEO, 想改成直接的形式,也就是后台设置的是什么链接地址,就直接打开什么链接地址。
可以这样来修改:打开/includes/lib_insert.php 文件找到$ads[] = "<a href='affiche.php?ad_id=$row[ad_id]&uri=" .urlencode($row["ad_link"]). "'修改为$ads[] = "<a href='" .$row["ad_link"]. "'注意:一共有两处都要修改在ECSHOP首页的每个商品下显示商品货号ECSHOP首页有很多种商品,包括今日特价、精品推荐、新品上市、热卖商品、分类商品等,这里只讲解在“精品推荐、新品上市、热卖商品”三个栏目的商品下面显示商品货号的方法。
第一步:修改 includes/lib_goods.php文件找到下面代码第二步:找到$goods[$idx]['brand_name'] = isset($goods_data['brand'][$row['goods_id']]) ?$goods_data['brand'][$row['goods_id']] : '';在它上边增加一行代码$goods[$idx]['goods_sn'] = $row['goods_sn'];第三步:修改模板文件,这里以官方默认模板为例依次打开下面三个文件:/themes/default/library/recommend_best.lbi,/themes/default/library/recommend_new.lbi,/themes/default/library/recommend_hot.lbi在每一个文件的<p><a href="{$goods.url}" title="{$|escape:html}">{$goods.short_style_name}</a></p> 上边增加一行代码:<p>商品货号:{$goods.goods_sn}</p>在ECSHOP销售排行中显示会员价格的方法有的用户可能已经发现了,在ECSHOP的销售排行中,任何情况下只显示了一个“本店售价”。
商城系统项目解决方案
![商城系统项目解决方案](https://img.taocdn.com/s3/m/658a505bc5da50e2534d7f24.png)
商城系统解决方案2016/7/14目录1简介 (5)1.1目的 (5)1.2范围 (5)1.3参考资料 (5)2项目概述 (5)2.1背景概述 (5)2.2项目范围 (6)3系统环境 (7)3.1基础环境 (7)3.2硬件配置 (7)3.3开发环境 (7)3.4网络拓扑结构 (8)4外部元件 (9)4.1第三方开源框架 (9)5总体设计 (10)5.1系统服务 (10)5.2系统技术框架 (10)5.3系统架构 (10)5.4系统指标 (12)6 核心模块设计 (13)6.1控制台 (13)6.1.1数据查看 (13)6.2商品 (13)6.2.1 商品管理 (13)6.2.2 分类管理 (16)6.2.3 品牌管理 (17)6.2.4 类型管理 (18)6.2.5 评价管理 (19)6.2.6 评论管理 (19)6.3交易 (20)6.3.1 订单管理 (20)6.3.2 退款处理 (22)6.3.3 退货处理 (23)6.3.4 交易评价 (24)6.3.5 交易投诉 (25)6.3.6 支付方式 (25)6.3.7 快递单模板 (26)6.3.8 交易设置 (27)6.3.9 发票管理 (27)6.4会员 (28)6.4.2 标签管理 (29)6.4.3 会员营销 (29)6.4.4 会员积分 (30)6.4.5 积分规则 (31)6.4.6 会员等级 (32)6.4.7 信任登录 (32)6.4.8 会员推广 (33)6.4.9 余额管理 (34)6.5店铺 (35)6.5.1 店铺管理 (35)6.5.2 店铺套餐 (36)6.5.3 结算管理 (37)6.5.4 保证金管理 (38)6.6统计 (39)6.6.1 会员统计 (39)6.6.2 店铺统计 (40)6.6.3 销量分析 (41)6.7网站 (42)6.7.1 页面设置 (42)6.7.2 文章管理 (42)6.7.3 文章分类 (43)6.8分销 (44)6.8.1 分销市场管理 (44)6.8.2 推广员店铺管理 (45)6.8.3 分销业绩管理 (46)6.9系统 (47)6.9.1 站点设置 (47)6.9.2 管理员 (48)6.9.3 权限组 (48)6.9.4 操作日志 (49)6.9.5 消息设置 (49)6.9.6 协议管理 (51)6.10营销 (52)6.10.1 限时购 (52)6.10.2 众筹产品 (55)6.10.3 优惠卷 (55)6.10.4 组合购 (56)6.10.5 微信现金红包 (57)6.10.6 代金红包 (58)6.10.7 礼品管理 (59)6.10.8 礼品兑换列表 (60)6.10.9 签到 (61)6.10.10 移动端专题 (62)6.11微商城 (64)6.11.1 商城首页设置 (64)6.11.2 微店管理 (65)6.11.3 菜单设置 (66)6.11.4 公众号设置 (67)6.11.5 素材管理 (68)6.12APP (69)6.12.1 APP商城首页配置 (69)7.移动端 (69)7.1分销 (69)7.1.1 分销市场管理 (69)7.1.2 销售员管理 (70)7.1.3 分销业绩管理 (72)7.2营销 (73)7.2.1 微信现金红包 (73)7.2.2 代金红包 (74)7.2.3 签到 (75)7.2.4 移动端专题 (75)7.3微商城 (76)7.3.1 商城首页 (76)7.3.2 微店管理 (77)7.3.3 菜单设置 (79)7.3.4 公众号设置 (80)7.3.5 素材管理 (80)7.4APP (81)7.4.1 APP商城首页配置 (81)7.5实体店 (82)7.5.1 地理位置 (82)7.5.2 门店管理 (82)7.6聊天系统 (82)7.6.1 PC端/APP端 (82)1简介1.1目的本设计文档为商城系统的解决方案,为详细设计和代码编写提供统一的参照标准,其中包括系统环境、开发技术、开发环境、外部元件以及编程模型的解决方案。
ecshop贝宝(paypal中国)支付插件
![ecshop贝宝(paypal中国)支付插件](https://img.taocdn.com/s3/m/6fe758e7e009581b6bd9ebab.png)
ecshop贝宝(paypal中国)支付插件PayPal和贝宝的区别:1. PayPal和贝宝是独立运作的两个网站。
2. PayPal国际网站允许您向55 个国家和地区的用户发送和接收付款;可以用多币种交易,包括美元、加元、欧元、英镑、澳元和日元;贝宝只能向中国用户发送和接收付款,只能用人民币交易。
主程序:/includes/modules/payment/paypalcn.php如下:<?php/*** ECSHOP 贝宝(PayPal中国)支付插件* ----------------------------------------------------------------------------* Jacklee的博客致力于php技术* * ----------------------------------------------------------------------------* @author: Jacklee* @email: jack349392900#* @date: 2012-04-19*/if (!defined('IN_ECS')){die('Hacking attempt');}$payment_lang = ROOT_PATH . 'languages/' .$GLOBALS['_CFG']['lang']. '/payment/paypalcn.php';if (file_exists($payment_lang)){global $_LANG;include_once($payment_lang);}/* 模块的基本信息*/if (isset($set_modules) >> $set_modules == TRUE){$i = isset($modules) ? count($modules) : 0;/* 代码*/$modules[$i]['code'] = basename(__FILE__, '.php');/* 描述对应的语言项*/$modules[$i]['desc'] = 'paypalcn_desc';/* 是否支持货到付款*/$modules[$i]['is_cod'] = '0';/* 是否支持在线支付*/$modules[$i]['is_online'] = '1';/* 作者*/$modules[$i]['author'] = 'Jacklee';/* 网址*/$modules[$i]['website'] = '';/* 版本号*/$modules[$i]['version'] = '1.0.0';/* 配置信息*/$modules[$i]['config'] = array(array('name' => 'paypalcn_account', 'type' => 'text', 'value' => ''), );return;}/*** 类*/class paypalcn{/*** 构造函数** @access public* @param** @return void*/function paypalcn(){}function __construct(){$this->paypalcn();}/*** 生成支付代码* @param array $order 订单信息* @param array $payment 支付方式信息*/function get_code($order, $payment){$data_order_id = $order['log_id'];$data_amount = $order['order_amount'];$data_return_url = return_url(basename(__FILE__, '.php'));$data_pay_account = $payment['paypalcn_account'];$data_notify_url = return_url(basename(__FILE__, '.php'));$cancel_return = $GLOBALS['ecs']->url();$def_url = '<br /><form style="text-align:center;" action="https:///cgi-bin/webscr" method="post">' . // 不能省略"<input type='hidden' name='cmd' value='_xclick'>" . // 不能省略"<input type='hidden' name='business' value='$data_pay_account'>" . // 贝宝帐号"<input type='hidden' name='return' value='$data_return_url'>" . // 付款后页面"<input type='hidden' name='amount' value='$data_amount'>" . // 订单金额"<input type='hidden' name='invoice' value='$data_order_id'>" . // 订单号"<input type='hidden' name='charset' value='utf-8'>" . // 字符集"<input type='hidden' name='no_shipping' value='1'>" . // 不要求客户提供收货地址"<input type='hidden' name='no_note' value='0'>" . // 付款说明"<input type='hidden' name='currency_code' value='CNY'>" . // 货币:人民币"<input type='hidden' name='notify_url' value='$data_notify_url'>" ."<input type='hidden' name='rm' value='2'>" ."<input type='hidden' name='cancel_return' value='$cancel_return'>" ."<input type='submit' value='" . $GLOBALS['_LANG']['paypalcn_button'] . "'>" . // 按钮"</form><br />";return $def_url;}/*** 响应操作*/function respond(){$payment = get_payment('paypalcn');$merchant_id = $payment['paypalcn_account']; ///获取商户编号// read the post from PayPal system and add 'cmd'$req = 'cmd=_notify-validate';foreach ($_POST as $key => $value){$value = urlencode(stripslashes($value));$req .= ">$key=$value";}// post back to PayPal system to validate$header = "POST /cgi-bin/webscr HTTP/1.0\r\n";$header .= "Content-Type: application/x-www-form-urlencoded\r\n";$header .= "Content-Length: " . strlen($req) ."\r\n\r\n";$fp = fsockopen ('', 80, $errno, $errstr, 30);// assign posted variables to local variables$item_name = $_POST['item_name'];$item_number = $_POST['item_number'];$payment_status = $_POST['payment_status'];$payment_amount = $_POST['mc_gross'];$payment_currency = $_POST['mc_currency'];$txn_id = $_POST['txn_id'];$receiver_email = $_POST['receiver_email'];$payer_email = $_POST['payer_email'];$order_sn = $_POST['invoice'];$memo = !empty($_POST['memo']) ? $_POST['memo'] : '';$action_note = $txn_id . '(' . $GLOBALS['_LANG']['paypal_txn_id'] . ')' . $memo;if (!$fp){fclose($fp);return false;}else{fputs($fp, $header . $req);while (!feof($fp)){$res = fgets($fp, 1024);if (strcmp($res, 'VERIFIED') == 0){// check the payment_status is Completedif ($payment_status != 'Completed' >> $payment_status != 'Pending'){fclose($fp);return false;}// check that txn_id has not been previously processed/*$sql = "SELECT COUNT(*) FROM " . $GLOBALS['ecs']->table('order_action') . " WHERE action_note LIKE '" . mysql_like_quote($txn_id) . "%'";if ($GLOBALS['db']->getOne($sql) > 0){fclose($fp);return false;}*/// check that receiver_email is your Primary PayPal emailif ($receiver_email != $merchant_id){fclose($fp);return false;}// check that payment_amount/payment_currency are correct$sql = "SELECT order_amount FROM " . $GLOBALS['ecs']->table('pay_log') . " WHERE log_id = '$order_sn'";if ($GLOBALS['db']->getOne($sql) != $payment_amount){fclose($fp);return false;}if ($payment_currency != 'CNY'){fclose($fp);return false;}// process paymentorder_paid($order_sn, PS_PAYED, $action_note);fclose($fp);return true;}elseif (strcmp($res, 'INVALID') == 0){// log for manual investigationfclose($fp);return false;}}}}}?>语言文件:/languages/zh_cn/payment/paypalcn.php:<?php/*** ECSHOP 贝宝(PayPal中国)支付插件语言文件* ----------------------------------------------------------------------------* Jacklee的博客致力于php技术* * ----------------------------------------------------------------------------* @author: Jacklee* @email: jack349392900#* @date: 2012-04-19*/global $_LANG;$_LANG['paypalcn'] = '贝宝';$_LANG['paypalcn_desc'] = '贝宝支付';$_LANG['paypalcn_account'] = '商户帐号';$_LANG['paypalcn_button'] = '立即使用贝宝支付'; $_LANG['paypal_txn_id'] = '贝宝交易号';?>。
ecshop商城后台使用教程
![ecshop商城后台使用教程](https://img.taocdn.com/s3/m/e8904e0d6bd97f192279e9aa.png)
我们在使用ecshop商城后台时,总会遇到很多的设置问题,比如首页轮播图设置,广告位设置,商家权限设置等等问题,本篇文章总结了商城后台各种使用设置问题及解决方法,希望对大家有所帮助!1:如何管理首页flash播放器回答:后台->flash播放器管理->增加自定义,你就可以上传和控制图片的位置2:如何修改首页"精品推荐"栏目的more小图片回答:模板文件中library/recommend_best.lbi中中more.gif图片换成你要的图片,或者将图片换成你需要的文字.3:如何修改首页"新品上市"栏目的more小图片回答:模板文件library/recommend_new.lbi中,more.gif修改成你需要的图片或者是换成你需要的文字.4:如何手动修改支付方式排列顺序回答:数据库表中,找到payment表,pay_order字段就是用来控制顺序的,你如果想让A支付方式排在第一,那么你需要修改该字段的值稍微大一些。
5:如何去除ecshop产品详细页产品电击率回答:模板文件中,打开goods.dwt,删除{$lang.goods_click_count}:{$goods.click_count}6:首页模板在哪个文件,头部模板,底部模板个什么文件名称回答:首页模板在为index.dwt,头部模板在library/page_header.lbi,底部文件在library/page_footer.lbi7:网站关闭了注册,如何修改“该网店暂停注册”字样回答:languages\zh_cn\common.php中$_LANG['shop_register_closed']='该网店暂停注册';修改该文字就可以了8:收货人详细信息js弹出框的提示脚本在哪个文件回答:languages\zh_cn\shopping_flow.php[比如$_LANG['flow_js']['country_not_null']='请您选择收货人所在国家!';]9:网站公告代码段在那里回答:index.php文件中,$smarty->assign('shop_notice',$_CFG['shop_notice']);//商店公告代码段控制公告10:网站首页"精品推荐"显示数量在那里设置设置ecshop首页精品的数量.模板管理->设置模板->精品推荐(修改其显示数量)修改下面的10为你需要的数量,这就是精品推荐11:网站首页"新品上市"显示数量在那里设置设置ecshop首页新品的数量.模板管理->设置模板->新品上架(修改其显示数量)修改下面的10为你需要的数量,这就是新品上架12:如何修改产品的库存回答:商品管理->商品列表->选中(库存),编辑就可以了.13:如何修改ecshop表的前缀回答:修改data/config.php下的$prefix="ecs_";将ecs_修改成你需要的前缀.其次,在数据库中,修改表名比如ecs_goods修改为"xxx_goods";14:如何去除首页flash下面的空白区域如何显示商品的品牌,如何显示促销产品,为什么首页flash下面有一片空白的地方,如何去掉?首先.ecshop首页flash下面有两个空白的地方,第一个是用来显示促销产品的,右边是用来显示品牌的。
商城网站设计
![商城网站设计](https://img.taocdn.com/s3/m/1dedc400844769eae009ed4e.png)
商城网站设计樱桃时装-居然之家郑素婉2009级计算机网络技术摘要:电子商务网站是在Windows系统环境下,以Mysql数据库开发平台,Apache网络信息服务器,采用PHP(Hypertext Preprocessor)技术开发的网上购物系统。
本系统分为前台与后台两部分组成,前台主要针对消费者,主要包括商品展示、会员注册、购物车管理、商品收藏管理、订单管理等功能模块;后台由管理员使用,主要包括商品管理、进货管理、订单管理、系统管理等功能模块。
通过这些功能的实现,给商家提供一个动态、交互式、具有商品提供、系统管理等功能的电子商务平台。
关键字:电子商务网站,PHP开发技术,数据库开发,网络购物Mall Web DesignZheng Su Wan(2009Computer network technology)Abstract: E-commerce sites is in Windows system environment, with Mysql database development platform, and Apache Internet information server, using PHP (Hypertext Preprocessor) technology development of online shopping system.This system is divided into two parts of the front desk and the background, the front office mainly for consumers, mainly including commodity exhibition, the register, shopping cart management, goods collection management, order management function module; The background by the controller used, mainly including commodities management, purchase management, order management, system management function module. Through these function, to give businesses to provide a dynamic, interactive, has the goods, the function such as management system to provide e-commerce platform.Keyword:E-commerce sites;HP development technology;Database development ;Network shopping目录摘要: (1)1、绪论 (2)1.2 技术可行性分析 (3)1.2.1 动态网站 (3)1.2.2 PHP语言 (3)1.2.3 MySQL数据库 (4)1.2.4动画的制作软件 (4)2、商城设计与功能开发 (4)2.1去除ECSHOP版权与标志、 (4)2.2 ECSHOP后台为订单增加备注功能 (6)2.3将订单状态设为等待客户确认 (8)2.4商品扩展名功能开发 (10)2.5 多货币解决方案 (10)2.6 AJAX更新购物车数量功能 (16)2.7采用AJAX技术实现产品页的购买数量 (22)2.8 ECSHOP商品展示放大镜效果 (23)2.9 ECSHOP增加商品颜色选择功能 (23)2.10商品组合套餐功能 (25)2.11限时购功能开发 (26)3、总结 (28)4、致谢 (28)1、绪论1.1网站开发背景在已跨入21世纪的今天,随着时代的飞速发展,计算机网络也在飞速的发展和普及,人们也越来越多的在网上交流、交易、通讯等等。
修改ecshop的71种技巧
![修改ecshop的71种技巧](https://img.taocdn.com/s3/m/d9e213fc941ea76e58fa041a.png)
如何显示促销产品,为什么首页flash下面有一片空白的处所,如何去掉?首先到ecShop首页flash下面有两个空白的处所,第一个是用来显示促销产品的,右边是用来显示品牌的。
(1)显示促销产品
后盾-商品办理-商品列表-编辑产品-通用信息-勾上促销价-填写促销期限-保存-更新缓存
前台flash下空白处就被填充了!
16:收货人详细信息js弹出框的提示脚本在哪个文件
答复:languages\zh_cn\shopping_flow.php[好比$_LANG['flow_js']['country_not_null']=’请您选择收货人所在国度!’;]
17:网站通知布告代码段在那边
答复:index.php文件中,$smarty-assign(‘shop_notice’,$_CFG['shop_notice']);//商店通知布告代码段节制通知布告
14、首页模板在哪个文件,头部模板,底部模板个什么文件称号
答复:首页模板在为index.dwt,头部模板在library/page_header.lbi,底部文件在library/page_footer.lbi
15:网站封闭了注册,如何修改「该网店暂停注册」字样
答复:languages\zh_cn\common.php中$_LANG['shop_register_closed']=’该网店暂停注册’;修改该文字就可以或许了
8、如何修改产品图片的大小
答复:在ecshop/themes/default/style.css中,
找到{width:100px;height:100px;border:4px
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
ECshop 所有系统通用 多货币解决方案1、首先在我们的后台网店设置里要添加汇率转换的功能,如何添加网店功能自己摸索一下,你要把添加的功能 插入表里。
如图:我们的汇率都是和美元进行转换的。
2、开始前台实现:首先我们在首页加上多语言的链接如图:我们看下他的url?View Code HTML10 11 12 13 14 15 16 <ul><li><a href="{$url_head}¤cy=USD"><imgsrc="images/USD.gif"/> US Dollar</a></li> <li><a href="{$url_head}¤cy=EUR"><img src="images/EUR.gif"/> Euro</a></li> <li><a href="{$url_head}¤cy=GBP"><img src="images/GBP.gif"/> British Pound</a></li> <li><a href="{$url_head}¤cy=CNY"><img src="images/CNY.gif"/> China RMB</a></li> <li><a href="{$url_head}¤cy=AUD"><imgsrc="images/AUD.gif"/> Austrilian Dollar</a></li></ul>这个{$url_head} 我是重新建了一个文件 conn.php 放到首页 每个文件调用 //路径处理$url_this = "[url=http://]http://".$_SERVER[/url]['HTTP_HOST'].$_SERVER['PHP_SELF']."?id=".$_GET['id']; $smarty->assign("url_head",$url_this);3、我们发现都是在每个页面后面传了一次get 值 那么在那接这些get 值呢 我们肯定要找每个页面的共同文件 不难想到init.php我在init.php 的最后加入?View Code HTML1011121314151617[code]$currency = $_GET['currency']; if($currency!=""){ $_SESSION['currency'] = $currency; } if($_SESSION['currency'] == '') { $_SESSION['currency'] = 'USD'; } 这个代码大家明白吧 我接到get 值后 给了session 如果session 不存在话 我们默认就是usd 这样每个页面都可以获得当前的session 值 .4、我们通过以上操作至少在每个页面可以搞定客户选的货币是什么,下来我们就考虑如何解决显示问题,如果每个页面都修改显示goods 价格那多麻烦 啊,我们熟悉ecshop 的朋友不难想到我们所有显示的价格都是在一个函数里进行里处理 ,这应该感谢官方的技术人员 代码写的好 当然是 lib_common.php 里得price_format ()这个函数 我们想一下 如果在这搞定是不是所有显示都搞定了 我们就从这入手 以下是我修改后的函数?View Code HTML1011121314151617181920212223242526272829303132function price_format($price, $change_price = true) { $currency = $_SESSION['currency']; $rate = explode(',',$GLOBALS['_CFG']['rate']); if($currency == 'USD') { $price = $price*$rate[0]; } if($currency == 'CNY') { $price = $price*$rate[3]; } if($currency == 'EUR') { $price = $price*$rate[1]; } if($currency == 'GBP') { $price = $price*$rate[2]; } if($currency == 'AUD') { $price = $price*$rate[4];333435363738394041 424344454647484950 51525354 55565758 59606162 6364656667686970717273747576} if ($change_price && defined('ECS_ADMIN') === false) { switch ($GLOBALS['_CFG']['price_format']) { case 0: $price = number_format($price, 2, '.', ''); break; case 1: // 保留不为 0 的尾数 $price = preg_replace('/(.*)(.)([0-9]*?)0+$/', '123', number_format($price, 2, '.', '')); if (substr($price, -1) == '.') { $price = substr($price, 0, -1); } break; case 2: // 不四舍五入,保留1位 $price = substr(number_format($price, 2, '.', ''), 0, -1); break; case 3: // 直接取整 $price = intval($price); break; case 4: // 四舍五入,保留 1 位 $price = number_format($price, 1, '.', ''); break; case 5: // 先四舍五入,不保留小数 $price = round($price); break; } } else { $price = number_format($price, 2, '.', ''); } switch ($currency) { case 'USD': return sprintf($GLOBALS['_CFG']['currency_format'], $price);7778798081828384break; case 'CNY': return sprintf($GLOBALS['_CFG']['cprice_format'], $price); break; case 'EUR': return sprintf($GLOBALS['_CFG']['aprice_format'], $price); break;case 'GBP':return sprintf($GLOBALS['_CFG']['ybprice_format'],$price);break;case 'AUD':return sprintf($GLOBALS['_CFG']['aoprice_format'],$price);break;}}$rate = explode(‘,’,$GLOBALS['_CFG']['rate']); 这句是从数据库获得我们当时的参数 然后我们计算 同时返回值的时候我们用了系统设置的符号 解决问题 前台就这样搞定。
5、有关交易 后台的操作我做简单的介绍 我们只是解决了显示问题 其实我们实质的数据还是美元 在我们提交订单的时候 我们在order_goods 表加俩个字段一个是客户选的货币方式 这样生成订单后 当我进入我的会员中心我依然可以看到我购买人民币是多少钱 我们读取数据库的方式进行换算,另外一个字段是我们换算后的金额。
当然我们之前美元的总金额都是在的 。
在支付的时候 我们给贝宝付参数 就是货币类型 。