asp.net core 腾讯验证码的接入

asp.net core 腾讯验证码的接入

Intro

之前使用的验证码服务是用的极验验证,而且是比较旧的,好久之前接入的,而且验证码服务依赖 Session,有点不太灵活,后来发现腾讯也有验证码服务,而且支持小程序,并且是唯一支持小程序的验证码。。(垄断么。。)

而且相比之下,腾讯验证码不需要依赖 Session,集成起来也比较方便,于是就用了腾讯验证码,详细参考:https://007.qq.com/product.html?ADTAG=index.block

验证流程

640?wx_fmt=png

640?wx_fmt=png

服务器端接入

using System.ComponentModel.DataAnnotations;	
using System.Net.Http;	
using System.Threading.Tasks;	
using Microsoft.Extensions.Logging;	
using Microsoft.Extensions.Options;	
using Newtonsoft.Json;	
using WeihanLi.Extensions;	
namespace ActivityReservation.Common	
{	public class TencentCaptchaOptions	{	/// <summary>	/// 客户端AppId	/// </summary>	[Required]	public string AppId { get; set; }	/// <summary>	/// App Secret Key	/// </summary>	[Required]	public string AppSecret { get; set; }	}	public class TencentCaptchaRequest	{	/// <summary>	/// 验证码客户端验证回调的票据	/// </summary>	public string Ticket { get; set; }	/// <summary>	/// 验证码客户端验证回调的随机串	/// </summary>	public string Nonce { get; set; }	/// <summary>	/// 提交验证的用户的IP地址(eg: 10.127.10.2)	/// </summary>	public string UserIP { get; set; }	}	public class TencentCaptchaHelper	{	private class TencentCaptchaResponse	{	/// <summary>	/// 1:验证成功,0:验证失败,100:AppSecretKey参数校验错误	/// </summary>	[JsonProperty("response")]	public int Code { get; set; }	/// <summary>	/// 恶意等级 [0, 100]	/// </summary>	[JsonProperty("evil_level")]	public string EvilLevel { get; set; }	/// <summary>	/// 错误信息	/// </summary>	[JsonProperty("err_msg")]	public string ErrorMsg { get; set; }	}	private const string TencentCaptchaVerifyUrl = "https://ssl.captcha.qq.com/ticket/verify";	private readonly TencentCaptchaOptions _captchaOptions;	private readonly ILogger _logger;	private readonly HttpClient _httpClient;	public TencentCaptchaHelper(	IOptions<TencentCaptchaOptions> option,	ILogger<TencentCaptchaHelper> logger,	HttpClient httpClient)	{	_captchaOptions = option.Value;	_logger = logger;	_httpClient = httpClient;	}	public async Task<bool> IsValidRequestAsync(TencentCaptchaRequest request)	{	// 参考文档:https://007.qq.com/captcha/#/gettingStart	var response = await _httpClient.GetAsync(	$"{TencentCaptchaVerifyUrl}?aid={_captchaOptions.AppId}&AppSecretKey={_captchaOptions.AppSecret}&Ticket={request.Ticket}&Randstr={request.Nonce}&UserIP={request.UserIP}");	var responseText = await response.Content.ReadAsStringAsync();	if (responseText.IsNotNullOrEmpty())	{	_logger.Debug($"Tencent captcha verify response:{responseText}");	var result = responseText.JsonToType<TencentCaptchaResponse>();	if (result.Code == 1)	{	return true;	}	}	return false;	}	}	
}

Startup 配置:

services.AddHttpClient<TencentCaptchaHelper>(client => client.Timeout = TimeSpan.FromSeconds(3))	.ConfigurePrimaryHttpMessageHandler(() => new NoProxyHttpClientHandler());	
services.AddTencentCaptchaHelper(options =>	
{	options.AppId = Configuration["Tencent:Captcha:AppId"];	options.AppSecret = Configuration["Tencent:Captcha:AppSecret"];	
});

前端接入

前端接入这里不作多介绍了,接入方式多种多样,具体可以参考官方文档:https://cloud.tencent.com/document/product/1110/36841

下面的代码是 angular spa 在前端接入的核心代码

