微信开发--怎么获取用户的信息(openid)

来源:互联网 发布:淘宝怎么看是不是假货 编辑:程序博客网 时间:2024/06/05 01:29



using System.Collections.Generic;
using System.Linq;
using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Net;
using System.Text;
using System.IO;
namespace WebApplication4
{
    public partial class WebForm7 : System.Web.UI.Page
    {


        protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {

                string reurl = "";
                //传递参数,获取用户信息后,可跳转到自己定义的页面,想怎么处理就怎么处理
                if (Request.QueryString["reurl"] != null && Request.QueryString["reurl"] != "")
                {
                    reurl = Request.QueryString["reurl"].ToString();
                }
                else
                {
                    reurl = "http://xxxx/mqwhlst/home.aspx";
                }


                // string code = "";

                string appid = "xxxxx";  //公众微信平台下可以找到
                string redirectUrl = HttpUtility.UrlEncode("http://www.xxx/mqwhlst/wxProcess2.aspx");
                
                //弹出授权页面(如在不弹出授权页面基础下未获得openid,弹出授权页面,提示用户授权)
                if (Request.QueryString["auth"] != null && Request.QueryString["auth"] != "" && Request.QueryString["auth"] == "1")
                {
                    //弹出对话框提示用户名错误
                    
                                
                    string url =  string.Format("https://open.weixin.qq.com/connect/oauth2/authorize?appid=" + appid + "&redirect_uri=" + redirectUrl + "&response_type=code&scope=snsapi_userinfo&state=STATE#wechat_redirect");
                    Response.Redirect(url);

                }
                else
                {
                    //不弹出授权页面
                    //弹出对话框提示用户名错误
              
                    string url = string.Format("https://open.weixin.qq.com/connect/oauth2/authorize?appid=" + appid + "&redirect_uri=" + redirectUrl + "&response_type=code&scope=snsapi_base&state=1#wechat_redirect");
                    Response.Redirect(url);
                }
            }
        }
    }

    }


using System.Collections.Generic;
using System.Linq;
using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Net;
using System.Text;
using System.Runtime.Serialization.Json;
using System.Runtime.Serialization;
using System.IO;
//using bhPortal;
using System.Data.SqlClient;

namespace WebApplication4
{
    public partial class WebForm4 : System.Web.UI.Page
    {
        public string reurl = "";
       
        protected void Page_Load(object sender, EventArgs e)
        {

            if (!IsPostBack)
            {
                //获取从wxProcess.aspx传递过来的跳转地址reurl
                if (Request.QueryString["reurl"] != null && Request.QueryString["reurl"] != "")
                {
                    reurl = Request.QueryString["reurl"].ToString();
                    reurl = "http://xxxxx/mqwhlst/home.aspx";
                }

                string code = "";
                if (Request.QueryString["code"] != null && Request.QueryString["code"] != "")
                {
                    //获取微信回传的code
                    code = Request.QueryString["code"].ToString();
                    OAuth_Token Model = Get_token(code);  //获取token
                    OAuthUser OAuthUser_Model = Get_UserInfo(Model.access_token, Model.openid);
                    if (OAuthUser_Model.openid != null && OAuthUser_Model.openid != "")  //已获取得openid及其他信息
                    {
                        //在页面上输出用户信息
                        //Response.Write("用户OPENID:" + OAuthUser_Model.openid +
                        //    "<br>用户昵称:" + OAuthUser_Model.nickname +
                        //    "<br>性别:" + OAuthUser_Model.sex +
                        //    "<br>所在省:" + OAuthUser_Model.province +
                        //    "<br>所在市:" + OAuthUser_Model.city +
                        //    "<br>所在国家:" + OAuthUser_Model.country +
                        //    "<br>头像地址:" + OAuthUser_Model.headimgurl +
                        //    "<br>用户特权信息:" + OAuthUser_Model.privilege);
                        Session["openid"] = OAuthUser_Model.openid;
                        string openid = Session["openid"].ToString();
                        //或跳转到自己的页面,想怎么处理就怎么处理
                        //创建连接对象   
                        SqlConnection conn = new SqlConnection(System.Configuration.ConfigurationManager.ConnectionStrings["connection"].ConnectionString);
                        //创建查询,openid和手机号是否存在数据对象   
                        SqlCommand cmd = new SqlCommand("select * from users where mobilenumber is not null and openid='" + openid + "'", conn);
                        try
                        {
                            //如果存在则打开数据库
                            conn.Open();
                            SqlDataReader sdr = cmd.ExecuteReader();
                        
                            //如果openid和手机号存在
                            //非第一次登陆:查询后天的openid是否为空,不为空,说明用户已维护,直接进去查询界面
                            if (sdr.Read())
                            {

                                Session["branch"] = sdr["branch"].ToString();      
                                conn.Close();
                                Response.Redirect("home.aspx?openid=" + openid );
                            }
                            //第一次登陆判断:查询后台的openid是否为空,如果为空,说明用户第一次登陆,提示用户输入手机号;
                            //先查看手机号是否存在,存在的话,把openid和手机号匹配上,不存在说明不是我们的用户,拒绝登陆
                            else//否则
                            {
                                //跳转到手机号输入界面
                                // Session["branch"] = sdr["branch"].ToString(); ;
                                string urlphone = string.Format("mobile.aspx?openid=" + openid );
                                Response.Redirect(urlphone);
                            }
                        }
                        catch (System.Exception ee)//异常处理
                        {
                            Response.Write("<script  language=javascript>alert('" + ee.Message.ToString() + "')</script>");
                        }

                        finally
                        {
                            conn.Close(); //关闭数据库
                        }
        }
                        // Response.Redirect(home.aspx);      
                    else  //未获得openid,回到wxProcess.aspx,访问弹出微信授权页面,提示用户授权
                    {
                        Response.Redirect("wxProcess.aspx?auth=1");
                    }
                }
            }
        }

