这个笔记得做好。

1.vue页面的点击事件
import {login,loginy,wxLog,wxLogin,logout} from '../network/login'
wxloginBtn() {
          let _this = this
          wxLog()                               //调取微信登录页面的js方法
          this.alertSzTipsFlage = true
          this.tips = '正在登录...'
          setTimeout(function () {
                _this.alertSzTipsFlage = false
          }, 1500)
          this.wxLoginUserInfo()
        },
        wxLoginUserInfo(){
          let _this = this
          let userInfo = localStorage.getItem("wxUserInfo")              //拾取在js页面localStorage存储到用户信息
          if (null != userInfo) {
            userInfo = JSON.parse(userInfo)
            wxLogin(userInfo).then(res => {                                       //这里是常规登录部分,这里传递的参数userInfo的openid,nickname,headimgurl
              if (res.token) {
                window.localStorage.setItem("user", JSON.stringify(res))
                this.alertSzTipsFlage = true
                this.tips = '微信登录成功'
                setTimeout(function () {
                  _this.alertSzTipsFlage = false
                  _this.$router.push('/index')
                }, 1500)
              } else {
                this.alertSzTipsFlage = true
                this.tips = '微信登录失败'
                setTimeout(function () {
                    _this.alertSzTipsFlage = false
                }, 1500)
              }
            })
          }else {
            this.alertSzTipsFlage = true
            this.tips = '微信登录失败'
            setTimeout(function () {
                _this.alertSzTipsFlage = false
            }, 1500)
          }
        }
2.拾取到用户微信登录信息后调用登录接口
export function wxLogin(userInfo) {
  return request({
    url:'/api/weChatLogin',
    data:{
      "mobile":userInfo.openid,
      "nickname":userInfo.nickname,
      "logo":userInfo.headimgurl
    },
    method:'post',
    headers:{
      'post':{'Content-Type': 'application/json;charset=UTF-8'}
    }
  })
}
至此微信登录成功
3.之前js页面是如何拿取到用户登录权限并存储微信登录权限的?在2.下面粘贴复制:
export function wxLog(){
  let self = this;
  getService()
  // 微信授权登录对象
  let aweixin = null;
  // 当前环境支持的所有授权登录对象
  let auths = null;
  // 获取登录授权认证服务列表,单独保存微信登录授权对象
  function getService(){
    plus.oauth.getServices(function(services){
      //plus.nativeUI.alert("services:"+JSON.stringify(services));
      auths = services;
      authLogin()
    }, function(e){
      plus.nativeUI.alert("获取登录授权服务列表失败,请稍后重试");
      plus.nativeUI.alert("获取登录授权服务列表失败:"+JSON.stringify(e));
    } );
  }
  // 获取微信登录授权对象后可进行登录认证操作
  function authLogin(){
    for(let i = 0; i < auths.length; i++){
      if(auths[i].id == 'weixin'){
        aweixin = auths[i];
        break;
      }
    }
    if(!aweixin){
      plus.nativeUI.alert("当前环境不支持微信登录");
      return;
    }
    if(!aweixin.authResult){
      aweixin.login(function(e){
        //plus.nativeUI.alert("登录认证成功!"+JSON.stringify(e));
        authUserInfo()
      }, function(e){
        //plus.nativeUI.alert("登录认证失败: "+JSON.stringify(e));
      } );
    }else{
      authUserInfo()
      console.log("已经登录认证!");
    }
  }
  // 获取微信登录授权对象后获取用户信息操作
  function authUserInfo(){
    if(!aweixin){
      plus.nativeUI.alert("当前环境不支持微信登录");
      return;
    }
    if(aweixin.authResult){
      aweixin.getUserInfo( function(e){
        //登录成功处理
        //plus.nativeUI.alert("获取用户信息成功:"+JSON.stringify(aweixin.userInfo));
        window.localStorage.setItem("wxUserInfo", JSON.stringify(aweixin.userInfo));
        authLoginOut(); //注销登录防止切换账号获取到旧信息
      }, function(e){
        console.log("获取用户信息失败: "+JSON.stringify(e));
      } );
    }else{
      plus.nativeUI.alert("未登录认证!");
    }
  }
  // 注销登录认证
  function authLoginOut(){
    if(!aweixin){
      plus.nativeUI.alert("当前环境不支持微信登录");
      return;
    }
    aweixin.logout(function(e){
      // plus.nativeUI.alert("注销登录认证成功!"+JSON.stringify(e));
    }, function(e){
      console.log("注销登录认证失败: "+JSON.stringify(e));
    });
  }
}

