java 接友盟手机一键登录的案例(安卓端和IOS端传递token)

仅供参考,这是2020年写的文章,可能友盟改了,还请参考官方文档
仅供参考,这是2020年写的文章,可能友盟改了,还请参考官方文档
仅供参考,这是2020年写的文章,可能友盟改了,还请参考官方文档
仅供参考,这是2020年写的文章,可能友盟改了,还请参考官方文档
仅供参考,这是2020年写的文章,可能友盟改了,还请参考官方文档
仅供参考,这是2020年写的文章,可能友盟改了,还请参考官方文档

放一个友盟的手机登录流程图
在这里插入图片描述

上图可以看出,我们java只需要最后,拿到token后,发起请求,取到号码就行了

说的简单,做的真难做

这是友盟的开发文档

这是他提供的java签名demo

用以上的文件,整整弄了一下午,都没弄出来,总是提示 签名异常

我也是醉了

最后自己重新写了一个请求,才可以

废话不多说,直接上代码

@Test
public void getPhoneByYoumengToken(String youmengToken) {
		//这是你阿里云上面的appkey
		String APP_KEY = null;
		//这是你友盟上面的appkey
		String YOUMENG_APP_KEY =null;
        HttpClient httpClient;
        HttpPost postMethod;
        HttpResponse response;
        String reponseContent = null;
        //Body内容
        String body =  " {\n \"token\":\""+youmengToken+"\"\n }";

        Date d = new Date();
        String timestamp = String.valueOf(d.getTime());
        String uuid = IdUtils.randomUUID();

        try {
            httpClient = HttpClients.createDefault();
            postMethod = new HttpPost("http://verify5.market.alicloudapi.com/api/v1/mobile/info?appkey="+YOUMENG_APP_KEY);
            //设置请求头
            postMethod.addHeader("Content-type", "text/plain;charset=utf-8");
            postMethod.addHeader("Authorization", "这里放阿里云上面的appcode");
            postMethod.addHeader("X-Ca-Timestamp", timestamp);
            postMethod.addHeader("gateway_channel", "http");
            postMethod.addHeader("X-Ca-Key", APP_KEY);
            postMethod.addHeader("X-Ca-Nonce", uuid);
            postMethod.addHeader("X-Ca-Request-Mode", "DEBUG");
            postMethod.addHeader("X-Ca-Stage", "RELEASE");
            postMethod.addHeader("Host", "verify5.market.alicloudapi.com");
            postMethod.addHeader("Content-MD5", "这里把body用md5加密");
            postMethod.addHeader("Content-Type", "application/octet-stream; charset=UTF-8");
            postMethod.addHeader("Accept", "application/json");
            postMethod.addHeader("X-Ca-Signature-Headers","X-Ca-Key,X-Ca-Nonce,X-Ca-Signature,X-Ca-Signature-Headers,X-Ca-Stage,X-Ca-Timestamp");
            postMethod.setEntity(new StringEntity(body, Charset.forName("UTF-8")));
            response = httpClient.execute(postMethod);
            HttpEntity httpEntity = response.getEntity();
            reponseContent = EntityUtils.toString(httpEntity);
            System.out.println(reponseContent);

        } catch (Exception e) {
            e.printStackTrace();
        }
    }

好了,到这里,就能获取到手机号码了

有疑问的话,欢迎留言讨论 !!!

-------------------------------------------------------分割线-------------------------------------------------------------
好多人不知道md5的工具类是什么,我上面提供了友盟的sdk地址,进去拉到最下面下载就行了
这里面涉及到的工具类,都在这个java demo里面
在这里插入图片描述

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 22
    评论
安卓应用中使用token,可以通过以下步骤: 1. 在服务器生成一个token,并将其返回给安卓应用。 2. 安卓应用在发起请求时,需要将token作为请求的一个参数传递给服务器。 3. 服务器收到请求时,会检查请求中的token是否合法。如果合法,则继续处理请求,否则返回错误信息。 4. 在每次请求之前,安卓应用需要检查token是否过期。如果过期,则需要重新获取token并更新本地存储。 5. 在安卓应用中,可以将token保存在SharedPreferences或者SQLite数据库中,方便下次使用。同时,为了保障安全性,可以对token进行加密、解密处理。 示例代码: 在安卓应用中,可以使用OkHttp库来发送带有token参数的网络请求。示例如下: ```java OkHttpClient client = new OkHttpClient.Builder().build(); String token = "your_token_here"; Request request = new Request.Builder() .url("http://your_api_url_here") .addHeader("Authorization", "Bearer " + token) .build(); Call call = client.newCall(request); call.enqueue(new Callback() { @Override public void onFailure(Call call, IOException e) { e.printStackTrace(); } @Override public void onResponse(Call call, Response response) throws IOException { String responseBody = response.body().string(); Log.d("response", responseBody); } }); ``` 在服务器,可以使用JWT(JSON Web Token)来生成token。示例如下: ```java private String generateToken(User user) { long currentTimeMillis = System.currentTimeMillis(); long expireMillis = currentTimeMillis + 24 * 60 * 60 * 1000; // token有效期为24小时 String token = Jwts.builder() .setSubject(user.getUsername()) .setAudience("android_app") .setIssuedAt(new Date(currentTimeMillis)) .setExpiration(new Date(expireMillis)) .signWith(SignatureAlgorithm.HS256, "your_secret_key_here") .compact(); return token; } ``` 其中,"your_secret_key_here"是用于签名的密钥,需要保密。在验证token时,需要使用同样的密钥进行解密。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值