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);
}
}
}
}
}