未绑定企业号开发者_微信开发者工具提示未绑定企业号开发者 - CSDN
精华内容
参与话题
  • 微信开发者工具开发企业微信提示:未绑定企业号开发者 如图(1) 然后直接拉到底: 红框,开发者工具,选中后创始人就可以进行在微信开发者工具里开发了。 友情提示:链接微信在现在的版本里你是找不到的...

    微信开发者工具开发企业微信提示:未绑定企业号开发者

    如图(1)

     

    然后直接拉到底:

    红框,开发者工具,选中后创始人就可以进行在微信开发者工具里开发了。

    友情提示:链接微信在现在的版本里你是找不到的。

    展开全文
  • 调试第三方应用时同样也会提示未绑定企业号开发者。 下面将针对如何调试自建应用出现的企业号绑定问题。 1、首先,将自己设置为企业微信的管理员。 2、进入企业微信---我的企业---微工作台---勾选开发者工具 ...

    强调一下:微信开发者工具可以调试企业微信的自建应用,暂时还不支持调试第三方应用。调试第三方应用时同样也会提示未绑定企业号开发者。

    下面将针对如何调试自建应用出现的企业号未绑定问题。

    1、首先,将自己设置为企业微信的管理员。

     2、进入企业微信---我的企业---微工作台---勾选开发者工具 

     然后在微信开发者工具中打开就可以了。

    关于第三方应用目前可以先在手机端企业微信中安装测试应用,然后在手机端进行调试。

     

    展开全文
  • 创建应用后即可测试授权应用 点击“测试授权” 确认发起授权安装测试 ...在企业号管理员确认授权后微信后台会向开发者后台推送消息,开发者后台必须根据“第三方回调协议——授权成功推送auth_code事件...

     

    创建应用后即可测试授权应用

     

    点击“测试授权”

     

     

     

     确认发起授权安装测试

     

     

    登陆企业号

     

     勾选需要授权的应用

     

     对应用进行可见范围设置

     

     授权成功后等待跳转即可

     


     

     在企业号管理员确认授权后微信后台会向开发者后台推送消息,开发者后台必须根据“第三方回调协议——授权成功推送auth_code事件”规则响应推送。

    使用方式为‘线上自助注册授权使用’的套件,从企业号第三方官网发起授权时,微信服务器会向应用提供商的套件事件接收 URL(创建套件时填写)推送授权成功通知;从应用提供商网站发起的应用套件授权流程,由于授权完成时会跳转应用提供商管理后台,微信服务器不会向应用提供商推送授权成功通知。

    https://127.0.0.1/suite/receive?msg_signature=3a7b08bb8e6dbce3c9671d6fdb69d15066227608&timestamp=1403610513&nonce=380320359

    POST数据示例

    {
    	<xml>
    		<SuiteId><![CDATA[wxfc918a2d200c9a4c]]></ SuiteId>
    		<AuthCode><![CDATA[AUTHCODE]]></AuthCode>
                   <InfoType><![CDATA[create_auth]]></InfoType>
    		<TimeStamp>1403610513</TimeStamp>
    	</xml>	
    }
    

    应用提供商在收到推送消息后需要返回字符串success,返回值不是 success 时,会把返回内容当作错误信息显示(需要以UTF8编码)。

    字段说明

     

    参数说明
    SuiteId 应用套件的SuiteId
    AuthCode 授权的auth_code,用于获取企业的永久授权码
    InfoType create_auth
    TimeStamp 时间戳

     


     

    获取企业号的永久授权码

    该API用于使用临时授权码换取授权方的永久授权码,并换取授权信息、企业access_token。

    注:临时授权码使用一次后即失效

    接口调用请求说明

    https请求方式: POST

    https://qyapi.weixin.qq.com/cgi-bin/service/get_permanent_code?suite_access_token=SUITE_ACCESS_TOKEN

    POST数据示例

    {
    	"suite_id":"id_value" ,
    	"auth_code": "auth_code_value"
    }
    

    请求参数说明

    参数说明
    suite_id 应用套件id
    auth_code 临时授权码,会在授权成功时附加在redirect_uri中跳转回应用提供商网站。长度为64至512个字节

    返回结果示例

    {
    	"access_token": "xxxxxx", 
    	"expires_in": 7200, 
    	"permanent_code": "xxxx", 
    	"auth_corp_info": 
    	{
    		"corpid": "xxxx",
    		"corp_name": "name",
    		"corp_type": "verified",
    		"corp_round_logo_url": "xxxxxx",
    		"corp_square_logo_url": "yyyyy",
    		"corp_user_max": 50,
    		"corp_agent_max": 30,
                   "corp_full_name":"full_name",
                   "verified_end_time":1431775834,
                   "subject_type": 1,
                   "corp_wxqrcode": "zzzzz"
    	},
    	 "auth_info": {
                   "is_new_auth":true,
                    "agent" : [
                    {
                         "agentid":1,
                         "name":"NAME",
                         "round_logo_url":"xxxxxx",
                         "square_logo_url":"yyyyyy",
                         "appid":1,
                         "privilege":{
                              "level":1,
                              "allow_party":[1,2,3],
                              "allow_user":["zhansan","lisi"],
                              "allow_tag":[1,2,3],
                              "extra_party":[4,5,6],
                              "extra_user":["wangwu"],
                              "extra_tag":[4,5,6]
                         }
                    },
                    {
                         "agentid":2,
                         "name":"NAME2",
                         "round_logo_url":"xxxxxx",
                         "square_logo_url":"yyyyyy",
                         "appid":5
                    }
                    ]
            },
           "auth_user_info":
           {
                   "email":"xxxx@aaa.com",
                   "mobile":"1234567890",
                   "userid":"aa"
           }
    }
    

    结果参数说明

     

    参数说明
    access_token 授权方(企业)access_token
    expires_in 授权方(企业)access_token超时时间
    permanent_code 企业号永久授权码。长度为64至512个字节
    corp_info 授权方企业信息
    corpid 授权方企业号id
    corp_name 授权方企业号名称
    corp_type 授权方企业号类型,认证号:verified, 注册号:unverified,体验号:test
    corp_round_logo_url 授权方企业号圆形头像
    corp_square_logo_url 授权方企业号方形头像
    corp_user_max 授权方企业号用户规模
    corp_full_name 所绑定的企业号主体名称
    subject_type 企业类型,1. 企业; 2. 政府以及事业单位; 3. 其他组织, 4.团队号
    verified_end_time 认证到期时间
    corp_wxqrcode 授权方企业号二维码
    auth_info 授权信息
    is_new_auth 是否采用了新的授权,没有该字段或者该字段为false表示是旧授权,true表示是新授权。目前所有授权均为true。
    agent 授权的应用信息
    agentid 授权方应用id
    agent:name 授权方应用名字
    square_logo_url 授权方应用方形头像
    round_logo_url 授权方应用圆形头像
    appid 服务商套件中的对应应用id
    privilege 应用对应的权限
    allow_party 应用可见范围(部门)
    allow_tag 应用可见范围(标签)
    allow_user 应用可见范围(成员)
    extra_party 额外通讯录(部门)
    extra_user 额外通讯录(成员)
    extra_tag 额外通讯录(标签)
    level 权限等级, 1: 标识信息只读, 2:信息只读, 3:信息读写
    auth_user_info 授权管理员的信息
    auth_user_info:email 授权管理员的邮箱,可能为空(管理员通讯录中邮箱被清空)
    auth_user_info:mobile 授权管理员的手机号,可能为空(管理员在通讯录中未设置手机号)
    auth_user_info:userid 授权管理员的userid,可能为空(管理员不在通讯录中)


     

     

    推送事件的推送地址是创建套件时填写的回调地址,所以在“微信企业号第三方应用开发[一]——创建套件”的代码上继续修改

    /**
         * 微信回调响应
         * @author:leap
         * @MethodName: callback 
         * @Description: 
         * @param req
         * @param res
         * @date:2016年8月25日
         */
        @RequestMapping(value="callback")
        @ResponseBody
        public void callback(HttpServletRequest req, ServletResponse res){
            
            /** url中$CORPID$模板替换后的corpid **/
            String corpid = req.getParameter("corpid");
            /** url中的签名 **/
            String msgSignature = req.getParameter("msg_signature");
            /** url中的时间戳 **/
            String timestamp = req.getParameter("timestamp");
            /** url中的随机字符串 **/
            String nonce = req.getParameter("nonce");
            /** 创建套件时验证回调url有效性时传入**/
            String echostr = req.getParameter("echostr");
    
            WxAuthorizeLogic wxAuthorizeLogic = new WxAuthorizeLogic();
            String result = "";
            try {
                if(!Utils.isBlank(echostr)){    
                    /*
                     * 验证回调url有效性
                     * 响应需对echostr参数解密并原样返回echostr明文(不能加引号,不能带bom头,不能带换行符)
                     * 注:创建解密对象时传入的是CORP_ID而不是SUITE_ID
                     */
                    String verifyURLResult = wxAuthorizeLogic.verifyURL(msgSignature, 
                            timestamp, nonce, echostr, corpid);
                    res.getWriter().write(verifyURLResult);    
                }else {
                    //获取加密信息
                    String postData = IOUtils.toString(req.getInputStream(), "utf-8");
                    WxSaaSCallbackInfo callbackInfo = null;
                    if("$CORPID$".equals(corpid)){  //第三方回调协议的推送不会替换$CORPID$,普通消息推送才会替换
                        //获取解密信息,注意传入的是SUITE_ID不是CORP_ID
                        callbackInfo = wxAuthorizeLogic.getDecryptCallbcakInfo(
                                postData, msgSignature, timestamp, nonce, WXBase.SUITE_ID);
                    }else{
    //普通消息推送时是使用URL中的$CORPID$进行解密 callbackInfo
    = wxAuthorizeLogic.getDecryptCallbcakInfo( postData, msgSignature, timestamp, nonce, corpid); } //处理不同类型的推送事件 boolean isResponseSuccess = false; String infoType = callbackInfo.getInfoType(); if(Utils.isBlank(infoType)){ return; } switch (infoType) { case "suite_ticket": //推送suite_ticket isResponseSuccess = wxAuthorizeLogic.dealSuiteTicketEvent(callbackInfo); break; case "create_auth": //授权成功推送auth_code事件 isResponseSuccess = wxAuthorizeLogic.dealCreateAuthEvent(callbackInfo); break; case "change_auth": //变更授权的通知 isResponseSuccess = wxAuthorizeLogic.dealChangeAuthEvent(callbackInfo); break; case "cancel_auth": //取消授权的通知 isResponseSuccess = wxAuthorizeLogic.dealCancelAuthEvent(callbackInfo); break; case "contact_sync": //通讯录变更通知 isResponseSuccess = wxAuthorizeLogic.dealContactSyncEvent(callbackInfo); break; default: break; } /* * 响应回调 * 应用提供商在收到推送消息后需要返回字符串success, * 授权时返回值不是 success 时,会把返回内容当作错误信息显示(需要以UTF8编码) */ if(isResponseSuccess){ res.getWriter().write("success"); }else{ res.getWriter().write("false"); } } } catch (Exception e) { e.printStackTrace(); } }

     

    注:

    • wxAuthorizeLogic.getDecryptCallbcakInfo方法只是利用WXBizMsgCrypt解密回调信息,然后把xml内容转为实体,此处代码省略
    • wxAuthorizeLogic.dealCreateAuthEvent方法主要是同步用户组织架构、保存授权方企业号对应的永久授权码,具体业务逻辑需自行设计

     


    [目录]

    [上一篇]微信企业号第三方应用开发[二]——创建应用

    [下一篇]微信企业号第三方应用开发[四]——用户登录应用

     


    消息:新博客地址 blog.leapmie.com,以后的更新都会在新博客首发,感谢支持~(园子视情况更新)


     

    转载于:https://www.cnblogs.com/leap/p/5759079.html

    展开全文
  • 微信JS接口- 企业号开发者接口文档

    千次阅读 2019-01-22 14:05:04
    目录 1 概述 1.1 使用说明 1.1.1 步骤一:引入JS文件 1.1.2 步骤二:通过config接口注入权限验证配置 1.1.3 步骤三:通过ready接口处理成功验证 1.1.4 步骤四:通过error接口处理失败验证 ...


    目录

    概述

    微信JS-SDK是微信公众平台面向网页开发者提供的基于微信内的网页开发工具包。

    通过使用微信JS-SDK,网页开发者可借助微信高效地使用拍照、选图、语音、位置等手机系统的能力,同时可以直接使用微信分享、扫一扫等微信特有的能力,为微信用户提供更优质的网页体验。

    此文档面向网页开发者介绍微信JS-SDK如何使用及相关注意事项。

    使用说明

    在使用微信JS-SDK对应的JS接口前,需确保已获得使用对应JS接口的权限,可在下表中根据自己的帐号角色查看。 企业号帐号角色分为注册号和认证号,其中认证号拥有更多的JS-SDK权限,具体详见下方表格:

    功能1 接口 注册号 认证号
    基础接口 判断当前客户端版本是否支持指定JS接口
    分享接口 获取“分享到朋友圈”按钮点击状态及设置分享内容接口
    获取“分享给朋友”按钮点击状态及设置分享内容接口
    获取“分享到QQ”按钮点击状态及设置分享内容接口
    获取“分享到腾讯微博”按钮点击状态及设置分享内容接
    图像接口 本地选图或拍照接口
    图片预览接口
    上传图片接口
    下载图片接口
    音频接口 开始录音接口
    停止录音接口
    播放音频接口
    暂停播放接口
    停止播放接口
    上传语音接口
    下载语音接口
    智能接口 识别音频并返回识别结果接口
    设备信息 获取网络状态接口
    地理位置 查看地理位置地图接口
    获取地理位置接口
    界面操作 隐藏右上角菜单接口
    显示右上角菜单接口
    关闭当前窗口接口
    批量隐藏菜单项接口
    批量显示菜单项接口
    隐藏所有非基本菜单项接口
    显示所有被隐藏的非基本菜单项接口
    微信扫一扫 扫一扫接口

    注意: 所有的JS接口只能在企业号应用的可信域名下调用(包括子域名),可在企业号应用中心里设置应用可信域名。

    步骤一:引入JS文件

    在需要调用JS接口的页面引入如下JS文件,(支持https):http://res.wx.qq.com/open/js/jweixin-1.0.0.js

    备注:支持使用 AMD/CMD 标准模块加载方法加载

    步骤二:通过config接口注入权限验证配置

    所有需要使用JS-SDK的页面必须先注入配置信息,否则将无法调用(同一个url仅需调用一次,对于变化url的SPA的web app可在每次url变化时进行调用,目前Android微信客户端不支持pushState的H5新特性,所以使用pushState来实现web app的页面会导致签名失败,此问题会在Android6.2中修复)。

    wx.config({
        debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
        appId: '', // 必填,企业号的唯一标识,此处填写企业号corpid
        timestamp: , // 必填,生成签名的时间戳
        nonceStr: '', // 必填,生成签名的随机串
        signature: '',// 必填,签名,见附录1
        jsApiList: [] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
    });
    

    步骤三:通过ready接口处理成功验证

    wx.ready(function(){
    
        // config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中。
    });
    
    

     

    步骤四:通过error接口处理失败验证

    wx.error(function(res){
    
        // config信息验证失败会执行error函数,如签名过期导致验证失败,具体错误信息可以打开config的debug模式查看,也可以在返回的res参数中查看,对于SPA可以在这里更新签名。
    
    });
    

    接口调用说明

    所有接口通过wx对象(也可使用jWeixin对象)来调用,参数是一个对象,除了每个接口本身需要传的参数之外,还有以下通用参数:

    1. success:接口调用成功时执行的回调函数。
    2. fail:接口调用失败时执行的回调函数。
    3. complete:接口调用完成时执行的回调函数,无论成功或失败都会执行。
    4. cancel:用户点击取消时的回调函数,仅部分有用户取消操作的api才会用到。
    5. trigger: 监听Menu中的按钮点击时触发的方法,该方法仅支持Menu中的相关接口。


    注意:不要尝试在trigger中使用ajax异步请求修改本次分享的内容,因为客户端分享操作是一个同步操作,这时候使用ajax的回包会还没有返回


    以上几个函数都带有一个参数,类型为对象,其中除了每个接口本身返回的数据之外,还有一个通用属性errMsg,其值格式如下:

    1. 调用成功时:"xxx:ok" ,其中xxx为调用的接口名
    2. 用户取消时:"xxx:cancel",其中xxx为调用的接口名
    3. 调用失败时:其值为具体错误信息

    基础接口

    判断当前客户端版本是否支持指定JS接口

    wx.checkJsApi({
        jsApiList: ['chooseImage'] // 需要检测的JS接口列表,所有JS接口列表见附录2,
        success: function(res) {
            // 以键值对的形式返回,可用的api值true,不可用为false
            // 如:{"checkResult":{"chooseImage":true},"errMsg":"checkJsApi:ok"}
        });
    

    备注:checkJsApi接口是客户端6.0.2新引入的一个预留接口,第一期开放的接口均可不使用checkJsApi来检测。

    分享接口

    请注意不要有诱导分享等违规行为,对于诱导分享行为将永久回收企业号接口权限,详细规则请查看:朋友圈管理常见问题 。

    获取“分享到朋友圈”按钮点击状态及自定义分享内容接口

    wx.onMenuShareTimeline({
        title: '', // 分享标题
        link: '', // 分享链接
        imgUrl: '', // 分享图标
        success: function () {
            // 用户确认分享后执行的回调函数
        },
        cancel: function () {
            // 用户取消分享后执行的回调函数
        }
    });
    

    获取“分享给朋友”按钮点击状态及自定义分享内容接口

    wx.onMenuShareAppMessage({
        title: '', // 分享标题
        desc: '', // 分享描述
        link: '', // 分享链接
        imgUrl: '', // 分享图标
        type: '', // 分享类型,music、video或link,不填默认为link
        dataUrl: '', // 如果type是music或video,则要提供数据链接,默认为空
        success: function () {
            // 用户确认分享后执行的回调函数
        },
        cancel: function () {
            // 用户取消分享后执行的回调函数
        }
    });
    

    获取“分享到QQ”按钮点击状态及自定义分享内容接口

    wx.onMenuShareQQ({
        title: '', // 分享标题
        desc: '', // 分享描述
        link: '', // 分享链接
        imgUrl: '', // 分享图标
        success: function () {
           // 用户确认分享后执行的回调函数
        },
        cancel: function () {
           // 用户取消分享后执行的回调函数
        }
    });
    

    获取“分享到腾讯微博”按钮点击状态及自定义分享内容接口

    wx.onMenuShareWeibo({
        title: '', // 分享标题
        desc: '', // 分享描述
        link: '', // 分享链接
        imgUrl: '', // 分享图标
        success: function () {
           // 用户确认分享后执行的回调函数
        },
        cancel: function () {
            // 用户取消分享后执行的回调函数
        }
    });
    

    获取“分享到腾讯微博”按钮点击状态及自定义分享内容接口

    wx.onMenuShareWeibo({
        title: '', // 分享标题
        desc: '', // 分享描述
        link: '', // 分享链接
        imgUrl: '', // 分享图标
        success: function () {
           // 用户确认分享后执行的回调函数
        },
        cancel: function () {
            // 用户取消分享后执行的回调函数
        }
    });
    

    图像接口

    拍照或从手机相册中选图接口

    wx.chooseImage({
        count: 1, // 默认9
        sizeType: ['original', 'compressed'], // 可以指定是原图还是压缩图,默认二者都有
        sourceType: ['album', 'camera'], // 可以指定来源是相册还是相机,默认二者都有
        success: function (res) {
            var localIds = res.localIds; // 返回选定照片的本地ID列表,localId可以作为img标签的src属性显示图片
        }
    });
    

    预览图片接口

    wx.previewImage({
        current: '', // 当前显示图片的http链接
        urls: [] // 需要预览的图片http链接列表
    });
    

    上传图片接口

    wx.uploadImage({
        localId: '', // 需要上传的图片的本地ID,由chooseImage接口获得
        isShowProgressTips: 1// 默认为1,显示进度提示
        success: function (res) {
            var serverId = res.serverId; // 返回图片的服务器端ID
        }
    });
    

    备注:

    1. 上传图片有效期3天,可用微信多媒体接口下载图片到自己的服务器,此处获得的 serverId 即 media_id,参考文档
    2. 目前多媒体文件下载接口的频率限制为10000次/天,如需要调高频率,请邮件weixin-open@qq.com,邮件主题为【申请多媒体接口调用量】,请对你的项目进行简单描述,附上产品体验链接,并对用户量和使用量进行说明。

    下载图片接口

    wx.downloadImage({
        serverId: '', // 需要下载的图片的服务器端ID,由uploadImage接口获得
        isShowProgressTips: 1// 默认为1,显示进度提示
        success: function (res) {
            var localId = res.localId; // 返回图片下载后的本地ID
        }
    });
    

    音频接口

    开始录音接口

    wx.startRecord();
    

    停止录音接口

    wx.stopRecord({
        success: function (res) {
            var localId = res.localId;
        }
    });
    

    监听录音自动停止接口

    wx.onVoiceRecordEnd({
        // 录音时间超过一分钟没有停止的时候会执行 complete 回调
        complete: function (res) {
            var localId = res.localId;
        }
    });
    

    播放语音接口

    wx.playVoice({
        localId: '' // 需要播放的音频的本地ID,由stopRecord接口获得
    });
    

     

    暂停播放接口

    wx.pauseVoice({
        localId: '' // 需要暂停的音频的本地ID,由stopRecord接口获得
    });
    

    停止播放接口

    wx.stopVoice({
        localId: '' // 需要停止的音频的本地ID,由stopRecord接口获得
    });
    

    监听语音播放完毕接口

    wx.onVoicePlayEnd({
        serverId: '', // 需要下载的音频的服务器端ID,由uploadVoice接口获得
        success: function (res) {
            var localId = res.localId; // 返回音频的本地ID
        }
    });
    

     

    上传语音接口

    wx.uploadVoice({
        localId: '', // 需要上传的音频的本地ID,由stopRecord接口获得
        isShowProgressTips: 1// 默认为1,显示进度提示
            success: function (res) {
            var serverId = res.serverId; // 返回音频的服务器端ID
        }
    });
    

    备注:

    1. 上传语音有效期3天,可用微信多媒体接口下载语音到自己的服务器,此处获得的 serverId 即 media_id,参考文档
    2. 目前多媒体文件下载接口的频率限制为10000次/天,如需要调高频率,请邮件weixin-open@qq.com,邮件主题为【申请多媒体接口调用量】,请对你的项目进行简单描述,附上产品体验链接,并对用户量和使用量进行说明。

    下载语音接口

    wx.downloadVoice({
        serverId: '', // 需要下载的音频的服务器端ID,由uploadVoice接口获得
        isShowProgressTips: 1// 默认为1,显示进度提示
        success: function (res) {
            var localId = res.localId; // 返回音频的本地ID
        }
    });
    

     

    智能接口

    识别音频并返回识别结果接口

    wx.translateVoice({
       localId: '', // 需要识别的音频的本地Id,由录音相关接口获得
        isShowProgressTips: 1, // 默认为1,显示进度提示
        success: function (res) {
            alert(res.translateResult); // 语音识别的结果
        }
    });
    

    设备信息

    获取网络状态接口

    wx.getNetworkType({
        success: function (res) {
            var networkType = res.networkType; // 返回网络类型2g,3g,4g,wifi
        }
    });
    

     

    地理位置

    使用微信内置地图查看位置接口

    wx.openLocation({
        latitude: 0, // 纬度,浮点数,范围为90 ~ -90
        longitude: 0, // 经度,浮点数,范围为180 ~ -180。
        name: '', // 位置名
        address: '', // 地址详情说明
        scale: 1, // 地图缩放级别,整形值,范围从1~28。默认为最大
        infoUrl: '' // 在查看位置界面底部显示的超链接,可点击跳转
    });
    

    获取地理位置接口

    wx.getLocation({
        type: 'wgs84', // 默认为wgs84的gps坐标,如果要返回直接给openLocation用的火星坐标,可传入'gcj02'
        success: function (res) {
           var latitude = res.latitude; // 纬度,浮点数,范围为90 ~ -90
           var longitude = res.longitude ; // 经度,浮点数,范围为180 ~ -180。
            var speed = res.speed; // 速度,以米/每秒计
            var accuracy = res.accuracy; // 位置精度
        }
    });
    

    界面操作

    隐藏右上角菜单接口

    wx.hideOptionMenu();
    

    显示右上角菜单接口

    wx.showOptionMenu();
    

    关闭当前网页窗口接口

    wx.closeWindow();
    

    批量隐藏功能按钮接口

    wx.hideMenuItems({
        menuList: [] // 要隐藏的菜单项,所有menu项见附录3
    });
    

    批量显示功能按钮接口

    wx.showMenuItems({
        menuList: [] // 要显示的菜单项,所有menu项见附录3
    });
    

    隐藏所有非基础按钮接口

    wx.hideAllNonBaseMenuItem();
    

    显示所有功能按钮接口

    wx.showAllNonBaseMenuItem();
    

    微信扫一扫

    调起微信扫一扫接口

    wx.scanQRCode({
        desc: 'scanQRCode desc',
        needResult: 0, // 默认为0,扫描结果由微信处理,1则直接返回扫描结果,
        scanType: ["qrCode","barCode"], // 可以指定扫二维码还是一维码,默认二者都有
        success: function (res) {
        var result = res.resultStr; // 当needResult 为 1 时,扫码返回的结果
    }
    });
    

    企业号会话

    创建企业号会话

    1.接口描述

    名称:openEnterpriseChat

    功能:通过JS-SDK创建企业号会话

    2.请求参数

    参数 必填 说明
    userIds 参与会话的成员列表。格式为userid1;userid2;...,用分号隔开,最大限制为1000个。userid单个时为单聊,多个时为群聊。
    groupName 会话名称。单聊时该参数不需要传。

    3.代码示例

    wx.openEnterpriseChat({
    	userIds: ‘zhangshan;lisi;wangwu’, 
    	groupName: ‘openEnterpriseChat讨论组’,
    	success: function(res){
    		// 回调
    	},
    	error: function(res){
    		if(res.errMsg.indexOf('function_not_exist') > 0){
                        alert('版本过低请升级')
                   }
    	}
    });
    

    备注:引入新版js文件 http://res.wx.qq.com/open/js/jweixin-1.1.0.js 。微信客户端6.3.5支持该接口,可通过function_not_exist错误信息提示用户升级微信。

    4.返回码

    返回码 说明
    10001 appid无效
    10002 用户未关注企业号
    10003 消息服务未开启
    10004 用户不在消息服务可见范围
    10005 存在无效的消息会话成员
    10006 消息会话成员数不合法
    -1 系统出错

     

    附录1-JS-SDK使用权限签名算法

    jsapi_ticket

    生成签名之前必须先了解一下jsapi_ticket,jsapi_ticket是企业号号用于调用微信JS接口的临时票据。正常情况下,jsapi_ticket的有效期为7200秒,通过access_token来获取。由于获取jsapi_ticket的api调用次数非常有限,频繁刷新jsapi_ticket会导致api调用受限,影响自身业务,开发者必须在自己的服务全局缓存jsapi_ticket

    1. 参考以下文档获取access_token(有效期7200秒,开发者必须在自己的服务全局缓存access_token):http://qydev.weixin.qq.com/wiki/index.php?title=%E4%B8%BB%E5%8A%A8%E8%B0%83%E7%94%A8
    2. 用第一步拿到的access_token 采用http GET方式请求获得jsapi_ticket(有效期7200秒,开发者必须在自己的服务全局缓存jsapi_ticket):https://qyapi.weixin.qq.com/cgi-bin/get_jsapi_ticket?access_token=ACCESS_TOKE

    成功返回如下JSON:

    {
    "errcode":0,
    "errmsg":"ok",
    "ticket":"bxLdikRXVbTPdHSM05e5u5sUoXNKd8-41ZO3MhKoyN5OfkWITDGgnr2fwJ0m9E8NYzWKVZvdVtaUgWvsdshFKA",
    "expires_in":7200
    }
    

    获得jsapi_ticket之后,就可以生成JS-SDK权限验证的签名了。

     

    签名算法

    签名生成规则如下:参与签名的字段包括noncestr(随机字符串), 有效的jsapi_ticket, timestamp(时间戳), url(当前网页的URL,不包含#及其后面部分) 。对所有待签名参数按照字段名的ASCII 码从小到大排序(字典序)后,使用URL键值对的格式(即key1=value1&key2=value2…)拼接成字符串string1。这里需要注意的是所有参数名均为小写字符。对string1作sha1加密,字段名和字段值都采用原始值,不进行URL 转义。


    即signature=sha1(string1)。 示例:

    • noncestr=Wm3WZYTPz0wzccnW
    • jsapi_ticket=sM4AOVdWfPE4DxkXGEs8VMCPGGVi4C3VM0P37wVUCFvkVAy_90u5h9nbSlYy3-Sl-HhTdfl2fzFy1AOcHKP7qg
    • timestamp=1414587457
    • url=http://mp.weixin.qq.com


    步骤1. 对所有待签名参数按照字段名的ASCII 码从小到大排序(字典序)后,使用URL键值对的格式(即key1=value1&key2=value2…)拼接成字符串string1:

    jsapi_ticket=sM4AOVdWfPE4DxkXGEs8VMCPGGVi4C3VM0P37wVUCFvkVAy_90u5h9nbSlYy3-Sl-HhTdfl2fzFy1AOcHKP7qg&noncestr=Wm3WZYTPz0wzccnW&timestamp=1414587457&url=http://mp.weixin.qq.com
    

    附录2-所有JS接口列表

    版本1.0.0接口

    • onMenuShareTimeline
    • onMenuShareAppMessage
    • onMenuShareQQ
    • onMenuShareWeibo
    • onMenuShareQZone
    • startRecord
    • stopRecord
    • onVoiceRecordEnd
    • playVoice
    • pauseVoice
    • stopVoice
    • onVoicePlayEnd
    • uploadVoice
    • downloadVoice
    • chooseImage
    • previewImage
    • uploadImage
    • downloadImage
    • translateVoice
    • getNetworkType
    • openLocation
    • getLocation
    • hideOptionMenu
    • showOptionMenu
    • hideMenuItems
    • showMenuItems
    • hideAllNonBaseMenuItem
    • showAllNonBaseMenuItem
    • closeWindow
    • scanQRCode

    附录3-所有菜单项列表

    基本类

    • 举报: "menuItem:exposeArticle"
    • 调整字体: "menuItem:setFont"
    • 日间模式: "menuItem:dayMode"
    • 夜间模式: "menuItem:nightMode"
    • 刷新: "menuItem:refresh"
    • 查看企业号(已添加): "menuItem:profile"
    • 查看企业号(未添加): "menuItem:addContact"

    传播类

    • 发送给朋友: "menuItem:share:appMessage"
    • 分享到朋友圈: "menuItem:share:timeline"
    • 分享到QQ: "menuItem:share:qq"
    • 分享到QQ空间: "menuItem:share:QZone"
    • 分享到Weibo: "menuItem:share:weiboApp"
    • 收藏: "menuItem:favorite"
    • 分享到FB: "menuItem:share:facebook"
    • 分享到QQ空间:"menuItem:share:QZone"

    保护类

    • 调试: "menuItem:jsDebug"
    • 编辑标签: "menuItem:editTag"
    • 删除: "menuItem:delete"
    • 复制链接: "menuItem:copyUrl"
    • 原网页: "menuItem:originPage"
    • 阅读模式: "menuItem:readMode"
    • 在QQ浏览器中打开: "menuItem:openWithQQBrowser"
    • 在Safari中打开: "menuItem:openWithSafari"
    • 邮件: "menuItem:share:email"
    • 一些特殊企业号: "menuItem:share:brand"

    附录4-常见错误及解决方法

    调用config 接口1的时候传入参数 debug: true 可以开启debug模式,页面会alert出错误信息。以下为常见错误及解决方法:

    1. invalid url domain当前页面所在域名与使用的corpid没有绑定(可在该企业号的应用可信域名中配置域名)。
    2. invalid signature签名错误。建议按如下顺序检查:
      1. 确认签名算法正确,可用 http://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=jsapisign 页面工具进行校验。
      2. 确认config中nonceStr(js中驼峰标准大写S), timestamp与用以签名中的对应noncestr, timestamp一致。
      3. 确认url是页面完整的url(请在当前页面alert(location.href.split('#')[0])确认),包括'http(s)://'部分,以及'?'后面的GET参数部分,但不包括'#'hash后面的部分。
      4. 确认 config 中的 appid 与用来获取 jsapi_ticket 的 appid 一致。
      5. 确保一定缓存access_token和jsapi_ticket。
      6. 确保你获取用来签名的url是动态获取的,动态页面可参见实例代码中php的实现方式。如果是html的静态页面在前端通过ajax将url传到后台签名,前端需要用js获取当前页面除去'#'hash部分的链接(可用location.href.split('#')[0]获取,而且需要encodeURIComponent),因为页面一旦分享,微信客户端会在你的链接末尾加入其它参数,如果不是动态获取当前链接,将导致分享后的页面签名失败。
    3. the permission value is offline verifying这个错误是因为config没有正确执行,或者是调用的JSAPI没有传入config的jsApiList参数中。建议按如下顺序检查:
      1. 确认config正确通过。
      2. 如果是在页面加载好时就调用了JSAPI,则必须写在wx.ready的回调中。
      3. 确认config的jsApiList参数包含了这个JSAPI。
    4. permission denied该公众号没有权限使用这个JSAPI(部分接口需要认证之后才能使用)。
    5. function not exist当前客户端版本不支持该接口,请升级到新版体验。
    6. 为什么6.0.1版本config:ok,但是6.0.2版本之后不ok(因为6.0.2版本之前没有做权限验证,所以config都是ok,但这并不意味着你config中的签名是OK的,请在6.0.2检验是否生成正确的签名以保证config在高版本中也ok。)
    7. 在iOS和Android都无法分享(请确认公众号已经认证,只有认证的公众号才具有分享相关接口权限,如果确实已经认证,则要检查监听接口是否在wx.ready回调函数中触发)
    8. 服务上线之后无法获取jsapi_ticket,自己测试时没问题。(因为access_token和jsapi_ticket必须要在自己的服务器缓存,否则上线后会触发频率限制。请确保一定对token和ticket做缓存以减少2次服务器请求,不仅可以避免触发频率限制,还加快你们自己的服务速度。目前为了方便测试提供了1w的获取量,超过阀值后,服务将不再可用,请确保在服务上线前一定全局缓存access_token和jsapi_ticket,两者有效期均为7200秒,否则一旦上线触发频率限制,服务将不再可用)。
    9. uploadImage怎么传多图(目前只支持一次上传一张,多张图片需等前一张图片上传之后再调用该接口)
    10. 没法对本地选择的图片进行预览(chooseImage接口本身就支持预览,不需要额外支持)
    11. 通过a链接(例如先通过微信授权登录)跳转到b链接,invalid signature签名失败(后台生成签名的链接为使用jssdk的当前链接,也就是跳转后的b链接,请不要用微信登录的授权链接进行签名计算,后台签名的url一定是使用jssdk的当前页面的完整url除去'#'部分)
    12. 出现config:fail错误(这是由于传入的config参数不全导致,请确保传入正确的appId、timestamp、nonceStr、signature和需要使用的jsApiList)
    13. 如何把jsapi上传到微信的多媒体资源下载到自己的服务器(请参见文档中uploadVoice和uploadImage接口的备注说明)
    14. Android通过jssdk上传到微信服务器,第三方再从微信下载到自己的服务器,会出现杂音(微信团队已经修复此问题,目前后台已优化上线)
    15. 绑定父级域名,是否其子域名也是可用的(是的,合法的子域名在绑定父域名之后是完全支持的)
    16. 在iOS微信6.1版本中,分享的图片外链不显示,只能显示公众号页面内链的图片或者微信服务器的图片,已在6.2中修复
    17. 是否需要对低版本自己做兼容(jssdk都是兼容低版本的,不需要第三方自己额外做更多工作,但有的接口是6.0.2新引入的,只有新版才可调用)
    18. 该公众号支付签名无效,无法发起该笔交易(请确保你使用的jweixin.js是官方线上版本,不仅可以减少用户流量,还有可能对某些bug进行修复,拷贝到第三方服务器中使用,官方将不对其出现的任何问题提供保障,具体支付签名算法可参考 JSSDK微信支付一栏
    19. 目前Android微信客户端不支持pushState的H5新特性,所以使用pushState来实现web app的页面会导致签名失败,此问题已在Android6.2中修复
    20. uploadImage在chooseImage的回调中有时候Android会不执行,Android6.2会解决此问题,若需支持低版本可以把调用uploadImage放在setTimeout中延迟100ms解决
    21. require subscribe错误说明你没有订阅该测试号,该错误仅测试号会出现
    22. getLocation返回的坐标在openLocation有偏差,因为getLocation返回的是gps坐标,openLocation打开的腾讯地图为火星坐标,需要第三方自己做转换,6.2版本开始已经支持直接获取火星坐标
    23. 查看公众号(未添加): “menuItem:addContact”不显示,目前仅有从公众号传播出去的链接才能显示,来源必须是公众号

    附录5-DEMO页面和示例代码

    DEMO页面

    http://demo.open.weixin.qq.com/jssdk

    Jssdk demo001.png


    示例代码

    http://demo.open.weixin.qq.com/jssdk/sample.zip

    备注:链接中包含php、java、nodejs以及python的示例代码供第三方参考,第三方切记要对获取的accesstoken以及jsapi_ticket进行缓存以确保不会触发频率限制。

    附录6-问题反馈

    邮箱地址:weixin-open@qq.com

    邮件主题:【微信JS-SDK反馈】

    邮件内容说明:

    用简明的语言描述问题所在,并交代清楚遇到该问题的场景,可附上截屏图片,微信团队会尽快处理你的反馈。

    展开全文
  • 未绑定企业号开发者

    千次阅读 2020-04-20 19:57:55
    未绑定企业号开发者”问题 一直以来都是通过微信开发者工具调试企业微信页面的,最近因为某些原因也捣鼓起来了企业微信的页面,当时却发现直接在微信开发者工具打开企业页面的时候是无法打开的,提示“未绑定...
  • 使用微信web开发者工具调试微信企业号页面(前端页面,已发布在服务器上的)前几天写了一篇使用fiddler调试微信端页面的,然后博友评论说使用fiddler太麻烦了,推荐使用微信web开发者工具调试微信页面,这两天弄着玩...
  • 当前帐号在公众平台绑定,无法调试此授权登录链接。 解决方法:http://www.yayihouse.com/yayishuwu/chapter/1208
  • 微信开发者工具中![图片说明](https://img-ask.csdn.net/upload/201604/28/1461852196_60.png)说我没有绑定公众号,可是![图片说明](https://img-ask.csdn.net/upload/201604/28/1461852242_365029.png)后台我已经...
  • 微信浏览器调试

    万次阅读 2017-06-09 18:01:12
    微信浏览器调试
  • 微信公众号开发系列-开发环境要求和准备工作

    万次阅读 多人点赞 2014-11-02 10:19:05
    服务号:认证后支持自定义菜单、每个月群发4条信息,自动开通高级接口,可对第三方网页进行授权,24小时内互动无法主动推送发送消息,所有微信号都可以关注;企业号:认证后支持每个版块自定义菜单和指定版块...
  • 微信开发(web开发者工具)

    千次阅读 2016-10-04 15:20:41
    web开发者工具,就是为帮助开发者更方便、更安全地开发和调试基于微信的网页,我们推出了 web 开发者工具。它是一个桌面应用,通过模拟微信客户端的表现,使得开发者可以使用这个工具方便地在 PC 或者 Mac 上进行...
  • 苹果企业账号使用注意事项

    万次阅读 2016-04-13 13:57:52
    苹果企业账号(Apple Developer Enterprise Program)是苹果公司提供给 iOS 开发者的一种高级别的开发者账号,区别于个人开发者账号和公司开发者账号,企业账号具有如下特点: ... 其中,正是由于第3条的特点,给开
  • 微信开发之web开发者工具

    千次阅读 2016-10-02 17:13:11
    web开发者工具。 有任何疑问或建议请私信我,或者在评论区大家一起探讨。 概述 为帮助开发者更方便、更安全地开发和调试基于微信的网页,我们推出了 web 开发者工具。它是一个桌面应用,通过模拟微信客户端...
  • 微信企业号 技术解析

    千次阅读 2014-10-11 12:25:51
    摘要: 2014年9月18日,微信正式推出企业号公测,以“连接企业的另一种可能”为口号,使微信连接一切的链条更加完整。下面以我个人的角度,对我所理解的企业号,进行简单介绍: 什么是企业号 1.开放平台 企业号提供包...
  • PHP实现微信公众平台开发-基础篇

    万次阅读 2017-12-20 21:28:09
    第1章 微信公众账号及申请流程微信三角色关系微信公众账号: 充当的是自媒体角色 微信应用: 平台角色 微信用户: 普通用户 对微信应用而言: 微信应用给微信公众账号和微信用户提供了信息交互,获取资讯的一... ... ...
  • 通达OA对接企业微信与钉钉 设置

    万次阅读 2017-12-13 15:33:37
    3.4.2 企业号与钉钉设置 3.4.2.1 微信企业号设置 基础设置 第 1 步:以下为微信企业号申请地址,填写相关的信息即可申请,认证的账号,只有 50 人账号关注上限。 ...
  • 微信开发之入门教程

    万次阅读 多人点赞 2016-01-12 10:55:26
    时间葱葱,小宝鸽入职也有半年了,刚入的时候刚好有负责开发一个微信企业号的新项目。从项目的一无所有到第一版上线,再一步步完善升级。期间学到了许多东西。对微信开发也是有了一定的认识。在此,小宝鸽再次无私地...
  • 如何开发小程序?

    千次阅读 2018-08-27 15:45:10
    大家好,我是IT修真院郑州分院的学员,一枚正直纯洁善良的WEB程序员今天给大家分享一下,题目如何开发小程序? 一、背景介绍 微信小程序,简称小程序,英文名mini program,是一种不需要下载安装即可使用的应用,...
  • 微信小程序产品定位及功能介绍

    千次阅读 2016-12-28 19:15:29
    微信小程序产品定位及功能介绍,微信小程序是一种全新的连接用户与服务的方式,它可以在微信内被便捷地获取和传播,同时具有出色的使用体验。
  • 主要面对移动应用/网站应用开发者,为其提供微信登录、分享、支付等相关权限和服务。 微信开放平台还提供了数据统计功能,用于开发者统计接入应用的登录、分享等数据情况。 接入步骤 已京东APP举例,比如京东APP...
1 2 3 4 5 ... 20
收藏数 612
精华内容 244
关键字:

未绑定企业号开发者