微信开发 获取用户微信号_微信开发 能获取用户微信号吗 - CSDN
  • 微信公众号授权登录、获取用户信息(openid) 实现方式也是两种: 1.静默授权登录 授权登录以snsapi_base为scope发起的网页授权,是用来获取进入页面的用户的openid的,并且是静默授权并自动跳转到回调页的。用户感知...

    微信公众号网页授权思路解析及具体代码

    微信开发文档
    实现方式也是两种:

    1.静默授权登录
    授权登录以snsapi_base为scope发起的网页授权,是用来获取进入页面的用户的openid的,并且是静默授权并自动跳转到回调页的。用户感知的就是直接进入了回调页(往往是业务页面)特点:用户无感知;

    2.非静默授权登录
    非静默授权以snsapi_userinfo为scope发起的网页授权,是用来获取用户的基本信息的。但这种授权需要用户手动同意,并且由于用户同意过,所以无须关注,就可在授权后获取该用户的基本信息。
    (区别:除了scope不一样,以及调用微信接口不一样,功能上,静默授权不需要用户确认,只需要用户访问某个网页,属于嵌套在普通网页里的授权形式,但是只能获取到用户的唯一标示openid和union id,无法拿到用户的微信头像、微信名称等个人信息,对于用户的简单认证还是很有用的。)

    非静默授权

    微信公众号技术开发文档: [https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1445241432]
    首先编写一个工具类

    package com.wlw.util;
    import java.io.IOException;
    import org.apache.http.HttpEntity;
    import org.apache.http.HttpResponse;
    import org.apache.http.client.ClientProtocolException;
    import org.apache.http.client.methods.HttpGet;
    import org.apache.http.impl.client.DefaultHttpClient;
    import org.apache.http.util.EntityUtils;
     
    import net.sf.json.JSONObject;
     
    /**
     * 
     * 工具类
     * 用来根据接口地址进行网络请求
     * @author wlw
     *
     */
    public class AuthUtil {
    	public static final String APP_ID = "****************";     //填写自己的APPID
    	public static final String APP_SECRET = "**************";   //填写自己的APPSECRET
        public static JSONObject doGetJson(String url) throws Exception, IOException {
    		JSONObject jsonObject=null;
    		//初始化httpClient
    		DefaultHttpClient client=new DefaultHttpClient();
    		//用Get方式进行提交
    		HttpGet httpGet=new HttpGet(url);
    		//发送请求
    		HttpResponse response= client.execute(httpGet);
        	//获取数据
    		HttpEntity entity=response.getEntity();
    		//格式转换
    		if (entity!=null) {
    			String result=EntityUtils.toString(entity,"UTF-8");
    			jsonObject=JSONObject.fromObject(result);
    		}
    		//释放链接
    		httpGet.releaseConnection();
    		return jsonObject;
        }
    	   
    }
    

    1.引导用户进入授权页面同意授权,获取code
    主要是发送请求:https://open.weixin.qq.com/connect/oauth2/authorize?appid="+wx_appid+"&redirect_uri="+api.wx_reg+"&response_type=code&scope=snsapi_login,snsapi_userinfo&state=1,0#wechat_redirect
    其中各个参数的意义:

    2.如果用户同意授权,页面将跳转至 redirect_uri并且携带"?code=CODE&state=STATE"
    通过code换取网页授权access_token(后台操作)以及通过access_token换取用户信息

    package com.wlw.servlet;
    import java.io.IOException;
    import javax.servlet.ServletException;
    import javax.servlet.annotation.WebServlet;
    import javax.servlet.http.HttpServlet;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    import com.wlw.util.AuthUtil;
    import net.sf.json.JSONObject;
     
    /**
     * 回调地址
     * 
     * @author wlw
     *
     */
    @WebServlet("/redirect_uri")
    public class CallBackServlet extends HttpServlet {
    	
    	@Override
    	protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
    		/**
    		 * 获取code
    		 */
    		String code=req.getParameter("code");
    	String url="https://api.weixin.qq.com/sns/oauth2/access_token?appid="+AuthUtil.APP_ID
    			+ "&secret="+AuthUtil.APP_SECRET
    			+ "&code="+code
    			+ "&grant_type=authorization_code";
    	JSONObject jsonObject;
    	try {
    		jsonObject = AuthUtil.doGetJson(url);
    		String openid=jsonObject.getString("openid");
    		String token=jsonObject.getString("access_token");
    		/**
    		 * 拉取用户信息
    		 */
    		String infoUrl="https://api.weixin.qq.com/sns/userinfo?access_token="+token
    				+ "&openid="+openid
    				+ "&lang=zh_CN";
    		JSONObject userInfo=AuthUtil.doGetJson(infoUrl);//这里的userInfo已经是用户的信息了
    		System.out.println(userInfo);
    		//使用微信用户信息直接登录,无需注册和绑定
    		req.setAttribute("info", userInfo);
    		req.getRequestDispatcher("/index1.jsp").forward(req, resp);
    	} catch (Exception e) {
    		// TODO Auto-generated catch block
    		e.printStackTrace();
    	}
    	}
    	@Override
    	protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
    		// TODO Auto-generated method stub
    		super.doPost(req, resp);
    	}
    }
    

    这里解释一下回调函数:回调地址是当我们用户同意授权后,程序会进行对回调地址的访问。所以回调地址必须在公网上能够进行访问的。(用我自己的理解就相当于是你给腾讯平台发送请求,获取用户的信息,当你参数携带正确的情况下,腾讯就会向你发送一个请求,而这个请求的路径就是上面的redirect_uri所指的路径,所以回调函数的调用只有可能在公网上进行调用)

    以上就是微信非静默授权登录的代码部分,至于微信公众平台里的配置,看我下一个文章吧~

    一下是另外两种登录的api,跟上面类似步骤,知识参数不一样而已,详细看开发文档,对应参数,详细你一定可以解决的…………
    网站的微信授权登录是以二维码的形式 api网址 api https://open.weixin.qq.com/cgi-bin/showdocument?action=dir_list&t=resource/res_list&verify=1&id=open1419316505&token=&lang=zh_CN

    手机端微信授权登录api网址 https://open.weixin.qq.com/cgi-bin/showdocument?action=dir_list&t=resource/res_list&verify=1&id=open1419317851&token=&lang=zh_CN

    特殊情况:html页面,controller不方便控制页面跳转的情况,公众平台上菜单的地址就不能写接口的地址,但是如果对微信接口的回调参数理解透彻的话,就很好吧,公众平台的菜单地址同样可以直接写它自身的授权接口,同时,回调地址写进入的页面,这样,相当于是通过菜单直接调微信授权接口,然后微信再跳转到你的网页页面上,同时可以携带上需要的code,页面上从路径中截取到code发送给后台,后台再进行access_token和openid的值的请求,就能正常的走通……

    参考文献

    在确保微信公众账号拥有授权作用域(scope参数)的权限的前提下(服务号获得高级接口后,默认拥有scope参数中的snsapi_base和snsapi_userinfo),引导关注者打开如下页面:
    
    https://open.weixin.qq.com/connect/oauth2/authorize?appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope=SCOPE&state=STATE#wechat_redirect 若提示“该链接无法访问”,请检查参数是否填写错误,是否拥有scope参数对应的授权作用域权限。
    
    尤其注意:由于授权操作安全等级较高,所以在发起授权请求时,微信会对授权链接做正则强匹配校验,如果链接的参数顺序不对,授权页面将无法正常访问
    
    参考链接(请在微信客户端中打开此链接体验):
    
    scope为snsapi_base
    
    https://open.weixin.qq.com/connect/oauth2/authorize?appid=wx520c15f417810387&redirect_uri=https%3A%2F%2Fchong.qq.com%2Fphp%2Findex.php%3Fd%3D%26c%3DwxAdapter%26m%3DmobileDeal%26showwxpaytitle%3D1%26vb2ctag%3D4_2030_5_1194_60&response_type=code&scope=snsapi_base&state=123#wechat_redirect
    
    scope为snsapi_userinfo
    
    https://open.weixin.qq.com/connect/oauth2/authorize?appid=wxf0e81c3bee622d60&redirect_uri=http%3A%2F%2Fnba.bluewebgame.com%2Foauth_response.php&response_type=code&scope=snsapi_userinfo&state=STATE#wechat_redirect
    
    尤其注意:跳转回调redirect_uri,应当使用https链接来确保授权code的安全性。
    
    //授权登录回调跳转,第一步先获取code参数,从而请求access_token
    var getRequest = GetRequest();
    var code = null;
    if (getRequest.code) {
        code = getRequest.code;
        var data = {};
        var url = getWeiContextPath() + "接口路径";
        data.code = code;//课程
        //同步ajax,供方法中调接口
        $.ajax({
            type: "POST",
            cache: false,
            data: data,
            async: false,
            url: url,
            success: function (result) {
                    //信息完整,直接进入测试页面
                    window.location.href = "index.html"
            },
            error: function (result) {
                alert(result.msg)
            }
        });
    } else {
        //没有code,再次请求获取code
        var pageUrl = window.location.href
            .replace(/[/]/g, "%2f")
            .replace(/[:]/g, "%3a")
            .replace(/[#]/g, "%23")
            .replace(/[&]/g, "%26")
            .replace(/[=]/g, "%3d");
        var url =
            "https://open.weixin.qq.com/connect/oauth2/authorize?appid=" +
            "wx7813bb6299b9b52a" +
            "&redirect_uri=" +
            pageUrl +
            "&response_type=code&scope=snsapi_base&state=STATE&connect_redirect=1#wechat_redirect";
        window.location.href = url;
    }
    
    
    //获取页面请求路径中的参数
    function GetRequest() {
        var url = location.search; //获取url中"?"符后的字串
        var theRequest = new Object();
        if (url.indexOf("?") != -1) {
            var str = url.substr(1);
            strs = str.split("&");
            for (var i = 0; i < strs.length; i++) {
                theRequest[strs[i].split("=")[0]] = unescape(strs[i].split("=")[1]);
            }
        }
        return theRequest;
    }
    
    展开全文
  • 步骤一:申请微信开发者测试账号 ...amp;amp;...步骤二:需要一个服务器,用来获取你要的信息,我使用的是阿里云 https://www.aliyun.com/?utm_content=se_1000301881 有了阿里云后推荐使用最近挺火的...

    步骤一:申请微信开发者测试账号
    https://mp.weixin.qq.com/debug/cgi-bin/sandboxinfo?action=showinfo&t=sandbox/index
    在这里插入图片描述
    步骤二:需要一个服务器,用来获取你要的信息,我使用的是阿里云
    https://www.aliyun.com/?utm_content=se_1000301881
    有了阿里云后推荐使用最近挺火的Xshell和Xftp来操作服务器
    个人使用的话是免费的
    https://www.netsarang.com/zh/free-for-home-school/

    步骤三:下载个微信web开发者工具,不仅可以用来测试微信,其他的也可以测试
    https://developers.weixin.qq.com/miniprogram/dev/devtools/download.html

    步骤四:可以页面设置个超链接进行测试,跳转到用户授权页面
    授权链接:
    https://open.weixin.qq.com/connect/qrconnect?appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope=SCOPE&state=STATE#wechat_redirect
    在这里插入图片描述
    也可内嵌二维码授,直接设置一个div id设为login_container
    步骤1:在页面中先引入如下JS文件(支持https):
    http://res.wx.qq.com/connect/zh_CN/htmledition/js/wxLogin.js
    步骤2:在需要使用微信登录的地方实例以下JS对象:
    var obj = new WxLogin({
    self_redirect:true,
    id:“login_container”,
    appid: “”,
    scope: “”,
    redirect_uri: “”,
    state: “”,
    style: “”,
    href: “”
    });
    在这里插入图片描述
    步骤五:当用户确认授权后,将返回一个code,可以通过code获取access_token
    注意:code是一次性的,这里的access_token网页临时授权的,也是一次性的
    不同的是还有一个access_token是全局接口使用凭证,有效期两个小时
    获取方法,需要appID和appsercret
    https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET
    这个access_token,是微信公众号的全局唯一票据,各个微信接口调用都需要用到它。这个接口每天使用限制是2000次,所以自动获取这个access_token是有限制,不能所以接口调用都去重新获取。它的有效期是2个小时,已经自动实现了平滑过渡,可以放心的每隔2小时调用一次。

    以下通过code获取access_token,这个access_token将在下一步用来获取用户信息
    https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code
    在这里插入图片描述
    返回说明

    正确的返回:
    {
    “access_token”:“ACCESS_TOKEN”,
    “expires_in”:7200,
    “refresh_token”:“REFRESH_TOKEN”,
    “openid”:“OPENID”,
    “scope”:“SCOPE”,
    “unionid”: “o6_bmasdasdsad6_2sgVt7hMZOPfL”
    }
    在这里插入图片描述
    可以用file_get_contents(url)获取网页返回的信息

    我是通过curl拓展库来获取url的信息,相对file_get_contents()更快更稳定
    resarr=curlgetcontents(res_arr = curl_get_contents(url);
    print_r($res_arr); //打印看看结果

    function curl_get_contents($url) {
    $ch = curl_init();//初始化

    curl_setopt($ch, CURLOPT_URL, $url);//登录提交的地址
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);// 抓取结果直接返回(如果为0,则直接输出内容到页面)
    curl_setopt($ch, CURLOPT_HEADER, 0);//是否显示头部信息  
    curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 30);//响应超时时间s
    
    $res_data = curl_exec($ch);//执行并获取HTML文档内容
    if ($res_data === false) {//检查错误
    	$res_data = 'cURL error:' . curl_error($ch);
    }
    curl_close($ch);//关闭curl
    return $res_arr;//返回结果
    

    }

    步骤六:通过步骤五获得的access_token和openid获取用户信息
    我的代码,供参考

    $_SESSION[‘access_token’] = $res_arr[‘access_token’];
    $_SESSION[‘openid’] = $res_arr[‘openid’];
    $url = “https://api.weixin.qq.com/sns/userinfo?access_token=” . $_SESSION[‘access_token’] . “&openid=” . $_SESSION[‘openid’] . “&lang=zh_CN”;
    resarr=curlgetcontents(res_arr = curl_get_contents(url);
    print_r($res_arr);
    结果:
    在这里插入图片描述
    我使用的是/sns/userinfo获取用户个人信息,以下是接口说明
    在这里插入图片描述
    参考:
    微信开发文档https://open.weixin.qq.com/cgi-bin/showdocument?action=dir_list&t=resource/res_list&verify=1&id=open1419316505&token=58dd5924aafd39c69972c47538101daba7237050&lang=zh_CN
    Oauth2.0协议http://www.ruanyifeng.com/blog/2014/05/oauth_2_0.html

    展开全文
  • 如果用户微信客户端中访问第三方网页,公众号可以通过微信网页授权机制,来获取用户基本信息,进而实现业务逻辑。 现在,我们要实现一个微信内网页,通过微信访问网页时,网页会展示微信用户的个人信息。因为涉及...

    说明:该篇博客是博主一字一码编写的,实属不易,请尊重原创,谢谢大家!

    一丶概述

    • 微信网页授权

    如果用户在微信客户端中访问第三方网页,公众号可以通过微信网页授权机制,来获取用户基本信息,进而实现业务逻辑。

    现在,我们要实现一个微信内网页,通过微信访问网页时,网页会展示微信用户的个人信息。因为涉及到用户的个人信息,所以需要有用户授权才可以。当用户授权后,我们的网页服务器(开发者服务器)会拿到用户的“授权书”(code),我们用这个code向微信服务器领取访问令牌(accecc_token)和用户的身份号码(openid),然后凭借access_token和openid向微信服务器提取用户的个人信息。

    1. 第一步:用户同意授权,获取code
    2. 第二步:通过code换取网页授权access_token
    3. 第三步:拉取用户信息(需scope为 snsapi_userinfo)

    那么,如何拿到用户的授权code呢?

    授权是由微信发起让用户进行确认,在这个过程中是微信在与用户进行交互,所以用户应该先访问微信的内容,用户确认后再由微信将用户导向到我们的网页链接地址,并携带上code参数。我们把这个过程叫做网页回调,类似于我们在程序编写时用到的回调函数,都是回调的思想。

    • 关于网页授权回调域名的说明 

    1、在微信公众号请求用户网页授权之前,开发者需要先到公众平台官网中的“开发 - 接口权限 - 网页服务 - 网页帐号 - 网页授权获取用户基本信息”的配置选项中,修改授权回调域名。请注意,这里填写的是域名(是一个字符串),而不是URL,因此请勿加 http:// 等协议头;关于网页授权回调域名的说明

    2、授权回调域名配置规范为全域名,比如需要网页授权的域名为:www.qq.com,配置以后此域名下面的页面http://www.qq.com/music.html 、 http://www.qq.com/login.html 都可以进行OAuth2.0鉴权。但http://pay.qq.com 、 http://music.qq.com 、 http://qq.com无法进行OAuth2.0鉴权

    3、如果公众号登录授权给了第三方开发者来进行管理,则不必做任何设置,由第三方代替公众号实现网页授权即可。

    第一步:用户同意授权,获取code

    在确保微信公众账号拥有授权作用域(scope参数)的权限的前提下(服务号获得高级接口后,默认拥有scope参数中的snsapi_base和snsapi_userinfo),引导关注者打开如下页面:

    https://open.weixin.qq.com/connect/oauth2/authorize?appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope=SCOPE&state=STATE#wechat_redirect

    尤其注意:由于授权操作安全等级较高,所以在发起授权请求时,微信会对授权链接做正则强匹配校验,如果链接的参数顺序不对,授权页面将无法正常访问

    参考链接(请在微信客户端中打开此链接体验):
    scope为snsapi_base
    https://open.weixin.qq.com/connect/oauth2/authorize?appid=wx520c15f417810387&redirect_uri=https%3A%2F%2Fchong.qq.com%2Fphp%2Findex.php%3Fd%3D%26c%3DwxAdapter%26m%3DmobileDeal%26showwxpaytitle%3D1%26vb2ctag%3D4_2030_5_1194_60&response_type=code&scope=snsapi_base&state=123#wechat_redirect
    scope为snsapi_userinfo
    https://open.weixin.qq.com/connect/oauth2/authorize?appid=wxf0e81c3bee622d60&redirect_uri=http%3A%2F%2Fnba.bluewebgame.com%2Foauth_response.php&response_type=code&scope=snsapi_userinfo&state=STATE#wechat_redirec

    尤其注意:跳转回调redirect_uri,应当使用https链接来确保授权code的安全性。

    参数说明

    参数 是否必须 说明
    appid 公众号的唯一标识
    redirect_uri 授权后重定向的回调链接地址, 请使用 urlEncode 对链接进行处理
    response_type 返回类型,请填写code
    scope 应用授权作用域,snsapi_base (不弹出授权页面,直接跳转,只能获取用户openid),snsapi_userinfo (弹出授权页面,可通过openid拿到昵称、性别、所在地。并且, 即使在未关注的情况下,只要用户授权,也能获取其信息 )
    state 重定向后会带上state参数,开发者可以填写a-zA-Z0-9的参数值,最多128字节
    #wechat_redirect 无论直接打开还是做页面302重定向时候,必须带此参数

     下图为scope等于snsapi_userinfo时的授权页面:

    用户同意授权后

    如果用户同意授权,页面将跳转至 redirect_uri/?code=CODE&state=STATE。

    code说明 : code作为换取access_token的票据,每次用户授权带上的code将不一样,code只能使用一次,5分钟未被使用自动过期。 

    第二步:通过code换取网页授权access_token

    首先请注意,这里通过code换取的是一个特殊的网页授权access_token,与基础支持中的access_token(该access_token用于调用其他接口)不同。公众号可通过下述接口来获取网页授权access_token。如果网页授权的作用域为snsapi_base,则本步骤中获取到网页授权access_token的同时,也获取到了openid,snsapi_base式的网页授权流程即到此为止。

    尤其注意:由于公众号的secret和获取到的access_token安全级别都非常高,必须只保存在服务器,不允许传给客户端。后续刷新access_token、通过access_token获取用户信息等步骤,也必须从服务器发起。

    请求方法

    获取code后,请求以下链接获取access_token:  https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code

    参数说明

    参数 是否必须 说明
    appid 公众号的唯一标识
    secret 公众号的appsecret
    code 填写第一步获取的code参数
    grant_type 填写为authorization_code

    返回说明

    正确时返回的JSON数据包如下:

    { "access_token":"ACCESS_TOKEN",
    "expires_in":7200,
    "refresh_token":"REFRESH_TOKEN",
    "openid":"OPENID",
    "scope":"SCOPE" }
    参数 描述
    access_token 网页授权接口调用凭证,注意:此access_token与基础支持的access_token不同
    expires_in access_token接口调用凭证超时时间,单位(秒)
    refresh_token 用户刷新access_token
    openid 用户唯一标识,请注意,在未关注公众号时,用户访问公众号的网页,也会产生一个用户和公众号唯一的OpenID
    scope 用户授权的作用域,使用逗号(,)分隔

     

    错误时微信会返回JSON数据包如下(示例为Code无效错误):

    {"errcode":40029,"errmsg":"invalid code"}

     第三步:拉取用户信息(需scope为 snsapi_userinfo)

    如果网页授权作用域为snsapi_userinfo,则此时开发者可以通过access_token和openid拉取用户信息了。

    请求方法

    http:GET(请使用https协议) https://api.weixin.qq.com/sns/userinfo?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN

    参数说明

    参数 描述
    access_token 网页授权接口调用凭证,注意:此access_token与基础支持的access_token不同
    openid 用户的唯一标识
    lang 返回国家地区语言版本,zh_CN 简体,zh_TW 繁体,en 英语

    返回说明

    正确时返回的JSON数据包如下:

    {    "openid":" OPENID",
    " nickname": NICKNAME,
    "sex":"1",
    "province":"PROVINCE"
    "city":"CITY",
    "country":"COUNTRY",
    "headimgurl":    "http://thirdwx.qlogo.cn/mmopen/g3MonUZtNHkdmzicIlibx6iaFqAc56vxLSUfpb6n5WKSYVY0ChQKkiaJSgQ1dZuTOgvLLrhJbERQQ4eMsv84eavHiaiceqxibJxCfHe/46",
    "privilege":[ "PRIVILEGE1" "PRIVILEGE2"     ],
    "unionid": "o6_bmasdasdsad6_2sgVt7hMZOPfL"
    }
    参数 描述
    openid 用户的唯一标识
    nickname 用户昵称
    sex 用户的性别,值为1时是男性,值为2时是女性,值为0时是未知
    province 用户个人资料填写的省份
    city 普通用户个人资料填写的城市
    country 国家,如中国为CN
    headimgurl 用户头像,最后一个数值代表正方形头像大小(有0、46、64、96、132数值可选,0代表640*640正方形头像),用户没有头像时该项为空。若用户更换头像,原有头像URL将失效。
    privilege 用户特权信息,json 数组,如微信沃卡用户为(chinaunicom)
    unionid 只有在用户将公众号绑定到微信开放平台帐号后,才会出现该字段。

    错误时微信会返回JSON数据包如下(示例为openid无效):

    {"errcode":40003,"errmsg":" invalid openid "}

     二丶代码实现

    • 思路分析
    • 首选在我们的flask程序中需要定义一个视图函数路由规则为/wechat8007/index,定义微信服务器重定向网址redirect_uri为服务器域名+/wechat8007/index(例如http://www.xxxx.com/wechat8007/index),通过访问微信提供的引导页面,让用户同意授权,然后重定向到我们定义的网址,此时微信服务器就会给我们的服务一个code,我们的服务器再通过code向微信服务器换取网页授权access_token(存取令牌),如果网页授权作用域为snsapi_userinfo,则此时可以通过access_token和openid拉取用户信息了。
    • step1 同意授权,这一块不需要代码实现,只需要提供授权链接即可
    • step2 定义视图函数,当用户同意授权,页面将跳转至 redirect_uri/?code=CODE&state=STATE ,在flask程序中定义一个是视图函数接口index,让用户同意授权后,去访问的视图
    • 上一篇博客定义的wechat视图,是由微信服务器访问,现在定义的index视图为用户访问的
    @app.route("/wechat8007/index")
    def index():
        """让用户通过微信访问的网页页面视图"""
    • step3  刚开始还没拉去用户资料时,可直接返回一个模板
    return render_template("index.html")
    • step4 从微信服务器中获取用户的资料数据,将用户的资料数据填充到index.html模板中
    • 1.获取code参数
    code = request.args.get("code")
    • 2.当code不存在时,返回字符串
    if not code:
        return u"缺失code参数"
    url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=%s&secret=%s&code=%s&grant_type=authorization_code" %(WECHAT_APPID,WECHAT_APPSECRET,code)
    
    response = urllib2.urlopen(url)
    
    # 获取响应体数据,微信返回的json数据
    json_str = response.read()
    resp_dict = json.loads(json_str)
    • 4.提取access_token,首先对获取到的响应体数据进行判断,如果不存在,直接返回提示字符串,存在则通过get方式拿去字典中的access_token键的值以及用户编号openid的值
    if "errcode" in resp_dict:
        return u"获取access_token失败"
    
    access_token = resp_dict.get("access_token")
    open_id = resp_dict.get("openid")  # 用户的编号
    • step5 向微信服务器发送http请求,获取用户的资料数据 
    url = "https://api.weixin.qq.com/sns/userinfo?access_token=%s&openid=%s&lang=zh_CN" %(access_token,open_id)
    
    response = urllib2.urlopen(url)
    
    # 读取微信传回的json的响应体数据
    user_json_str = response.read()
    user_dict_data = json.loads(user_json_str)
    • step6 判断微信返回的响应体数据中是否有errorcode字段,如果存在则返回失败信息,不存在说明微信返回的json数据为正确数据,则将该数据传给index.html模板,当用户访问 http://xxx/wechat8007/index地址时,会渲染出我们定义的index.html模板
    if "errcode" in user_dict_data:
        return u"获取用户信息失败"
    else:
        # 将用户的资料数据填充到页面中
        return render_template("index.html", user=user_dict_data)
    •  step7 当前目录下创建templates模板目录,在该目录中创建index.html文件 ,代码如下
    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="utf-8">
        <title>{{user["nickname"]}}的个人主页</title>
    </head>
    <body>
        <img alt="头像" src="{{user['headimgurl']}}" width="60">
        <table>
            <tr>
                <th>openid</th>
                <td>{{user["openid"]}}</td>
            </tr>
            <tr>
                <th>昵称</th>
                <td>{{user["nickname"]}}</td>
            </tr>
            <tr>
                <th>性别</th>
                <td>
                    {% if 1 == user["sex"] %}
                        男
                    {% elif 2 == user["sex"] %}
                        女
                    {% else %}
                        未知
                    {% endif %}
                </td>
            </tr>
            <tr>
                <th>省份</th>
                <td>{{user["province"]}}</td>
            </tr>
            <tr>
                <th>城市</th>
                <td>{{user["city"]}}</td>
            </tr>
            <tr>
                <th>国家</th>
                <td>{{user["country"]}}</td>
            </tr>
        </table>
    </body>
    </html>

     三丶部署测试

    • step1 将代码推送到服务器上

    成功推送到服务器上

    •  step2 在服务器上进入虚拟环境,运行此程序

     

    In [1]: import urllib
    
    In [2]: urllib.quote("http://www.xxx.com/wechat8007/index")
    Out[2]: 'http%3A//www.xxx.com/wechat8007/index'
    
    
    

     

    • 拼接好的用户访问的url地址为

    • step4 可以将该网址生成二维码,使用微信扫一扫,也可以在接口公众号直接发送此链接地址
    •  使用谷歌浏览器的二维码插件,将网址生成对应的二维码(这里以百度首页网址为例)

    • 直接在浏览器中输入此地址会提示请在微信客户端打开链接

    •  step5 测试,在手机微信上打开此链接,出现授权登录提示,点击允许即可获取用户个人信息

    点击允许后,进入如下界面

    点击继续访问,则出现博主个人的微信信息了,如下图 

    此时查看服务器上程序运行日志 

    四丶完整代码

    # coding:utf-8
    from flask import Flask, request, render_template
    import json, urllib2
    
    
    WECHAT_APPID = "yourappid"
    WECHAT_APPSECRET = "yoursecret"
    
    app = Flask(__name__)
    
    
    
    @app.route("/wechat8007/index")
    def index():
    
        code = request.args.get("code")
    
        if not code:
            return u"缺失code参数"
    
        url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=%s&secret=%s&code=%s&grant_type=authorization_code" % (WECHAT_APPID, WECHAT_APPSECRET, code)
    
        response = urllib2.urlopen(url)
    
        json_str = response.read()
        resp_dict = json.loads(json_str)
    
        if "errcode" in resp_dict:
            return u"获取access_token失败"
    
        access_token = resp_dict.get("access_token")
        open_id = resp_dict.get("openid")
    
        url = "https://api.weixin.qq.com/sns/userinfo?access_token=%s&openid=%s&lang=zh_CN" % (access_token, open_id)
    
        response = urllib2.urlopen(url)
        user_json_str = response.read()
        user_dict_data = json.loads(user_json_str)
    
        if "errcode" in user_dict_data:
            return u"获取用户信息失败"
        else:
            return render_template("index.html", user=user_dict_data)
    
    
    if __name__ == '__main__':
        app.run(port=8007, debug=True)

    总结:微信公众号接口开发,根据官方提供的开发文档,进行开发,逻辑实现都很简单,多想多思考多练习,你会越来越棒的!

    展开全文
  • 之所以写这个是因为,在工作当中突然就收到消息要做一个抽奖的活动,需要获取用户信息,再次就记录一下获取微信用户信息的整个流程,以及代码分享一下。 这个项目是使用spring boot的前后分离项目,然后剩下的就不...

    1、由来以及项目环境

    之所以写这个是因为,在工作当中突然就收到消息要做一个抽奖的活动,需要获取用户信息,再次就记录一下获取微信用户信息的整个流程,以及代码分享一下。
    这个项目是使用spring boot的前后分离项目,然后剩下的就不具体细说了。按照惯例先把联系方式填写下qq704273004

    2、讲述一下获取微信用户信息的原理或者说途径

    在此讲一些原理和接口也是参考别人然后加上自己理解,使用的时候最好也自己理解一下。获取用户信息根据微信公众号的文档的流程来的,具体公众号的地址就不贴出来了 读者自行寻找就好了,大概获得用户信息的方法有三种,如有理解不对或是错误的地方之后再更改。

    获取用户信息主要分为2中方式,一种是静默授权一种是用户感知授权,这其中主要区别是调用接口和是否弹出授权页面,以及获取用户信息使用的接口不一样。
    个人理解静默授权需要关注公众号,用户感知授权可以不需要用户关注公号就取到用户信息。
    同时是用户感知授权对应的授权是方式网页授权,静默授权的授权方式是全局授权,最大的区别是两个access_token的区别。

    关于Access_token的异同:

    有效期:两者有效时间都是7200s。
    使用范围:通过网页授权获得的access_token,只能获取到对应的微信用户信息,与微信用户是一对一关系;
    					而普通的access_token在有效期内可以使用,可以获取所有用户信息。
    次数限制:普通access_token每天获取最多次数为2000次,而网页授权的access_token获取次数没有限制。
    
    

    (引用博客连接)详细区别请点击

    3、具体的使用方法及调用接口

    方法一:使用全局的Access Token获取用户基本信息**

    • 用户关注及恢复小时的时候,获取用户的OpenId
    • 使用全局获取access_token接口获取
      https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET
    • 在使用全局access_token获取OpenId的详细信息
      https://api.weixin.qq.com/cgi-bin/user/info?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN

    方法二:通过网页授权弹出授权页面获取用户基本信息**

    • 微信公众号配置回调域名

    • 构造url请求将回调指向自己服务器的接口或者页面,例如:

      https://open.weixin.qq.com/connect/oauth2/authorize?appid=APPID&redirect_uri=REDIRECT_URL&response_type=code&scope=snsapi_userinfo&state=1#wechat_redirect 
      

      参数解释:APPID微信公众号的APPID;REDIRECT_URL重定向页面这个URL一般指向自己的服务器;scope=snsapi_userinfo该参数表示授权的作用域是请求用户信息
      注意:scope的参数有两种一种是snsapi_base该参数只能获取OpenId并且不会弹出授权页面;snsapi_userinfo参数会弹出授权页面,并且可以用于取用户信息

    • REDIRECT_URL回调页面
      当请求成功的时候会重定向到回调页面(接口),此时的URL将会增加俩参数一个是code一个是state。例如:
      http://xxxx.xxxx.cn/om/wx/getUserInfo?code=CODE&state=1

    • 使用code调用网页授权的获取access_token接口取得access_token
      https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=APPSECRET&code=CODE&grant_type=authorization_code
      调用之后回返回OpenId以及网页授权的access_token

    • 使用access_token和openId获取用户信息
      https://api.weixin.qq.com/sns/userinfo?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN

      这样便去的了用户信息,我采用的方案便是这种,改方案的好处使用网页授权无需关心用户是否关注。

      注意:到此大家肯定发现了方法一和方法二获取用户信息的接口不一样;
      对于这两个接口要给大家说明一下:方法一中的获取用户信息接口有先决条件首先用户需要关注公众号,然后接口中的ACCESS_TOKEN必须是全局的!!!
      方法二当中的:不需要用户关注,只需要授权即可,ACCESS_TOKEN是网页授权的次数没有限制

    方法三:通过网页授权不弹出授权页面获得用户基本信息

    个人感觉该方法就是上面两种方法的综合体,该方法有一定局限性,需要用户关注!!!

    • 微信公众号配置回调域名
    • 网页授权请求构造(静默)
      https://open.weixin.qq.com/connect/oauth2/authorize?appid=APPID&redirect_uri=REDIRECT_URL&response_type=code&scope=snsapi_base&state=1#wechat_redirect
      和方法二的区别就是scope=snsapi_base作用域变成不弹出授权页面只进行跳转,只获取用户的OpenId
    • REDIRECT_URL回调页面
      当请求成功的时候会重定向到回调页面(接口),此时的URL将会增加俩参数一个是code一个是state。例如:
      http://xxxx.xxxx.cn/om/wx/getUserInfo?code=CODE&state=1
      取到code
    • 获取全局的Access Token(下面的步骤就和方法一种的一样了)
      https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET
    • 在使用全局access_token获取OpenId的详细信息
      https://api.weixin.qq.com/cgi-bin/user/info?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN

    注意点:

    对添加的回调页面域名:首先,不能加入http:// ,只需要填写域名;另外,只需要写总的域名地址,不需要精确到最内层。
    https的回调好像有问题,尽量使用http吧,这个我没有深入。

    4、代码的实现(暂时只对方法2进行了实现)

    上面的原理都已经讲过了在这里可能只贴代码不进行具体的讲解了

    Controller层代码:
    package com.jerei.ebase.modules.ommt.controller;
    
    import com.baomidou.mybatisplus.mapper.EntityWrapper;
    import com.jerei.ebase.common.result.Result;
    import com.jerei.ebase.common.utils.RedisUtils;
    import com.jerei.ebase.modules.ommt.entity.WeiXinUser;
    import com.jerei.ebase.modules.ommt.entity.WxUserSignEntity;
    import com.jerei.ebase.modules.ommt.service.WeiXinUserInfoService;
    import com.jerei.ebase.modules.ommt.service.WxUserSignService;
    import com.jerei.ebase.modules.ommt.util.ProjectConst;
    import org.slf4j.Logger;
    import org.slf4j.LoggerFactory;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.web.bind.annotation.RequestMapping;
    import org.springframework.web.bind.annotation.RestController;
    import org.springframework.web.servlet.ModelAndView;
    import org.springframework.web.servlet.view.RedirectView;
    
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpSession;
    import java.util.HashMap;
    import java.util.Map;
    
    /**
     * @author 柚子
     * @Description: om-meeting-pro
     * @Title: 重定向之后调取的url
     * @Created by zhongshuiayou on 2019/4/25 16:36
     */
    @RestController
    @RequestMapping("/wx")
    public class WeiXinUserInfoController {
    	private static Logger logger = LoggerFactory.getLogger(WeiXinUserInfoController.class);
    	@Autowired
    	private WeiXinUserInfoService userService;
    
    	@Autowired
    	private WxUserSignService wxUserSignService;
    	/**
    	 * 进行网页授权,便于获取到用户的绑定的内容
    	 * @param request
    	 * @param session
    	 * @param map
    	 * @return
    	 */
    	@RequestMapping("/getUserInfo")
    	public ModelAndView check(HttpServletRequest request , HttpSession session, Map<String, Object> map) {
    		//首先判断一下session中,是否有保存着的当前用户的信息,有的话,就不需要进行重复请求信息
    		//这个地方作用主要是一次授权可以维持一定时间不需要再次授权
    		WeiXinUser  weiXinUser = null ;
    		if(session.getAttribute("currentUser") != null){
    			weiXinUser = (WeiXinUser) session.getAttribute("currentUser");
    		}else {
    			/**
    			 * 进行获取openId,必须的一个参数,这个是当进行了授权页面的时候,再重定向了我们自己的一个页面的时候
    			 */
    			String code = request.getParameter("code");
    			try {
    				//得到当前用户的信息(具体信息就看weixinUser这个javabean)
    				weiXinUser = getTheCode(session, code);
    				logger.info(weiXinUser.toString());
    				WxUserSignEntity wxUserSignEntity = wxUserSignService.selectOne(new EntityWrapper<WxUserSignEntity>().eq("open_id",weiXinUser.getOpenId()));
    				if (wxUserSignEntity==null|| wxUserSignEntity.getOpenId()==null) {
    					//保存用户信息的业务代码
    					wxUserSignEntity = new WxUserSignEntity();
    					wxUserSignEntity.setOpenId(weiXinUser.getOpenId());
    					wxUserSignEntity.setNickname(weiXinUser.getNickname());
    					wxUserSignEntity.setHeadImgUrl(weiXinUser.getHeadImgUrl());
    					wxUserSignEntity.setCity(weiXinUser.getCity());
    					wxUserSignEntity.setLanguage(weiXinUser.getLanguage());
    					wxUserSignEntity.setSex(weiXinUser.getSex());
    					wxUserSignEntity.setProvince(weiXinUser.getProvince());
    					wxUserSignEntity.setCountry(weiXinUser.getCountry());
    					wxUserSignService.insert(wxUserSignEntity);
    				}else{
    					//返回参与活动成功之后的页面
    					return new ModelAndView(new RedirectView(ProjectConst.Get_WEIXINPAGE_Code));
    				}
    				//将获取到的用户信息,放入到session中
    				System.out.println(weiXinUser.toString());
    				session.setAttribute("currentUser", weiXinUser);
    			} catch (Exception e) {
    				e.printStackTrace();
    			}
    		}
    		map.put("weiXinUser", weiXinUser);
    		return new ModelAndView(new RedirectView(ProjectConst.Get_WEIXINPAGE_Code));
    	}
    	/**
    	 * 获取用户的openId
    	 * @param session
    	 * @param code
    	 * @return 返回封装的微信用户的对象
    	 */
    	private WeiXinUser getTheCode(HttpSession session, String code) {
    		Map<String , String> authInfo = new HashMap<>();
    		String openId = "";
    		if (code != null)
    		{
    			// 调用根据用户的code得AccessToken 已经openId
    			authInfo= userService.getAuthInfo(code);
    			//获取到openId
    			openId = authInfo.get("Openid");
    		}
    		//获取到微信用户的信息
    		WeiXinUser userinfo = userService.getUserInfo(authInfo.get("AccessToken") ,openId);
    
    		return userinfo;
    	}
    }
    
    
    Service层接口:
    package com.jerei.ebase.modules.ommt.service;
    
    import com.jerei.ebase.modules.ommt.entity.WeiXinUser;
    
    import java.util.Map;
    
    /**
     * @author 柚子
     * @Description: om-meeting-pro
     * @Title: 获取微信用户信息service接口
     * @Created by zhongshuiayou on 2019/4/25 13:59
     */
    public interface WeiXinUserInfoService {
    	/**
    	 * 获取到微信个人用户的信息
    	 * @param accessToken
    	 * @param openId
    	 * @return
    	 */
    	WeiXinUser getUserInfo(String accessToken, String openId);
    
    	/**
    	 *用于获取网页授权后的信息字段,其中主要是获取openId
    	 * @param code  授权码
    	 * @return
    	 */
    	Map<String , String > getAuthInfo(String code);
    
    	/**
    	 * 进行网页授权的认证
    	 * @param code 授权码
    	 * @return
    	 */
    	Map<String,String> oauth2GetOpenid(String code);
    }
    
    
    Service实现层:
    package com.jerei.ebase.modules.ommt.service.impl;
    
    import com.alibaba.fastjson.JSONObject;
    import com.jerei.ebase.modules.ommt.entity.WeiXinUser;
    import com.jerei.ebase.modules.ommt.service.WeiXinUserInfoService;
    import com.jerei.ebase.modules.ommt.util.ProjectConst;
    import com.jerei.ebase.modules.ommt.util.WxUtils;
    import org.springframework.stereotype.Service;
    
    import java.util.HashMap;
    import java.util.Map;
    
    /**
     * @author 柚子
     * @Description: om-meeting-pro
     * @Title: 获取用户信息实现层
     * @Created by zhongshuiayou on 2019/4/25 14:01
     */
    
    @Service
    public class WeiXinUserInfoImlp implements WeiXinUserInfoService {
    	@Override
    	public WeiXinUser getUserInfo(String accessToken, String openId) {
    		WeiXinUser weixinUserInfo = null;
    		// 拼接获取用户信息接口的请求地址access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN
    		String requestUrl = ProjectConst.GET_PAGEUSERS_URL+"access_token="+accessToken+"&openid="+openId+"&lang=zh_CN";
    		// 获取用户信息(返回的是Json格式内容)
    		JSONObject jsonObject = WxUtils.doGetStr(requestUrl);
    
    		if (null != jsonObject) {
    			try {
    				//封装获取到的用户信息
    				weixinUserInfo = new WeiXinUser();
    				// 用户的标识
    				weixinUserInfo.setOpenId(jsonObject.getString("openid"));
    				// 昵称
    				weixinUserInfo.setNickname(WxUtils.filterEmoji(jsonObject.getString("nickname")));
    				// 用户的性别(1是男性,2是女性,0是未知)
    				weixinUserInfo.setSex(jsonObject.getInteger("sex"));
    				// 用户所在国家
    				weixinUserInfo.setCountry(jsonObject.getString("country"));
    				// 用户所在省份
    				weixinUserInfo.setProvince(jsonObject.getString("province"));
    				// 用户所在城市
    				weixinUserInfo.setCity(jsonObject.getString("city"));
    				// 用户头像
    				weixinUserInfo.setHeadImgUrl(jsonObject.getString("headimgurl"));
    			} catch (Exception e) {
    				//这个地方可以去掉不会出现这种问题(原文博主是用地三种方式取的,我已经将其修改成为第二种)
    				//可以只留着else里面的错误信息
    				//if (0 == weixinUserInfo.getSubscribe()) {
    				//	System.out.println("用户并没有关注本公众号");
    				//} else {
    					int errorCode = jsonObject.getInteger("errcode");
    					String errorMsg = jsonObject.getString("errmsg");
    					System.out.println("由于"+errorCode +"错误码;错误信息为:"+errorMsg+";导致获取用户信息失败");
    				//}
    			}
    		}
    		return weixinUserInfo;
    	}
    
    	@Override
    	public Map<String, String> getAuthInfo(String code) {
    		//进行授权验证,获取到OpenID字段等信息包括AccessToken
    		Map<String, String> result = oauth2GetOpenid(code);
    		// 从这里可以得到用户openid
    		String openId = result.get("Openid");
    
    		return result;
    
    	}
    
    	@Override
    	public Map<String, String> oauth2GetOpenid(String code) {
    		//自己的配置appid(公众号进行查阅)
    		String appid = ProjectConst.PROJECT_APPID;
    		//自己的配置APPSECRET;(公众号进行查阅)
    		String appsecret = ProjectConst.PROJECT_APPSECRET;
    		//拼接用户授权接口信息
    		String requestUrl = ProjectConst.GET_WEBAUTH_URL+"appid="+appid+"&secret="+appsecret+"&code="+code+"&grant_type=authorization_code";
    		//存储获取到的授权字段信息
    		Map<String, String> result = new HashMap<String, String>();
    		try {
    			//这个地方用户自行判断是否要保存该信息(此处主要实现的功能是通过网页授权获取openId,access_token)
    			JSONObject OpenidJSONO = WxUtils.doGetStr(requestUrl);
    			//OpenidJSONO可以得到的内容:access_token expires_in  refresh_token openid scope
    			String Openid = String.valueOf(OpenidJSONO.get("openid"));
    			String AccessToken = String.valueOf(OpenidJSONO.get("access_token"));
    			//用户保存的作用域
    			String Scope = String.valueOf(OpenidJSONO.get("scope"));
    			String refresh_token = String.valueOf(OpenidJSONO.get("refresh_token"));
    			result.put("Openid", Openid);
    			result.put("AccessToken", AccessToken);
    			result.put("scope", Scope);
    			result.put("refresh_token", refresh_token);
    		} catch (Exception e) {
    			e.printStackTrace();
    		}
    		return result;
    	}
    }
    
    
    实体类接口:

    由于采用的是方法2的方式所以有一些字段是没有数据的,原文博客的博主是采用方法3取得因此在此我没有进行修改,基础字段是一样,我采用lombok因此没有get和set方法,需要的同学自行加上就好。

    package com.jerei.ebase.modules.ommt.entity;
    
    import lombok.Data;
    
    /**
     * @author 柚子
     * @Description: om-meeting-pro
     * @Title: 获取微信用户信息实体
     * @Created by zhongshuiayou on 2019/4/25 8:26
     */
    @Data
    public class WeiXinUser {
    	/**
    	 * 用户的标识
    	 */
    	private String openId;
    	/**
    	 * 关注状态(1是关注,0是未关注),未关注时获取不到其余信息
    	 */
    	private int subscribe;
    	/**
    	 * 用户关注时间,为时间戳。如果用户曾多次关注,则取最后关注时间
    	 */
    	private String subscribeTime;
    	/**
    	 * 昵称
    	 */
    	private String nickname;
    	/**
    	 * 用户的性别(1是男性,2是女性,0是未知)
    	 */
    	private int sex;
    	/**
    	 * 用户所在国家
    	 */
    	private String country;
    	/**
    	 * 用户所在省份
    	 */
    	private String province;
    	/**
    	 * 用户所在城市
    	 */
    	private String city;
    	/**
    	 * 用户的语言,简体中文为zh_CN
    	 */
    	private String language;
    	/**
    	 * 用户头像
    	 */
    	private String headImgUrl;
    
    	@Override
    	public String toString() {
    		return "WeiXinUser{" +
    				"openId='" + openId + '\'' +
    				", subscribe=" + subscribe +
    				", subscribeTime='" + subscribeTime + '\'' +
    				", nickname='" + nickname + '\'' +
    				", sex=" + sex +
    				", country='" + country + '\'' +
    				", province='" + province + '\'' +
    				", city='" + city + '\'' +
    				", language='" + language + '\'' +
    				", headImgUrl='" + headImgUrl + '\'' +
    				'}';
    	}
    }
    
    用到的工具类以及静态常量:
    package com.jerei.ebase.modules.ommt.util;
    
    
    import com.alibaba.fastjson.JSONObject;
    import org.apache.http.HttpEntity;
    import org.apache.http.HttpResponse;
    import org.apache.http.client.ClientProtocolException;
    import org.apache.http.client.methods.HttpGet;
    import org.apache.http.impl.client.DefaultHttpClient;
    import org.apache.http.util.EntityUtils;
    
    import java.io.IOException;
    
    /**
     * @author 柚子
     * @Description: om-meeting-pro
     * @Title: 获取微信用户信息工具类
     * @Created by zhongshuiayou on 2019/4/25 13:49
     */
    public class WxUtils {
    	/**
    	 * Get请求,方便到一个url接口来获取结果
    	 * @param url
    	 * @return
    	 */
    	public static JSONObject doGetStr(String url) {
    		DefaultHttpClient defaultHttpClient = new DefaultHttpClient();
    		HttpGet httpGet = new HttpGet(url);
    		JSONObject jsonObject = null;
    		try {
    			HttpResponse response = defaultHttpClient.execute(httpGet);
    			HttpEntity entity = response.getEntity();
    			if (entity != null) {
    				String result = EntityUtils.toString(entity, "UTF-8");
    				jsonObject = JSONObject.parseObject(result);
    				System.out.println(jsonObject.toJSONString());
    			}
    		} catch (ClientProtocolException e) {
    			e.printStackTrace();
    		} catch (IOException e) {
    			e.printStackTrace();
    		}
    		return jsonObject;
    	}
    
    	/**
    	 * 检测是否有emoji字符
    	 * @param source 需要判断的字符串
    	 * @return 一旦含有就抛出
    	 */
    	public static boolean containsEmoji(String source) {
    		int len = source.length();
    		for (int i = 0; i < len; i++) {
    			char codePoint = source.charAt(i);
    			if (!notisEmojiCharacter(codePoint)) {
    				//判断确认有表情字符
    				return true;
    			}
    		}
    		return false;
    	}
    
    
    	/**
    	 * 非emoji表情字符判断
    	 * @param codePoint
    	 * @return
    	 */
    	private static boolean notisEmojiCharacter(char codePoint) {
    		return (codePoint == 0x0) ||
    				(codePoint == 0x9) ||
    				(codePoint == 0xA) ||
    				(codePoint == 0xD) ||
    				((codePoint >= 0x20) && (codePoint <= 0xD7FF)) ||
    				((codePoint >= 0xE000) && (codePoint <= 0xFFFD)) ||
    				((codePoint >= 0x10000) && (codePoint <= 0x10FFFF));
    	}
    
    	/**
    	 * 过滤emoji 或者 其他非文字类型的字符
    	 * @param source  需要过滤的字符串
    	 * @return
    	 */
    	public static String filterEmoji(String source) {
    		if (!containsEmoji(source)) {
    			//如果不包含,直接返回
    			return source;
    		}
    		//该buf保存非emoji的字符
    		StringBuilder buf = null;
    		int len = source.length();
    		for (int i = 0; i < len; i++) {
    			char codePoint = source.charAt(i);
    			if (notisEmojiCharacter(codePoint)) {
    				if (buf == null) {
    					buf = new StringBuilder(source.length());
    				}
    				buf.append(codePoint);
    			}
    		}
    
    		if (buf == null) {
    			//如果没有找到非emoji的字符,则返回无内容的字符串
    			return "";
    		} else {
    			if (buf.length() == len) {
    				buf = null;
    				return source;
    			} else {
    				return buf.toString();
    			}
    		}
    	}
    
    }
    
    
    /**
     * @author zhongshuiayou
     * @Description: om-meeting-pro
     * @Title: 静态常量(该静态常量当中基本列出了所有的常用获取微信用户信息接口,使用者按需取就可以了)
     * @Created by zhongshuiayou on 2019/4/25 13:25
     */
    public class ProjectConst {
    	//测试号 APPID 和APPSECRET
    	public static final String PROJECT_APPID ="";
    	public static final String PROJECT_APPSECRET ="";
    
    	/**
    	 * 用于获取当前与微信公众号交互的用户信息的接口(第一个接口需要用户关注第二个不需要)
    	 */
    	public static final String GET_WEIXIN_USER_URL = "https://api.weixin.qq.com/cgi-bin/user/info?access_token=ACCESS_TOKEN&openid=OPENID";
    	public final static String GET_PAGEUSERS_URL = "https://api.weixin.qq.com/sns/userinfo?";
    
    	/**
    	 * 用于进行网页授权验证的接口URL,通过这个才可以得到opendID等字段信息(用户网页授权access_token 获取接口地址)
    	 */
    	public final static String GET_WEBAUTH_URL = "https://api.weixin.qq.com/sns/oauth2/access_token?";
    
    	/**
    	 * 这个主要是为了获取用户信息成功之后的跳转页面
    	 * 注意:参数:REDIRECT_URL 表示的是当授权成功后,跳转到的自己设定的页面,所以这个要根据自己的需要进行修改
    	 * 使用位置:是在控制器当中的modelAndView的返回中使用的
    	 */
    	public final static String Get_WEIXINPAGE_Code = "https://open.weixin.qq.com/connect/oauth2/authorize?appid=APPID&redirect_uri=REDIRECT_URL&response_type=code&scope=snsapi_userinfo&state=1#wechat_redirect";
    	/**
    	 * 获取access_token的URL(基础接口的token也叫全局access_token获取接口)
    	 */
    	public static final String ACCESS_TOKEN_URL = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET";
    }
    
    

    文章在再这里基本上就结束了,这样就能获取到用户信息,至于实际当中用什么方法取要看业务需求,如果大家还有疑问可以通过qq联系我,谢谢。

    5、上面实现代码参考

    我也是参考了之前大神的文章写的,原博文当中的疑问我也已经搞明白,有不明白的可以咨询我。
    原文地址:方法参考原文地址

    展开全文
  • 在学习网页授权之前,我们先来了解下这次的需求:我们的应用中有一个用来显示个人信息的页面,当微信用户微信app中打开这个页面,希望可以获取到该用户的头像,昵称等信息,并显示到该页面中。如下图所示:如果...
  • 开发可以自动实现用户登录的校验,开发者无需再次校验用户身份,直接通过云函数的 event.userInfo.openId 即可获取用户信息。直接调用数据库 、文件存储 API 时,也会自动关联到用户对应的 openId。如果用户授权...
  • 本片博客降解的网页授权分为两步,一是企业微信配置的...由于微信是本地开发,需要本地开发测试,准备一个内网穿透,将本地127.0.0.1:端口/项目名下所在的服务穿透到外网去,以便能与微信服务器通讯,开发调试;关...
  • 第一步:获取公众号的微信号(公众号微信号默认是没有设置的,需要设置后才有) 第二步:使用官网地址,生成公众号二维码 从微信官方获取微信公众号名片:...
  • 微信公众号开发获取openID以及用户详细信息,超详细步骤,亲测开发
  •  需要做一套微信签到、抽奖系统,我要在后台存储微信用户的相关信息,openIDNickname之类的信息。在开发前有一点准备工作,先去授权权限,在权限表里进行设置,如图:   填写这个网站地址的时候一定要注意填写...
  • 微信开发获取地理位置实例(java),使用环境 eclipse + maven + springmvc,虽然项目名是first_maven_project,但是确实是微信开发实例哈,不要有任何怀疑,免费分享啦,哈哈。实例讲解欢迎访问博主博客...
  • springboot项目,h5页面通过微信公众号获取微信用户信息 最近本人有一个项目需求,微信公众号里点击一个菜单进入一个商城购物系统。 对于在微信公众号还是小白的我来说难度有点大,但是做完后发现也就这样,用多了就...
  • 很多开发者在开发微信... 首先要获取微信发送过来的access_token,然后根据openid和access_token,来获取微信服务器发送过来json格式的用户消息,最后用josn_decode来转化一下就能获取用户的详细消息了; 在写...
  • 微信授权登陆: ... 第一步:用户同意授权、获取code 第二步:通过code换取网页授权access_token 详细步骤参考微信公众号平台 在页面地址输入授权后的url: eg: scope为snsapi_userinfo ...
  • 废话不多说,如果你的公众号 部署到线上出现...如果能获取到 code ,再次去检查你的微信公众号 的开发配置里面 是否配置了 ip白名单,如果没有配置,请配置一下。如果code获取不到 请重置 appsecret。什么特么的请求...
  • 微信公众号的开发主要是在服务号环境下进行,订阅号是拿不到用户的资料的,因此,下文的讨论都基于微信服务号。 微信公众号的两个access_token 在微信开发文档中,存在两个access_token,需要对它们加以区别。...
  • 获取微信用户绑定的手机号 1.getPhoneNumber这个组件通过button来实现(别的标签无效)。将button中的open-type=“getPhoneNumber”,并且绑定bindgetphonenumber事件获取回调。 &lt;button open-type="...
  • 做为一名开发人员,在测试当中也经常需要用到openid,但是微信公众号获取openid的方法也是特别麻烦!网页授权是最常见的方式, 但是网页授权的流程太复杂,不仅要开发,还要在公众号后台设置回调域名(必须备案域名...
  • 微信公众号获取微信用户api调用 使用appid,redirect_url获取code string.Format(“https://open.weixin.qq.com/connect/oauth2/authorize?appid={0}&redirect_uri={1}&response_type=code&scope=...
  • 申请微信appid,2.微信secret,3.微信mchid商户名,4.微信key,5.下载证书,6.商户平台设置扫码回调接口,即项目的外网可访问地址微信企业付款官方文档:...
1 2 3 4 5 ... 20
收藏数 7,691
精华内容 3,076
关键字:

微信开发 获取用户微信号