  private loadCaptcha(): void {	var tCaptcha = document.getElementById("tCaptcha");	if (tCaptcha) {	this.InitCaptcha();	return;	}	let script = <any>document.createElement('script');	script.id = "tCaptcha";	script.type = 'text/javascript';	script.src = "https://ssl.captcha.qq.com/TCaptcha.js"	if (script.readyState) {  //IE	script.onreadystatechange = () => {	if (script.readyState === "loaded" || script.readyState === "complete") {	this.InitCaptcha();	}	};	} else {  //Others	script.onload = () => {	this.InitCaptcha();	};	}	document.getElementsByTagName('body')[0].appendChild(script);	}	private InitCaptcha(): void {	let captchaDom = document.getElementById('TencentCaptcha1');	if (!captchaDom) {	return;	}	this.tencentRecaptcha = new TencentCaptcha(	captchaDom, appId, (res) => {	this.captchaValid = false;	console.log(res);	// res(用户主动关闭验证码)= {ret: 2, ticket: null}	// res(验证成功) = {ret: 0, ticket: "String", randstr: "String"}	if (res.ret === 0) {	this.captchaInfo.nonce = res.randstr;	this.captchaInfo.ticket = res.ticket;	this.captchaValid = true;	this.tencentRecaptcha.destroy();	let button = <HTMLElement>document.getElementById("btnSubmit");	button.click();	}	}	);	console.log(`captcha inited`);	this.tencentRecaptcha.show();	}

使用效果:

640?wx_fmt=png

老版网站接入效果:

640?wx_fmt=png

Reference

  • https://github.com/WeihanLi/ActivityReservation

  • https://reservation.weihanli.xyz/Home/Reservate

  • https://reservation-client.weihanli.xyz/reservation/new

  • https://cloud.tencent.com/document/product/1110/36841

640?wx_fmt=jpeg

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/313339.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Spring boot 启动过程

先Mark&#xff0c; https://www.cnblogs.com/trgl/p/7353782.html https://blog.csdn.net/zl1zl2zl3/article/details/79765725 https://blog.csdn.net/u010811939/article/details/80592461 https://www.jianshu.com/p/dc12081b3598

ffmpeg加环境变量

转自&#xff1a;http://blog.csdn.net/leixiaohua1020/article/details/19016469 FFMPEG是命令行工具&#xff0c;因此使用起来多少还是会有些不方便。在这记录两点方便使用FFMPEG的方法&#xff1a; 1.任何目录下都可以使用FFMPEG 问题描述&#xff1a;需要转码&#xff08;播…

.NET Core 微信公众号小程序6种获取UnionID方法,你知道哪几种?

前言获取UnionID是开发微信公众号/小程序中很有必要的一个环节&#xff0c;特别是针对一个公司拥有多个公众号小程序而推出的机制&#xff0c;实现打通账户一体化&#xff0c;用UnionID来区分多平台的唯一性。官方的解释&#xff1a;如果开发者拥有多个移动应用、网站应用、和公…

.NET LINQ分析AWS ELB日志避免996

前言小明是个单纯的 .NET开发&#xff0c;一天大哥叫住他&#xff0c;安排了一项任务&#xff1a;“小明&#xff0c;分析一下我们 超牛逼网站上个月的所有 AWS ELB流量日志&#xff0c;这些日志保存在 AWS S3上&#xff0c;你分析下&#xff0c;看哪个 API的响应时间中位数最长…

网络摄像头实时获取信息

转自&#xff1a;http://blog.csdn.net/yong_hen/article/details/42460387#quote 转自&#xff1a;http://blog.csdn.net/leo2007608/article/details/9885219 代码&#xff1a; openCV版本&#xff1a;2.4.10. 平台&#xff1a;win7 [cpp] view plaincopy #include <op…

微软100题第4题

转载自&#xff1a;http://blog.csdn.net/luxiaoxun/article/details/7537605 主要技术含量在于vector的使用(可变尺寸数组)和栈的概念。 题目&#xff1a;输入一个整数和一棵二元树。从树的根结点开始往下访问一直到叶结点所经过的所有结点形成一条路径。打印出和与输入整数相…

相同类方法之间调用,注解失效的问题

问题&#xff1a; 在Spring管理的项目中&#xff0c;方法A使用了Transactional注解&#xff0c;试图实现事务性。但当同一个class中的方法B调用方法A时&#xff0c;会发现方法A中的异常不再导致回滚&#xff0c;也即事务失效了。 原因&#xff1a; Transactional是Spring提供…

[ASP.NET Core 3框架揭秘] 依赖注入:依赖注入模式

IoC主要体现了这样一种设计思想&#xff1a;通过将一组通用流程的控制权从应用转移到框架之中以实现对流程的复用&#xff0c;并按照“好莱坞法则”实现应用程序的代码与框架之间的交互。我们可以采用若干设计模式以不同的方式实现IoC&#xff0c;比如我们在前面介绍的模板方法…

微软100题第5题

转载自&#xff1a;http://blog.csdn.net/littlestream9527/article/details/8104731 http://blog.csdn.net/v_july_v/article/details/6370650 http://blog.csdn.net/insistgogo/article/details/7689297 下面&#xff0c;我试图用最清晰易懂&#xff0c;最易令人理解的思维…

大样本统计

题目描述 我们对 0 到 255 之间的整数进行采样&#xff0c;并将结果存储在数组 count 中&#xff1a;count[k] 就是整数 k 的采样个数。 我们以 浮点数 数组的形式&#xff0c;分别返回样本的最小值、最大值、平均值、中位数和众数。其中&#xff0c;众数是保证唯一的。 我们…

北京Dotnet分享会 || 精英论坛第三期

编者按&#xff1a;没有一成不变的定律&#xff0c;没有长久不衰的流行&#xff0c;更没有一劳永逸的侥幸&#xff0c;只有自己刻苦努力、脚踏实地、兢兢业业的学习和工作&#xff0c;才会成为这个社会永远不会被淘汰的中流砥柱。一、昨夜西风凋碧树昨夜西风凋碧树&#xff0c;…

一些技术方案

延迟队列&#xff1a; https://juejin.im/post/5b5e52ecf265da0f716c3203

Matlab生成棋盘格点图

转自zhouyelihua**http://blog.csdn.net/zhouyelihua/article/details/46674191** 在摄像机标定过程中常常需要打印棋盘格程序&#xff0c;还有就是在投影仪标定当中常常需要投射和投影仪相同分辨率的 <code class"language--matlab hljs matlab has-numbering" s…

微软开源微服务运行时Dapr,赋能云原生应用开发

Dapr 是一个可移植的、由事件驱动的 Serverless 运行时&#xff0c;用于跨云和边缘构建分布式应用程序。10月9日&#xff0c;正式以 MIT 协议开源。Dapr 使开发人员能够轻松地构建弹性、无状态和有状态的微服务&#xff0c;让它们在云和边缘位置上运行&#xff0c;并包含了开发…

缺失的第一个正数

题目描述 给定一个未排序的整数数组&#xff0c;找出其中没有出现的最小的正整数。 示例 1: 输入: [1,2,0] 输出: 3示例 2: 输入: [3,4,-1,1] 输出: 2示例 3: 输入: [7,8,9,11,12] 输出: 1说明: 你的算法的时间复杂度应为O(n)&#xff0c;并且只能使用常数级别的空间。 …

最大堆和最小堆

堆和栈的区别&#xff1a;一、堆栈空间分配区别&#xff1a;1、栈&#xff08;操作系统&#xff09;&#xff1a;由操作系统自动分配释放 &#xff0c;存放函数的参数值&#xff0c;局部变量的值等。其操作方式类似于数据结构中的栈&#xff1b;2、堆&#xff08;操作系统&…

认知的高度 = 人生的高度

大家好&#xff0c;我是Z哥。我们每个人&#xff0c;每天要和很多不同的人打交道。我相信下面的场景每个程序员都有遇到过&#xff0c;业务方在某个模块下新提出了一个功能&#xff0c;但是你希望做新功能之前先把这个模块的低质量代码重构一下。但是&#xff0c;不管你怎么摆事…

快乐数

题目描述 编写一个算法来判断一个数是不是“快乐数”。 一个“快乐数”定义为&#xff1a;对于一个正整数&#xff0c;每一次将该数替换为它每个位置上的数字的平方和&#xff0c;然后重复这个过程直到这个数变为 1&#xff0c;也可能是无限循环但始终变不到 1。如果可以变为…

Pthread

转自&#xff1a;http://blog.chinaunix.net/uid-21084809-id-2215376.html Outline - 1.线程特点 - 2.pthread创建 - 3.pthread终止 - 4.mutex互斥量使用框架 - 5.cond条件变量 - 6.综合实例 1. 线程特点 线程拥有自己独立的栈、调度优先级和策略、信号屏蔽字&#xff08;…

移除链表元素

题目描述 删除链表中等于给定值 val 的所有节点。 示例: 输入: 1->2->6->3->4->5->6, val 6 输出: 1->2->3->4->5解法 使用哑结点&#xff0c;只需要变更next指针即可。 /*** Definition for singly-linked list.* public class ListNode …