当前位置:首页 > 经验 >

微信打开的网页怎么清除cookie(微信清除缓存cookie)

来源:原点资讯(www.yd166.com)时间:2022-11-07 01:24:28作者:YD166手机阅读>>

微信开放平台:微信扫码登录功能

官方文档:https://developers.weixin.qq.com/doc/oplatform/Website_App/WeChat_Login/WeChat_Login.html

1. 授权流程说明

微信OAuth2.0授权登录让微信用户使用微信身份安全登录第三方应用或网站,在微信用户授权登录已接入微信OAuth2.0的第三方应用后,第三方可以获取到用户的接口调用凭证(access_token),通过access_token可以进行微信开放平台授权关系接口调用,从而可实现获取微信用户基本开放信息和帮助用户实现基础开放功能等。

微信OAuth2.0授权登录目前支持authorization_CODE模式,适用于拥有server端的应用授权。该模式整体流程为:

① 第三方发起微信授权登录请求,微信用户允许授权第三方应用后,微信会拉起应用或重定向到第三方网站,并且带上授权临时票据code参数;

② 通过code参数加上AppID和AppSecret等,通过API换取access_token;

③ 通过access_token进行接口调用,获取用户基本数据资源或帮助用户实现基本操作。

微信打开的网页怎么清除cookie,微信清除缓存cookie(1)

第一步:请求CODE