        #region 属性
        public string appid = "xxx";  //公众微信平台下可以找到
        public string appsecret = "xxxx";  //公众微信平台下可以找到
        #endregion

        //根据appid,secret,code获取微信openid、access token信息
        protected OAuth_Token Get_token(string Code)
        {
            //获取微信回传的openid、access token
            string Str = GetJson("https://api.weixin.qq.com/sns/oauth2/access_token?appid=" + appid + "&secret=" + appsecret + "&code=" + Code + "&grant_type=authorization_code");
            //微信回传的数据为Json格式,将Json格式转化成对象
            OAuth_Token Oauth_Token_Model = JsonHelper.ParseFromJson<OAuth_Token>(Str);
            return Oauth_Token_Model;
        }

        //刷新Token(好像这个刷新Token没有实际作用)
        protected OAuth_Token refresh_token(string REFRESH_TOKEN)
        {
            string Str = GetJson("https://api.weixin.qq.com/sns/oauth2/refresh_token?appid=" + appid + "&grant_type=refresh_token&refresh_token=" + REFRESH_TOKEN);
            OAuth_Token Oauth_Token_Model = JsonHelper.ParseFromJson<OAuth_Token>(Str);
            return Oauth_Token_Model;
        }

        //根据openid,access token获得用户信息
        protected OAuthUser Get_UserInfo(string REFRESH_TOKEN, string OPENID)
        {
            string Str = GetJson("https://api.weixin.qq.com/sns/userinfo?access_token=" + REFRESH_TOKEN + "&openid=" + OPENID);
            OAuthUser OAuthUser_Model = JsonHelper.ParseFromJson<OAuthUser>(Str);
            return OAuthUser_Model;
        }

        //访问微信url并返回微信信息
        protected string GetJson(string url)
        {
            WebClient wc = new WebClient();
            wc.Credentials = CredentialCache.DefaultCredentials;
            wc.Encoding = Encoding.UTF8;
            string returnText = wc.DownloadString(url);

            if (returnText.Contains("errcode"))
            {
                //可能发生错误
            }
            return returnText;
        }