vue项目hbuilder打包-微信登录调取手机微信登录权限的更多相关文章

  1. vue项目 构建 打包 发布 三部曲

    一.vue项目的创建 1.首先第一肯定是要有Node.js及npm这个不多说了2.安装脚手架 此时可以直接浏览-但是现在肯定有很多小白想将他发布到gitHub上并可以浏览,使用vue全家桶制作自己的博 ...

  2. Vue项目的打包

    vue项目的打包 更改config文件夹下的index.js里的assetsPublicPath路径    将 “/”  改为  “./” build: { env: require('./prod. ...

  3. vue项目如何打包扔向服务器

    vue项目如何打包扔向服务器   当我们将 vue 项目完成后,面临的就是如何将项目进行打包上线,放到服务器中.我使用的是 vue-cli(simple) 脚手架,所以就讲一下如何将项目进行打包,并放 ...

  4. h5微信页面在手机微信端和微信web开发者工具中都能正常显示,但是在pc端微信浏览器上打不开(显示空白)

    h5微信页面在手机微信和微信开发者工具中都能正常显示,但是在pc端微信浏览器上打不开或者数据加载不出来. 原因:pc端微信浏览器不支持ES6语法,我的代码中使用了一些ES6的特性 解决:将ES6转换为 ...

  5. vue项目webpack打包后有的文件big 问题

    vue项目打包的时候,有的big, 超过1M,   需要进行优化,方法有: 1.  非首屏图片,可以采用懒加载的方式,  如:图片的懒加载,  vue中路由的懒加载 等 2. 各个模块, 采用如sea ...

  6. vue项目如何打包前后端不分离发布手把手教学apache、nginx

    vue项目如何不分离发布 1.首先yarn build 我用了vue-cli脚手架,bulid后的dist文件夹里的index.html有加版本号,那么为什么需要加版本号呢? a.回滚 b.解决浏览器 ...

  7. vue项目 webpack打包后,图片路径是绝对路径

    vue项目,使用webpack打包,虽然在全局把路径改成了相对的路径,但是图片引用的路径还是异常的,解决办法如下: 1.config文件夹下index.js中: assetsPublicPath:&q ...

  8. Springboot项目与vue项目整合打包

    我的环境 * JDK 1.8 * maven 3.6.0 * node环境 1.为什么需要前后端项目开发时分离,部署时合并? 在一些公司,部署实施人员的技术无法和互联网公司的运维团队相比,由于各种不定 ...

  9. vue项目中打包编译后,CSS样式【-webkit-box-orient: vertical】打包后丢失问题

    最近在做vue项目的时候页面处理多行文本样式时用到了-webkit-box-orient: vertical这个属性,本地跑项目没问题,但是打包放到服务器后发现这个属性丢失了.如下图: 后来在网上查了 ...

  10. Vue项目如何打包问题总结

    当我们将 vue 项目完成后,面临的就是如何将项目进行打包上线,放到服务器中.我使用的是 vue-cli(simple) 脚手架,所以就讲一下如何将项目进行打包,并放到 tomcat 上. 先来描述一 ...

随机推荐

  1. 数字电路之MOS设计

    数字电路之MOS设计 1.MOS的基本性质 MOS,即场效应管,四端器件,S.D.G.B四个端口可以实现开和关的逻辑状态,进而实现基本的逻辑门.NMOS和PMOS具有明显的对偶特性:NMOS高电平打开 ...

  2. KingbaseES参数track_activity_query_size介绍

    背景 同事A在客户现场,最近注意到客户的主数据库性能有所下降,尤其是在高峰时段.怀疑可能有一些复杂的查询影响了数据库的性能,但尚未确定具体是哪些查询. 为了诊断问题,A决定查看高峰期正在执行的查询,先 ...

  3. apue 文章集锦

    与 apue 相关的一系列文章比较庞杂,按原书目录整理了一下,形成目录,方便系统性阅读. 另外这些文章是在我快读完的时候开始写的,之前的一些章节还多有遗漏,后面慢慢补上. chapter 1: UNI ...

  4. 如在 Java 中分割 Excel 工作表

    前言 在Excel中创建的大多数商业报告不是单页的文档,而是包含了多个上下文相关的信息,这些信息被存储在多个工作表中.例如我们的一些地区销售报告.按部门分类的员工记录.每家店铺的库存清单等. 然而,随 ...

  5. 使用OHOS SDK构建freetype

    参照OHOS IDE和SDK的安装方法配置好开发环境. 从github下载源码. 执行如下命令: git clone https://github.com/freetype/freetype.git ...

  6. OpenHarmony 4.0 Beta1发布,邀您体验

      初夏之际,OpenAtom OpenHarmony(简称"OpenHarmony") 4.0 Beta1版本如期而至.4.0 Beta1版本在3.2 Release版本基础上, ...

  7. 开源相机管理库Aravis例程学习(一)——单帧采集single-acquisition

    目录 简介 源码 函数说明 arv_camera_new arv_camera_acquisition arv_camera_get_model_name arv_buffer_get_image_w ...

  8. IntelliJ IDEA 配置类注释模板

    菜单栏依次点击 File > Settings 在弹出窗口中找到 Editor >File and Code Templates 在右侧中 Files 选项卡中找到 Class. 在右侧输 ...

  9. 抓包整理————tcp 三次握手性能优化[十]

    前言 tcp 三次握手性能优化. 正文 服务器三次握手流程示例: 下面就是3次握手的过程: 知道这个有什么用呢? 我举一个我使用到的例子哈. 比如有很多 tcp 连接到一台机器上机器上,那么tcp_m ...

  10. nginx重新整理——————热部署和日志切割[三]

    前言 简单演示热部署和日志切割. 正文 什么是热部署了,我们前文也说过了一个编译后的nginx 二进制. 热部署就是无需停止现有的nginx,替换正在运行的nginx. 步骤: 复制nginx 二进制 ...