全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

微信小程序 商城开发(ecshop )简单实例

最近小程序特别火,所以我们公司也针对ecshop平台对接了小程序

包括完整的用户系统和购物体统

用户系统:收货地址,订单管理,消息管理,优惠券管理等等

购物系统支付购物车管理,微信支付等等







相信有很多小伙伴都用的是ecshop作为自己的商城,最近小程序又火了,于是就有人问ecshop对接小程序怎么做。

正好最近在开发一个对接ecshop的小程序项目,就将我的一些开发经验分享一下。

一:扫描小程序二维码后的用户信息的获取和缓存

获取用户信息需要用到两个api

wx.login(OBJECT)

调用接口获取登录凭证(code)进而换取用户登录态信息,包括用户的唯一标识(openid) 及本次登录的 会话密钥(session_key)。用户数据的加解密通讯需要依赖会话密钥完成。

wx.getUserInfo(OBJECT)

获取用户信息,需要先调用 wx.login 接口。

获取缓存需要用到的api

wx.setStorageSync(KEY,DATA)

将 data 存储在本地缓存中指定的 key 中,会覆盖掉原来该 key 对应的内容,这是一个同步接口。

下面就是具体实例代码:

我们可以将这段写在公共的app.js页面

//app.js 
App({ 
 onLaunch: function() { 
 }, 
 getUserInfo: function (cb) { 
 var that = this 
 if (this.globalData.userInfo) { 
  typeof cb == "function" && cb(this.globalData.userInfo) 
 } else { 
  //调用登录接口 
  wx.login({ 
  success: function (res) { 
   if (res.code) { 
   var userid = wx.getStorageSync('scuserid') 
   var sc_session_id = wx.getStorageSync('sc_session_id') 
   var openid = wx.getStorageSync('sc_session_id') 
   if(!userid){ 
     wx.request({ 
     url: 'xxxx/data.php?action=sendCode', 
     data: { 
      code: res.code, 
     }, 
     success: function (res) { 
      //console.log(res) 
      var status = res.data.status 
      if(status == 1){ 
       wx.showToast({ 
       title: res.data.message, 
       icon: 'success', 
       duration: 2000 
       }) 
      }else if(status == 2){ 
       var scuserid = res.data.userid 
       if(scuserid > 0){ 
        //缓存user_id 
        wx.setStorageSync('scuserid', scuserid) 
        wx.setStorageSync('openid', res.data.openid) 
        wx.setStorageSync('sc_session_id', res.data.session_id) 
       } 
      }else{ 
       //缓存session_id 
       wx.setStorageSync('openid', res.data.openid) 
       wx.setStorageSync('sc_session_id', res.data.session_id) 
       //获取用户信息 
       wx.getUserInfo({ 
       success: function (res) { 
        that.globalData.userInfo = res.userInfo 
        typeof cb == "function" && cb(that.globalData.userInfo) 
        //console.log(res); 
        wx.request({ 
        url: 'xxxx/data.php?action=saveUserInfo', 
        data: { 
         userinfo: res.userInfo, 
         openid: wx.getStorageSync('openid'), 
        }, 
        success: function (res) { 
         //console.log(res.data) 
         var status = res.data.status 
         if(status == 1){ 
          wx.showToast({ 
           title: res.data.message, 
           icon: 'success', 
           duration: 2000 
          }) 
         }else{ 
          var scuserid = res.data.userid 
          if(scuserid > 0){ 
          //缓存user_id 
          wx.setStorageSync('scuserid', scuserid) 
          } 
         } 
        } 
        }) 
       } 
       }) 
      } 
     } 
     }) 
   } 
   } 
  } 
  }) 
 } 
 }, 
 globalData: { 
 userInfo: null 
 } 
}) 

二:获取微信用户的信息以及如何将用户信息缓存起来

要获取用户的地理信息则要用到

wx.getLocation(OBJECT)

获取当前的地理位置、速度。当用户离开小程序后,此接口无法调用;当用户点击“显示在聊天顶部”时,此接口可继续调用。

具体实例代码:

//获取纬度,经度 
 wx.getLocation({ 
  type: 'wgs84', 
  success: function (res) { 
  var latitude = res.latitude 
  var longitude = res.longitude 
  wx.request({ 
   url: 'http://XXXXXX/data.php?action=get_dq', 
   data: { 
   latitude: latitude, 
   longitude: longitude 
   }, 
   headers: { 
   'Content-Type': 'application/json' 
   }, 
   success: function (res) { 
   //console.log(res.data) 
   var province = res.data.result.addressComponent.province 
   //console.log(province) 
   var city = res.data.result.addressComponent.city 
   var district = res.data.result.addressComponent.district 
   var diqu = province+city+district 
   //缓存当前所在地区 
   wx.setStorageSync('dq_diqu', diqu) 
   wx.setStorageSync('dq_district', district) 
   } 
  }) 
  } 
 }) 