        /// <summary>
        /// token类
        /// </summary>
        public class OAuth_Token
        {
            public OAuth_Token()
            {

                //
                //TODO: 在此处添加构造函数逻辑
                //
            }
            //access_token 网页授权接口调用凭证,注意:此access_token与基础支持的access_token不同
            //expires_in access_token接口调用凭证超时时间,单位(秒)
            //refresh_token 用户刷新access_token
            //openid 用户唯一标识,请注意,在未关注公众号时,用户访问公众号的网页,也会产生一个用户和公众号唯一的OpenID
            //scope 用户授权的作用域,使用逗号(,)分隔
            public string _access_token;
            public string _expires_in;
            public string _refresh_token;
            public string _openid;
            public string _scope;
            public string access_token
            {
                set { _access_token = value; }
                get { return _access_token; }
            }
            public string expires_in
            {
                set { _expires_in = value; }
                get { return _expires_in; }
            }

            public string refresh_token
            {
                set { _refresh_token = value; }
                get { return _refresh_token; }
            }
            public string openid
            {
                set { _openid = value; }
                get { return _openid; }
            }
            public string scope
            {
                set { _scope = value; }
                get { return _scope; }
            }

        }

        /// <summary>
        /// 用户信息类
        /// </summary>
        public class OAuthUser
        {
            public OAuthUser()
            { }
            #region 数据库字段
            private string _openID;
            private string _searchText;
            private string _nickname;
            private string _sex;
            private string _province;
            private string _city;
            private string _country;
            private string _headimgUrl;
            private string _privilege;
            #endregion

            #region 字段属性
            /// <summary>
            /// 用户的唯一标识
            /// </summary>
            public string openid
            {
                set { _openID = value; }
                get { return _openID; }
            }
            /// <summary>
            ///
            /// </summary>
            public string SearchText
            {
                set { _searchText = value; }
                get { return _searchText; }
            }
            /// <summary>
            /// 用户昵称
            /// </summary>
            public string nickname
            {
                set { _nickname = value; }
                get { return _nickname; }
            }
            /// <summary>
            /// 用户的性别,值为1时是男性,值为2时是女性,值为0时是未知
            /// </summary>
            public string sex
            {
                set { _sex = value; }
                get { return _sex; }
            }
            /// <summary>
            /// 用户个人资料填写的省份
            /// </summary>
            public string province
            {
                set { _province = value; }
                get { return _province; }
            }
            /// <summary>
            /// 普通用户个人资料填写的城市
            /// </summary>
            public string city
            {
                set { _city = value; }
                get { return _city; }
            }
            /// <summary>
            /// 国家,如中国为CN
            /// </summary>
            public string country
            {
                set { _country = value; }
                get { return _country; }
            }
            /// <summary>
            /// 用户头像,最后一个数值代表正方形头像大小(有0、46、64、96、132数值可选,0代表640*640正方形头像),用户没有头像时该项为空
            /// </summary>
            public string headimgurl
            {
                set { _headimgUrl = value; }
                get { return _headimgUrl; }
            }
            /// <summary>
            /// 用户特权信息,json 数组,如微信沃卡用户为(chinaunicom)其实这个格式称不上JSON,只是个单纯数组
            /// </summary>
            public string privilege
            {
                set { _privilege = value; }
                get { return _privilege; }
            }
            #endregion
        }

        /// <summary>
        /// 将Json格式数据转化成对象
        /// </summary>
        public class JsonHelper
        {
            /// <summary> 
            /// 生成Json格式 
            /// </summary> 
            /// <typeparam name="T"></typeparam> 
            /// <param name="obj"></param> 
            /// <returns></returns> 
            public static string GetJson<T>(T obj)
            {
                DataContractJsonSerializer json = new DataContractJsonSerializer(obj.GetType());
                using (MemoryStream stream = new MemoryStream())
                {
                    json.WriteObject(stream, obj);
                    string szJson = Encoding.UTF8.GetString(stream.ToArray()); return szJson;
                }
            }
            /// <summary> 
            /// 获取Json的Model 
            /// </summary> 
            /// <typeparam name="T"></typeparam> 
            /// <param name="szJson"></param> 
            /// <returns></returns> 
            public static T ParseFromJson<T>(string szJson)
            {
                T obj = Activator.CreateInstance<T>();
                using (MemoryStream ms = new MemoryStream(Encoding.UTF8.GetBytes(szJson)))
                {
                    DataContractJsonSerializer serializer = new DataContractJsonSerializer(obj.GetType());
                    return (T)serializer.ReadObject(ms);
                }
            }
        }

    }
}




原创粉丝点击