热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

微信登录(网站应用)ASP.NET

微信登录(网站应用)ASP.NET第一步:请求CODE.第二步:通过CODE获取access_token.第三步:通过access_token调用接

微信登录(网站应用)ASP.NET

第一步:请求CODE.
第二步:通过CODE获取access_token.
第三步:通过access_token调用接口
代码在底部

官方开发指南(指南已经说的很清楚了)

官方流程图:
这里写图片描述


第一步:
第三方使用网站应用授权登录前请注意已获取相应网页授权作用域(scope=snsapi_login),则可以通过在PC端打开以下链接:
https://open.weixin.qq.com/connect/qrconnect?appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope=SCOPE&state=STATE#wechat_redirect
若提示“该链接无法访问”,请检查参数是否填写错误,如redirect_uri的域名与审核时填写的授权域名不一致或scope不为snsapi_login

这里写图片描述
这里写图片描述

请求示例

登录一号店网站应用
https://passport.yhd.com/wechat/login.do
打开后,一号店会生成state参数,跳转到
https://open.weixin.qq.com/connect/qrconnect?appid=wxbdc5610cc59c1631&redirect_uri=https%3A%2F%2Fpassport.yhd.com%2Fwechat%2Fcallback.do&response_type=code&scope=snsapi_login&state=3d6be0a4035d839573b04816624a415e#wechat_redirect
微信用户使用微信扫描二维码并且确认登录后,PC端会跳转到
https://passport.yhd.com/wechat/callback.do?code=CODE&state=3d6be0a4035d839573b04816624a415e

第二步:
https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code
这里写图片描述
这里写图片描述

第三步:(我调用的是获取个人信息接口)
获取用户个人信息(UnionID机制)
接口说明
此接口用于获取用户个人信息。开发者可通过OpenID来获取用户基本信息。特别需要注意的是,如果开发者拥有多个移动应用、网站应用和公众帐号,可通过获取用户基本信息中的unionid来区分用户的唯一性,因为只要是同一个微信开放平台帐号下的移动应用、网站应用和公众帐号,用户的unionid是唯一的。换句话说,同一用户,对同一个微信开放平台下的不同应用,unionid是相同的。请注意,在用户修改微信头像后,旧的微信头像URL将会失效,因此开发者应该自己在获取用户信息后,将头像图片保存下来,避免微信头像URL失效后的异常情况。
请求说明
http请求方式: GET
https://api.weixin.qq.com/sns/userinfo?access_token=ACCESS_TOKEN&openid=OPENID

这里写图片描述

这里写图片描述

代码:

//=======【微信开放平台应用基本信息设置】
/* 微信登录信息配置
* L_APPID:微信开放平台应用的APPID
* L_APPSECRET:微信开放平台应用asecert
* L_QRCONNECTION :请求code 地址
* L_REDIRECTURL :重定向地址(必须进行UrlEncode)
*/


///
/// 转到微信登录窗口,拼接URL 进行请求
///

///
///
public partial class redirectPage : System.Web.UI.Page
{
string state = WxPayApi.GenerateNonceStr();
Session["validState"] = state;
string wxLoginPage = WxPayConfig.L_QRCONNECTION + "appid=" + WxPayConfig.L_APPID + "&redirect_uri=" + HttpUtility.UrlEncode(WxPayConfig.L_REDIRECTURL) + "&response_type=code&scope=snsapi_login&state=" + state + "#wechat_redirect";//
Response.Redirect(wxLoginPage);
}

