js获取微信code

 1          function callback(result) {    
 2             alert('cucess');    
 3             alert(result);  //输出openid  
 4         } 
 5               
 6         function getQueryString(name) {  
 7             var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i");  
 8             var r = window.location.search.substr(1).match(reg);  
 9             if (r != null) return unescape(r[2]); return null;  
10             
11         }  
12         
13         var code = getQueryString("code");  

14 // 之后进行ajax
15 $.ajax({ 16 async: false, 17 url: "http://uuuuuu.php", //这是我的服务端处理文件php的 18 type: "GET", 19 //下面几行是jsonp,如果去掉下面几行的注释,后端对应的返回结果也要去掉注释 20 // dataType: 'jsonp', 21 // jsonp: 'callback', //jsonp的值自定义,如果使用jsoncallback,那么服务器端,要返回一个jsoncallback的值对应的对象. 22 // jsonpCallback:'callback', 23 data: {code:code}, //传递本页面获取的code到后台,以便后台获取openid 24 timeout: 5000, 25 success: function (result) { 26 callback(result); 27 }, 28 error: function (jqXHR, textStatus, errorThrown) { 29 alert(textStatus); 30 } 31 });

 

这个方法的作用,获取页面中url参数的值:

1 function getQueryString(name) {  
2     var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i");  
3      var r = window.location.search.substr(1).match(reg);  
4      if (r != null) return unescape(r[2]); return null;  
5             
6 }  

例如:

1 //        ?name=123&age=234              页面路径
2 
3 //        r[0]  &age=234 或 name=123&
4 //        r[2]  123
5 //        r[3]  &

 

转载于:https://www.cnblogs.com/zuojiayi/p/7117178.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
A: 首先,要使用微信的登录能力,需要注册并开通微信开放平台。具体可以参考微信开放平台的文档。 其次,在开发者工具中创建一个小程序,获取到小程序的 appID。 然后,在小程序中引入开放能力模块,调用 wx.login 接口获取登录凭证 code。 在获取code 后,可以通过微信提供的云开发服务或者自行搭建后台服务器,调用微信的接口换取用户手机号。 下面是一个通过云开发服务获取手机号的例子: ```java import com.tencent.cloud.CosStsClient; import com.tencent.cloud.auth.Credential; import com.tencent.cloud.auth.Credentials; import com.tencent.cloud.auth.ShortTimeCredential; import com.tencent.cloud.CosXmlService; import com.tencent.cloud.CosXmlServiceConfig; import com.tencent.cloud.CosXmlServiceException; import com.tencent.cloud.auth.ScopeLimitCredentialProvider; import com.tencent.cloud.CosXmlSignSourceProvider; import com.tencent.cloud.QCloudSignSourceProvider; import com.tencent.cloud.CosXmlSignSourceProvider.GetSignSourceType; import com.tencent.qcloud.core.auth.COSXmlSignSourceProvider; import com.tencent.qcloud.core.auth.ShortTimeCredentialProvider; import java.util.LinkedList; import java.util.List; public class WeChat { public static void main(String[] args) throws Exception { String appId = "你的小程序的appID"; String appSecret = "你的小程序的appSecret"; String jsCode = "获取到的登录凭证code"; String sessionKey = getSessionKey(appId, appSecret, jsCode); String encryptedData = "获取到的encryptedData"; String iv = "获取到的iv"; String phoneNumber = getPhoneNumber(appId, sessionKey, encryptedData, iv); System.out.println("用户绑定的手机号为:" + phoneNumber); } public static String getSessionKey(String appId, String appSecret, String jsCode) throws Exception { String url = "https://api.weixin.qq.com/sns/jscode2session?appid=" + appId + "&secret=" + appSecret + "&js_code=" + jsCode + "&grant_type=authorization_code"; String response = HttpUtils.sendGet(url); JSONObject jsonObject = JSONObject.parseObject(response); String sessionKey = jsonObject.getString("session_key"); return sessionKey; } public static String getPhoneNumber(String appId, String sessionKey, String encryptedData, String iv) throws Exception { String appIdKey = appId + "_session_key"; String appSecretKey = appId + "_session_secret"; String bucketName = "default-bucket-name"; String regionName = "region"; String secretId = "secretId"; String secretKey = "secretKey"; String token = ""; long durationSeconds = 1800; // 创建临时密钥 Credential cred = new Credential(secretId, secretKey); ScopeLimitCredentialProvider scopeLimitCredentialProvider = new ScopeLimitCredentialProvider(new ShortTimeCredentialProvider(cred, durationSeconds), "selected resource regionName", "selected resource bucketName", "selected resource prefix"); LinkedList<String> headers = new LinkedList<String>(); headers.add("host"); headers.add("content-type"); CosStsClient client = new CosStsClient(scopeLimitCredentialProvider); JSONObject credentials = client.getCredential(headers); String token = credentials.getString("sessionToken"); Credentials cred = new Credentials(credentials.getLong("startTime"), credentials.getLong("expiredTime"), credentials.getString("tmpSecretId"), credentials.getString("tmpSecretKey"), token); // 创建 CosXmlServiceConfig 对象,根据个人需求修改默认的配置参数 CosXmlServiceConfig serviceConfig = new CosXmlServiceConfig.Builder() .setAppidAndRegion(appId, regionName) .setDebuggable(true) .builder(); // 创建 CosXmlService 对象,实现获取短期证书的请求签名 CosXmlService cosXmlService = new CosXmlService(context, serviceConfig, new GetSignSourceType() { @Override public QCloudSignSourceProvider getSourceProvider() { return new CosXmlSignSourceProvider(cred); } }); byte[] sessionKeyByte = Base64.decode(sessionKey, Base64.DEFAULT); byte[] encryptedDataByte = Base64.decode(encryptedData, Base64.DEFAULT); byte[] ivByte = Base64.decode(iv, Base64.DEFAULT); // AES解密 Cipher cipher = Cipher.getInstance("AES/CBC/PKCS7Padding"); SecretKeySpec keySpec = new SecretKeySpec(sessionKeyByte, "AES"); IvParameterSpec ivSpec = new IvParameterSpec(ivByte); cipher.init(Cipher.DECRYPT_MODE, keySpec, ivSpec); byte[] dataByte = cipher.doFinal(encryptedDataByte); String data = new String(dataByte, "UTF-8"); JSONObject jsonObject = JSONObject.parseObject(data); String phoneNumber = jsonObject.getString("phoneNumber"); return phoneNumber; } } ``` 需要注意的是,在调用云开发服务时,需要引入对应的 SDK 依赖。具体可以参考腾讯云 COSXML SDK 的文档。 另外,由于微信的登录接口比较敏感,开发者在开发时需要注意保护用户的隐私信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值