if($act=="get_dq"){ 
 //获取当然城市 
 //http://api.map.baidu.com/geocoder/v2/?ak=327381a342077a8f3d584251b811cce5&callback=renderReverse&location=30.593099,114.305393&output=json 
 //纬度 
 $latitude = $_REQUEST['latitude']; 
 //经度 
 $longitude = $_REQUEST['longitude']; 
 $url = 'http://api.map.baidu.com/geocoder/v2/?ak=327381a342077a8f3d584251b811cce5&location='.$latitude.','.$longitude.'&output=json'; 
 $result = file_get_contents($url); 
 exit($result); 
}

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


# 微信小程序  # 商城开发(ecshop  #   # 商城开发  # 微信小程序商城项目之购物数量加减(3)  # 微信小程序商城项目之商品属性分类(4)  # 微信小程序商城项目之侧栏分类效果(1)  # 微信小程序购物商城系统开发系列-目录结构介绍  # 微信小程序购物商城系统开发系列-工具篇的介绍  # 微信小程序商城项目之淘宝分类入口(2)  # 自己的  # 的是  # 有很多  # 这段  # 这是一个  # 我们可以  # 希望能  # 收货  # 怎么做  # 购物车  # 就将  # 谢谢大家  # 都用  # 写在  # 接了  # 如何将  # 火了  # 则要  # 购物系统  # 小伙伴 


相关文章: 香港服务器部署网站为何提示未备案?  制作证书网站有哪些,全国城建培训中心证书查询官网?  ui设计制作网站有哪些,手机UI设计网址吗?  深圳网站制作案例,网页的相关名词有哪些?  建站之星代理如何获取技术支持?  重庆网站制作公司哪家好,重庆中考招生办官方网站?  制作网站怎么制作,*游戏网站怎么搭建?  如何通过服务器快速搭建网站?完整步骤解析  电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?  如何快速搭建支持数据库操作的智能建站平台?  c++怎么用jemalloc c++替换默认内存分配器【性能】  ,怎么用自己头像做动态表情包?  建站之星后台密码遗忘如何找回?  网站制作软件有哪些,制图软件有哪些?  C++如何将C风格字符串(char*)转换为std::string?(代码示例)  建站ABC备案流程中有哪些关键注意事项?  贸易公司网站制作流程,出口贸易网站设计怎么做?  建站之星CMS五站合一模板配置与SEO优化指南  英语简历制作免费网站推荐,如何将简历翻译成英文?  如何在IIS7上新建站点并设置安全权限?  如何在Windows 2008云服务器安全搭建网站?  官网自助建站系统:SEO优化+多语言支持,快速搭建专业网站  如何用花生壳三步快速搭建专属网站?  香港服务器网站推广:SEO优化与外贸独立站搭建策略  宝华建站服务条款解析:五站合一功能与SEO优化设置指南  阿里云网站搭建费用解析:服务器价格与建站成本优化指南  ,巨量百应是干嘛的?  香港服务器租用费用高吗?如何避免常见误区?  如何在Windows虚拟主机上快速搭建网站?  已有域名和空间如何快速搭建网站?  如何快速搭建高效可靠的建站解决方案?  香港服务器建站指南:外贸独立站搭建与跨境电商配置流程  深入理解Android中的xmlns:tools属性  已有域名和空间如何搭建网站?  宿州网站制作公司兴策,安徽省低保查询网站?  Dapper的Execute方法的返回值是什么意思 Dapper Execute返回值详解  香港服务器网站卡顿?如何解决网络延迟与负载问题?  制作农业网站的软件,比较好的农业网站推荐一下?  网站制作大概要多少钱一个,做一个平台网站大概多少钱?  如何在服务器上配置二级域名建站?  如何通过可视化优化提升建站效果?  武汉网站如何制作,黄黄高铁武穴北站途经哪些村庄?  如何快速查询域名建站关键信息?  如何在VPS电脑上快速搭建网站?  已有域名如何免费搭建网站?  如何通过老薛主机一键快速建站?  外贸公司网站制作,外贸网站建设一般有哪些步骤?  宝塔面板如何快速创建新站点?  高防服务器租用如何选择配置与防御等级?  ,柠檬视频怎样兑换vip? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。