用户进行扫码后,重定向到配置的redirect_uri 页面,此页面代码:

    public partial class wxLoginRedirectURL : System.Web.UI.Page
{
private static JavascriptSerializer jss = null;
private static BLL.User user = null;
private static Model.UserEntity uentity = null;
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
string code = Request.QueryString["code"] ?? "";
if (!string.IsNullOrEmpty(code))
{
string state = Request.QueryString["state"] ?? "";//微信回发的上一步设置的state
if (!string.IsNullOrEmpty(Session["validState"].ToString()) && !string.IsNullOrEmpty(state))
{
if (Equals(Session["validState"].ToString(), state))// 校验是否相等
{
//域名所属人ID
string duserid = 1;//测试用户id
//拼接获取access_token的URL(通过code获取access_token)
string getTokenUrl = WxPayConfig.L_ACCESSTOKEN + "appid=" + WxPayConfig.L_APPID + "&secret=" + WxPayConfig.L_APPSECRET + "&code=" + code + "&grant_type=authorization_code";
string tokenResult = HttpService.Get(getTokenUrl);//开始请求
jss = new JavascriptSerializer();
// 反序列化token 信息
TokenResult obj = jss.Deserialize(tokenResult);
if (string.IsNullOrEmpty(obj.errcode))
{
user = new BLL.User();
//拼接获取用户信息的接口,通过access_token调用接口(获取用户个人信息接口(/sns/userinfo))
string wxUserInfoUrl = WxPayConfig.L_SNSUSERINFO + "access_token=" + obj.access_token + "&openid=" + obj.openid;
string userInfoResult = HttpService.Get(wxUserInfoUrl);
// 反序列化用户信息
UserInfoResult uobj = jss.Deserialize(userInfoResult);
//检查是否数据库中存在
Model.UserEntity IsExistEntity = user.SelectByUserName(uobj.unionid);
if (IsExistEntity != null)
{
//用户存在
Session["uid"] = IsExistEntity.Id;
// Log.Info("用户存在=", "!=null");
Model.UserEntity pentity = user.Select(Convert.ToInt32(duserid));
Response.Redirect(pentity.DomainLevel);
}
else
{
//用户不存在
// 存储数据库
uentity = new Model.UserEntity();
uentity.Name = uobj.nickname;
uentity.UserName = uobj.unionid;
uentity.Description = uobj.headimgurl;
if (!string.IsNullOrEmpty(duserid))
{
uentity.ParentId = Convert.ToInt32(duserid);
}
int uid = user.Save(uentity);
if (uid > 0)
{//存储session
Session["uid"] = uid;
//根据Session["pid"] 获取host
Model.UserEntity pentity = user.Select(Convert.ToInt32(duserid));
if (pentity != null)
{
Response.Redirect(" pentity.DomainLevel);
}
else
{
Log.Info("
pentity=", "null");
Response.Redirect("
~/custompage/err.htm");
}
}
}
}
else
{
// 失败
Log.Info("
反序列化openid", obj.errcode + ":" + obj.errmsg);
// 转走
Response.Redirect("
~/custompage/err.htm");
}

}
else
{
//校验失败
Response.Redirect("
~/custompage/err.htm");
}
}
else
{
//state 或Session["
validState"] 为null/空
Log.Info("
session[validstate]", Session["validState"].ToString());
}
}
else
{ //用户禁止授权
Response.Redirect("
~/main.aspx");
}
}
}
}
#region定义的序列化类
///
/// 获取微信用户信息
///

public class UserInfoResult : PubClass
{
public string nickname { get; set; }
public string province { get; set; }
public string city { get; set; }
public string country { get; set; }
public string headimgurl { get; set; }
public Array[] privilege { get; set; }
public string language { get; set; }
public int sex { get; set; }
}
///
/// access_token
///

public class TokenResult : PubClass
{
public string access_token { get; set; }
public string expires_in { get; set; }
public string refresh_token { get; set; }

public string scope { get; set; }

public string errcode { get; set; }
public string errmsg { get; set; }
}
///
/// 公有字段
///

public class PubClass
{
public string unionid { get; set; }
public string openid { get; set; }
}
#endregion

推荐阅读
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
  • 深入理解ASP.NET MVC中的_ViewStart.cshtml
    本文介绍了_ViewStart.cshtml文件在ASP.NET MVC 3.0及以上版本中的作用和使用方法。该文件位于Views目录下,主要用于统一配置视图布局和其他全局设置。 ... [详细]
  • 本文探讨了如何在iOS开发环境中,特别是在Xcode 6.1中,设置和应用自定义文本样式。我们将详细介绍实现方法,并提供一些实用的技巧。 ... [详细]
  • 树莓派摄像头配置与应用指南
    本文详细介绍了如何在树莓派上配置和使用摄像头,包括启用摄像头接口、简单的图片和视频捕捉方法以及如何通过网络实时传输视频流。 ... [详细]
  • 深入解析8086 CPU的转移指令
    本文详细介绍了8086 CPU中的转移指令,包括无条件转移、条件转移、循环指令及过程调用等,同时探讨了offset操作符的功能及其应用实例。 ... [详细]
  • 本文探讨了浏览器的同源策略限制及其对 AJAX 请求的影响,并详细介绍了如何在 Spring Boot 应用中优雅地处理跨域请求,特别是当请求包含自定义 Headers 时的解决方案。 ... [详细]
  • PyCharm下载与安装指南
    本文详细介绍如何从官方渠道下载并安装PyCharm集成开发环境(IDE),涵盖Windows、macOS和Linux系统,同时提供详细的安装步骤及配置建议。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 构建基于BERT的中文NL2SQL模型:一个简明的基准
    本文探讨了将自然语言转换为SQL语句(NL2SQL)的任务,这是人工智能领域中一项非常实用的研究方向。文章介绍了笔者在公司举办的首届中文NL2SQL挑战赛中的实践,该比赛提供了金融和通用领域的表格数据,并标注了对应的自然语言与SQL语句对,旨在训练准确的NL2SQL模型。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • 本文介绍如何使用Python进行文本处理,包括分词和生成词云图。通过整合多个文本文件、去除停用词并生成词云图,展示文本数据的可视化分析方法。 ... [详细]
  • 本文探讨了MariaDB在当前数据库市场中的地位和挑战,分析其可能面临的困境,并提出了对未来发展的几点看法。 ... [详细]
  • 本文介绍如何在现有网络中部署基于Linux系统的透明防火墙(网桥模式),以实现灵活的时间段控制、流量限制等功能。通过详细的步骤和配置说明,确保内部网络的安全性和稳定性。 ... [详细]
  • 本文作者分享了在阿里巴巴获得实习offer的经历,包括五轮面试的详细内容和经验总结。其中四轮为技术面试,一轮为HR面试,涵盖了大量的Java技术和项目实践经验。 ... [详细]
author-avatar
Jolina
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有