Asp.Net 핵심 기업 위 챗 침묵 권한 부여 의 실현
1. 구조 권한 부여 웹 링크
2.리 셋 으로 코드 획득 code+access가다
3. 사용자 정보 요청
디 버 깅 준비 작업->내부 네트워크 관통+도 메 인 이름 추천 해바라기 무료,무료 개발 테스트 충분
도 메 인 이름 설정
코드
[ApiController]
[Route("api/[controller]")]
public class Auth2Controller : ControllerBase
{
private readonly string _agentId = "1000002";
private readonly string _secret = "Y3f8ESBIBJoC8M_FPHOlpvmghS_Nn2ceFePRVZjw9_E";
private readonly string _corpId = "wwbf72a7a059eac0f8";
/// <summary>
///
/// </summary>
private readonly string _auth2url = "https://open.weixin.qq.com/connect/oauth2/authorize";
/// <summary>
///
/// </summary>
private readonly string _callbackurl = "http://******.zicp.vip/auth2callback/api/Auth2/Callback";
/// <summary>
/// access_token
/// </summary>
private readonly string _gettokenurl = "https://qyapi.weixin.qq.com/cgi-bin/gettoken";
/// <summary>
///
/// </summary>
private readonly string _getuserurl = "https://qyapi.weixin.qq.com/cgi-bin/user/getuserinfo";
private readonly ILogger<Auth2Controller> _logger;
private readonly IHttpClientFactory _clientFactory;
private readonly IMemoryCache _memoryCache;
public Auth2Controller(ILogger<Auth2Controller> logger, IHttpClientFactory clientFactory, IMemoryCache memoryCache)
{
_logger = logger;
_clientFactory = clientFactory;
_memoryCache = memoryCache;
}
[HttpGet]
public IActionResult Auth2(string redirecturi)
{
string strurl = $"{_auth2url}?" +
$"&appid={_corpId}" +
$"&redirect_uri={System.Web.HttpUtility.UrlEncode(_callbackurl)}" +
$"&response_type=code" +
$"&scope={_secret}" +
$"&agentid={_agentId}" +
$"&state={System.Web.HttpUtility.UrlEncode(redirecturi)}#wechat_redirect";
return Redirect(strurl);
}
[HttpGet("Callback")]
public async Task<IActionResult> Callback(string code, string state)
{
/**
1)code , 。 , code 。
2)code (5 ), 。
*/
string access_token = await GetAccessToken();
string url = $"{_getuserurl}?access_token={access_token}&code=[code]";
HttpResponseMessage response = await _clientFactory.CreateClient().GetAsync(url);
if (response.StatusCode == System.Net.HttpStatusCode.OK)
{
using (var responseStream = await response.Content.ReadAsStreamAsync())
{
var userinfo = JsonConvert.DeserializeObject<dynamic>(new StreamReader(responseStream).ReadToEnd());
int errcode = userinfo.errcode;
if (errcode == 0)
{
//
string UserId = userinfo.UserId;
//
string OpenId = userinfo.OpenId;
/**
userid ;
;
*/
if (UserId==null)
{
_memoryCache.Set<string>("UserId", OpenId);
}
else
{
_memoryCache.Set<string>("UserId", UserId);
}
}
else
{
_logger.LogError($"getuserinfo :{userinfo.errmsg}");
return Ok();
}
}
}
return Redirect($"{System.Web.HttpUtility.UrlDecode(state)}?UserId={_memoryCache.Get<string>("UserId")}");
}
public async Task<string> GetAccessToken()
{
if (_memoryCache.Get<string>("AccessToken") == null)
{
string url = $"{_gettokenurl}?corpid={_corpId}&corpsecret={_secret}";
HttpResponseMessage response = await _clientFactory.CreateClient().GetAsync(url);
if (response.StatusCode == System.Net.HttpStatusCode.OK)
{
using (var responseStream = await response.Content.ReadAsStreamAsync())
{
var access_token_result = JsonConvert.DeserializeObject<dynamic>(new StreamReader(responseStream).ReadToEnd());
int errcode = access_token_result.errcode;
if (errcode == 0)
{
string access_token = access_token_result.access_token;
int expires_in = access_token_result.expires_in;
_memoryCache.Set<string>("AccessToken", access_token, DateTimeOffset.Now.AddSeconds(expires_in - 10));
}
else
{
_logger.LogError($"access_token :{access_token_result.errmsg }");
}
}
}
}
return _memoryCache.Get<string>("AccessToken");
}
}
Asp.Net Core 기업 의 위 챗 침묵 권한 수여 실현 에 관 한 이 글 은 여기까지 소개 되 었 습 니 다.더 많은 관련 Asp.Net Core 침묵 권한 수여 내용 은 우리 의 이전 글 을 검색 하거나 아래 의 관련 글 을 계속 조회 하 시기 바 랍 니 다.앞으로 많은 응원 바 랍 니 다!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
WebAPI 원본 POST 요청 BODY 의 JSON 내용 가 져 오기controller 의 action 에 다음 코드 를 쓰 십시오: 그러나 이 코드 에서 얻 은 콘 텐 츠 는 비어 있 었 고 한참 동안 알 지 못 했 으 며 나중에 한 외국 포럼 에서 원인 을 찾 았 다. 그 이 유...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.