第三方使用网站应用授权登录前请注意已获取相应网页授权作用域(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的网址上,并且带上code和state参数

redirect_uri?code=CODE&state=STATE

若用户禁止授权,则重定向后不会带上code参数,仅会带上state参数

redirect_uri?state=STATE

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

第二步:通过code获取access_token

通过code获取access_token

https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code

返回说明

正确的返回:

{ "access_token":"ACCESS_TOKEN", "expires_in":7200, "refresh_token":"REFRESH_TOKEN", "openid":"OPENID", "scope":"SCOPE", "unionid": "o6_bmasdasdsad6_2sgVt7hMZOPfL" }

错误返回样例:

{"errcode":40029,"errmsg":"invalid code"}

  • Appsecret 是应用接口使用密钥,泄漏后将可能导致应用数据泄漏、应用的用户数据泄漏等高风险后果;存储在客户端,极有可能被恶意窃取(如反编译获取Appsecret);
  • access_token 为用户授权第三方应用发起接口调用的凭证(相当于用户登录态),存储在客户端,可能出现恶意获取access_token 后导致的用户数据泄漏、用户微信相关接口功能被恶意发起等行为;
  • refresh_token 为用户授权第三方应用的长效凭证,仅用于刷新access_token,但泄漏后相当于access_token 泄漏,风险同上。

建议将secret、用户数据(如access_token)放在App云端服务器,由云端中转接口调用请求。

第三步:通过access_token调用接口

获取access_token后,进行接口调用,有以下前提:

  1. access_token有效且未超时;
  2. 微信用户已授权给第三方应用帐号相应接口作用域(scope)。

对于接口作用域(scope),能调用的接口有以下:

微信打开的网页怎么清除cookie,微信清除缓存cookie(2)

2. 授权流程代码

因为微信开放平台的AppiD和APPSecret和微信公众平台的AppiD和AppSecret都是不同的,因此需要配置一下:

# 开放平台 wechat.open-app-id=wx6ad144e54af67d87 wechat.open-app-secret=91a2ff6d38a2bbccfb7e9f9079108e2e

@Data @Component @ConfigurationProperties(prefix = "wechat") public class WechatAccountConfig { //公众号appid private String mpAppId; //公众号appSecret private String mpAppSecret; //商户号 private String mchId; //商户秘钥 private String mchKey; //商户证书路径 private String keyPath; //微信支付异步通知 private String notifyUrl; //开放平台id private String openAppId; //开放平台秘钥 private String openAppSecret; }

@Configuration public class WechatOpenConfig { @Autowired private WechatAccountConfig accountConfig; @Bean public WxMpService wxOpenService() { WxMpService wxOpenService = new WxMpServiceImpl(); wxOpenService.setWxMpConfigStorage(wxOpenConfigStorage()); return wxOpenService; } @Bean public WxMpConfigStorage wxOpenConfigStorage() { WxMpInMemoryConfigStorage wxMpInMemoryConfigStorage = new WxMpInMemoryConfigStorage(); wxMpInMemoryConfigStorage.setAppId(accountConfig.getOpenAppId()); wxMpInMemoryConfigStorage.setSecret(accountConfig.getOpenAppSecret()); return wxMpInMemoryConfigStorage; } }

@Controller @RequestMapping("/wechat") @Slf4j public class WeChatController { @Autowired private WxMpService wxMpService; @Autowired private WxMpService wxOpenService; @GetMapping("/qrAuthorize") public String qrAuthorize() { //returnUrl就是用户授权同意后回调的地址 String returnUrl = "http://heng.nat300.top/sell/wechat/qrUserInfo"; //引导用户访问这个链接,进行授权 String url = wxOpenService.buildQrConnectUrl(returnUrl, WxConsts.QRCONNECT_SCOPE_SNSAPI_LOGIN, URLEncoder.encode(returnUrl)); return "redirect:" url; } //用户授权同意后回调的地址,从请求参数中获取code @GetMapping("/qrUserInfo") public String qrUserInfo(@RequestParam("code") String code) { WxMpOAuth2AccessToken wxMpOAuth2AccessToken = new WxMpOAuth2AccessToken(); try { //通过code获取access_token wxMpOAuth2AccessToken = wxOpenService.oauth2getAccessToken(code); } catch (WxErrorException e) { log.error("【微信网页授权】{}", e); throw new SellException(ResultEnum.WECHAT_MP_ERROR.getCode(), e.getError().getErrorMsg()); } //从token中获取openid String openId = wxMpOAuth2AccessToken.getOpenId(); //这个地址可有可无,反正只是为了拿到openid,但是如果没有会报404错误,为了好看随便返回一个百度的地址 String returnUrl = "http://www.baidu.com"; log.info("openid={}", openId); return "redirect:" returnUrl "?openid=" openId; } }

请求路径:在浏览器打开

https://open.weixin.qq.com/connect/qrconnect?appid=wx6ad144e54af67d87&redirect_uri=http://sell.springboot.cn/sell/qr/oTgZpwenC6lwO2eTDDf_-UYyFtqI&response_type=code&scope=snsapi_login&state=http://heng.nat300.top/sell/wechat/qrUserInfo

获取了openid:openid=o9AREv7Xr22ZUk6BtVqw82bb6AFk

微信打开的网页怎么清除cookie,微信清除缓存cookie(3)

3. 用户登录和登出

@Controller @RequestMapping("/seller") public class SellerUserController { @Autowired private SellerService sellerService; @Autowired private StringRedisTemplate redisTemplate; @Autowired private ProjectUrlConfig projectUrlConfig; @GetMapping("/login") public ModelAndView login(@RequestParam("openid") String openid, HttpServletResponse response, Map<String, Object> map) { //1. openid去和数据库里的数据匹配 SellerInfo sellerInfo = sellerService.findSellerInfoByOpenid(openid); if (sellerInfo == null) { map.put("msg", ResultEnum.LOGIN_FAIL.getMessage()); map.put("url", "/sell/seller/order/list"); return new ModelAndView("common/error"); } //2. 设置token至redis String token = UUID.randomUUID().toString(); //设置token的过期时间 Integer expire = RedisConstant.EXPIRE; redisTemplate.opsForValue().set(String.format(RedisConstant.TOKEN_PREFIX, token), openid, expire, TimeUnit.SECONDS); //3. 设置token至cookie CookieUtil.set(response, CookieConstant.TOKEN, token, expire); return new ModelAndView("redirect:" "http://heng.nat300.top/sell/seller/order/list"); } @GetMapping("/logout") public ModelAndView logout(HttpServletRequest request, HttpServletResponse response, Map<String, Object> map) { //1. 从cookie里查询 Cookie cookie = CookieUtil.get(request, CookieConstant.TOKEN); if (cookie != null) { //2. 清除Redis redisTemplate.opsForValue().getOperations().delete(String.format(RedisConstant.TOKEN_PREFIX, cookie.getValue())); //3. 清除cookie CookieUtil.set(response, CookieConstant.TOKEN, null, 0); } map.put("msg", ResultEnum.LOGOUT_SUCCESS.getMessage()); map.put("url", "/sell/seller/order/list"); return new ModelAndView("common/success", map); } }

① 将上一步获取到的openid存入数据库

微信打开的网页怎么清除cookie,微信清除缓存cookie(4)

首页 12下一页

栏目热文

清除微信cookie(微信cookie查询)

清除微信cookie(微信cookie查询)

手机内部不足,用起来简直太难受了。音乐不敢多下载几首,玩个大型游戏被提示存储空间不足……对于那些16G存储空间的手机用户...

2022-11-07 01:01:21查看全文 >>

微信怎么删除cookie(微信浏览器如何删除cookie)

微信怎么删除cookie(微信浏览器如何删除cookie)

近日,浙江绍兴越城区警方成功侦破史上最大规模的数据窃取案,阻止30亿条公民信息泄漏。警方查明,北京一个以新媒体营销为主业...

2022-11-07 01:11:34查看全文 >>

微信cookie过期怎么弄(如何清除微信的cookie)

微信cookie过期怎么弄(如何清除微信的cookie)

技术要点:1、如何获取业务系统中用户身份标识OPENID是微信公众号中用户的唯一标识,通过OPENID与业务系统中USR...

2022-11-07 01:27:20查看全文 >>

怎样清除微信的cookie(微信怎么获取cookie)

怎样清除微信的cookie(微信怎么获取cookie)

春节后复工,有很多朋友或许在想着换工作,于是在离职前总要做些准备吧? 如果你的工作会涉及到很多数据,或者你在办公的电脑上...

2022-11-07 00:49:31查看全文 >>

虾酱炒鸡蛋的做法(虾酱炒鸡蛋的做法最正宗的做法)

虾酱炒鸡蛋的做法(虾酱炒鸡蛋的做法最正宗的做法)

作者:奕空用料鸡蛋 3虾酱 10g葱 多油 适量做法步骤1、虾酱鸡蛋活在一起2、多一点,切小3、葱炒黄放虾酱4、放入虾酱...

2022-11-07 01:11:45查看全文 >>

微信没有cookie怎么办(清除微信cookie的方法)

微信没有cookie怎么办(清除微信cookie的方法)

第277期 编号:HDFYZYJJ2017277单位|恒都律师事务所 综合法律及争议解决事业部 作者|信息保护和网络安全...

2022-11-07 01:32:33查看全文 >>

微信浏览器cookie怎么清除(微信清除cookie怎么打开)

微信浏览器cookie怎么清除(微信清除cookie怎么打开)

如今这个时代,互联网已经和我们紧密相连,让我们的生活和工作更加便捷的同时,也让我们的隐私在不知不觉中被人“偷窥”。近日,...

2022-11-07 01:21:36查看全文 >>

微信cookie怎么打开(微信清除cookie怎么打开)

微信cookie怎么打开(微信清除cookie怎么打开)

上网浏览某网站时,如果浏览器的Cookies功能被禁用,可能会导致您无法登录用户帐号,可能造成无法登陆QQ邮箱,此时我们...

2022-11-07 00:50:59查看全文 >>

如何关闭微信cookie(微信cookie丢失)

如何关闭微信cookie(微信cookie丢失)

来源:央视网近日,浙江绍兴越城区警方成功侦破史上最大规模的数据窃取案,阻止30亿条公民信息泄漏。警方查明,北京一个以新媒...

2022-11-07 00:56:33查看全文 >>

清除电脑微信cookie(微信清除缓存cookie)

清除电脑微信cookie(微信清除缓存cookie)

今天我们来学习怎样在表单收集过程中,减少收集到无效数据在日常的投票、调查、甚至紧俏商品销售、活动报名类的表单中,我们经常...

2022-11-07 01:12:30查看全文 >>

文档排行