package com.feng.test;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.io.UnsupportedEncodingException;
import java.net.URL;
import java.net.URLEncoder;
import java.security.InvalidKeyException;
import java.security.Key;
import java.security.NoSuchAlgorithmException;
import java.util.Random;
import javax.crypto.Mac;
import javax.crypto.spec.SecretKeySpec;
public class GetRequest {
/*
* 拼接URL
*/
public static String getUrl(String baseUrl,String consumerKey,String consumer_secret,String nonce,String signatureMethord,String version) throws InvalidKeyException, NoSuchAlgorithmException, UnsupportedEncodingException {
//获取当前系统时间
Long test = System.currentTimeMillis();
//时间戳只有10位,需要处理
String time = test.toString().substring(0,10);
if("".equals(nonce) || nonce == null){
nonce = getRandomString(8);
}
if("".equals(signatureMethord) || signatureMethord == null){
signatureMethord = "HMAC-SHA1";
}
if("".equals(version) || version == null){
version = "1.0";
}
StringBuffer term = new StringBuffer("https://openapi.kuaipan.cn/open/requestToken?");
String signature = getSignature(baseUrl, consumerKey, consumer_secret, nonce, signatureMethord, version,time);
term.append("oauth_signature="+ signature +"");
term.append("&oauth_consumer_key="+ consumerKey +"");
term.append("&oauth_nonce="+ nonce +"");
term.append("&oauth_signature_method="+signatureMethord+"");
term.append("&oauth_timestamp="+ time +"");
term.append("&oauth_version="+version+"");
return term.toString();
}
/*
* 依据传递的参数拼接baseString
*/
public static String initBaseString(String baseUrl,String consumerKey,String nonce,String signatureMethord,String version,String time){
if(baseUrl.indexOf("GET") > -1 || baseUrl.indexOf("&") > -1){
System.out.println("初始URL不正确");
}
StringBuffer baseString = new StringBuffer("GET&"+encoderStr(baseUrl)+"&");
StringBuffer paramsStr = new StringBuffer();
paramsStr.append("oauth_consumer_key="+consumerKey);
paramsStr.append("&oauth_nonce="+nonce);
paramsStr.append("&oauth_signature_method="+signatureMethord);
paramsStr.append("&oauth_timestamp="+time);
paramsStr.append("&oauth_version="+version);
baseString.append(encoderStr(paramsStr.toString()));
return baseString.toString();
}
//生成密钥
public static String getSignature(String baseUrl,String consumerKey,String consumer_secret,String nonce,String signatureMethord,String version,String time){
String signature = "";
String base_string = initBaseString(baseUrl, consumerKey, nonce, signatureMethord, version,time);
String secret = consumer_secret + "&";
signature = new BASE64Encoder().encode(encodeHmacSHA(base_string.getBytes(), secret.getBytes())) ;
return signature;
}
/**
* 使用HmacSHA算法计算
*
* @param data 字符基串
* @param key 密钥
* @return 加密后的签名(长度为16的字节数组)
*/
public static byte[] encodeHmacSHA(byte[] data, byte[] key){
String method = "HmacSHA1";
Key k = new SecretKeySpec(key,method);
Mac mac = null;
try {
mac = Mac.getInstance(method);
mac.init(k);
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
} catch (InvalidKeyException e) {
e.printStackTrace();
}
return mac.doFinal(data);
}
/*
* 获取随机字符
*/
public static String getRandomString(int length){
StringBuffer buffer=new StringBuffer("0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ");
StringBuffer sb=new StringBuffer();
Random r=new Random();
int range=buffer.length();
for(int i=0;i<length;i++){
sb.append(buffer.charAt(r.nextInt(range)));
}
return sb.toString();
}
public static String encoderStr(String str){
String result = "";
try {
result = URLEncoder.encode(str, "UTF-8");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
return result;
}
public static void main(String[] args) {
String baseURL = "https://openapi.kuaipan.cn/open/requestToken";
String consumer_key = "应用的consumer_key";
String consumer_secret = "应用的consumer_secret";
String hmacMethod = "HMAC-SHA1";
String version = "1.0";
String url = "";
try {
url = getUrl(baseURL,consumer_key,consumer_secret,getRandomString(8),hmacMethod,version);
} catch (InvalidKeyException e1) {
e1.printStackTrace();
} catch (NoSuchAlgorithmException e1) {
e1.printStackTrace();
} catch (UnsupportedEncodingException e1) {
e1.printStackTrace();
}
try {
URL my_url = new URL(url);
BufferedReader br = new BufferedReader(new InputStreamReader(my_url.openStream()));
String strTemp = "";
while(null != (strTemp = br.readLine())){
System.out.println(strTemp);
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
package com.feng.util;
public class BASE64Encoder
{
private static final char last2byte = (char)Integer.parseInt("00000011", 2);
private static final char last4byte = (char)Integer.parseInt("00001111", 2);
private static final char last6byte = (char)Integer.parseInt("00111111", 2);
private static final char lead6byte = (char)Integer.parseInt("11111100", 2);
private static final char lead4byte = (char)Integer.parseInt("11110000", 2);
private static final char lead2byte = (char)Integer.parseInt("11000000", 2);
private static final char[] encodeTable = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '+', '/' };
public String encode(byte[] from)
{
StringBuffer to = new StringBuffer((int)(from.length * 1.34D) + 3);
int num = 0;
char currentByte = '\000';
for (int i = 0; i < from.length; i++) {
num %= 8;
while (num < 8) {
switch (num) {
case 0:
currentByte = (char)(from[i] & lead6byte);
currentByte = (char)(currentByte >>> '\002');
break;
case 2:
currentByte = (char)(from[i] & last6byte);
break;
case 4:
currentByte = (char)(from[i] & last4byte);
currentByte = (char)(currentByte << '\002');
if (i + 1 >= from.length) break;
currentByte = (char)(currentByte | (from[(i + 1)] & lead2byte) >>> 6);
break;
case 6:
currentByte = (char)(from[i] & last2byte);
currentByte = (char)(currentByte << '\004');
if (i + 1 >= from.length) break;
currentByte = (char)(currentByte | (from[(i + 1)] & lead4byte) >>> 4);
case 1:
case 3:
case 5:
}to.append(encodeTable[currentByte]);
num += 6;
}
}
if (to.length() % 4 != 0) {
for (int i = 4 - to.length() % 4; i > 0; i--) {
to.append("=");
}
}
return to.toString();
}
}
相关推荐
oauth2获取access_token1
通过httpclient post去获取,response返回码是302,返回的code放在header的Location中。 请求的时候client_id,response_type,redirect_uri,state拼接在url后面,account和password放在body表单(x-...
记一次异常解决:OAuth2获取token报错invalid stream header 在整合springcloud gateway、eureka、security、OAuth2的时候,采用授权码模式,用授权码去访问/oauth/token获取token时,遇到invalid stream header异常...
使用'mechanize'写的对于新浪的Oauth2取得access_token.
微信登录For ASP OAuth2.0接口 获取 OpenId Access_Token 头像 昵称 性别等信息
Oauth2.0连接oracle数据库,进行资源认证,生成access_token.
微信登录For ASP OAuth2.0接口 获取 OpenId Access_Token 头像 昵称 性别等信息
使用HttpClient获取oAuth2.0中的、token及refreshToken
Token刷新 jwt token刷新方案可以分为两种:...网上大部分方案也是这种:失效后,使用refresh_token获取新的access_token。并将新的access_token设置到response.header然后跳转,前端接收并无感更新新的access_token。
使用asp编程,运用于实际微信抽奖活动项目中,要求抽奖用户必须关注并且每天只能抽一次。代码实现将获取到的全局access_token缓存到数据库并...而后再用access_token获取昵称、头像、是否关注等用户信息并存于cookies中
主要将新浪微博返回来的oauth_token,oauth_token_secret存储到数据库中,然后可以 根据这两个值做oauth授权,并可以发布微博、获取微博数据以及调用其他的API 应用网站:http://www.88kuka.com 点击会员登陆->使用...
该资源是oauth2的内置表结构,其中有7张表,分别是clientdetails、oauth_access_token、oauth_approvals、oauth_client_details、oauth_client_token、oauth_code、oauth_refresh_token,仅支持mysql。
运用于实际项目中,完善后可将获取到的全局access_token缓存到数据库并判断是否需要更新,再获取用户头像、昵称、是否关注等等信息,可解决access_token重复获取的问题
主要介绍了详解OAuth2 Token 一定要放在请求头中吗,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
c# WebApi Owin 适用Microsoft.Owin.Security.OAuth Authorize - 特性验证
通过winform使用httpclient客户端调用webApi接口,api使用oauth2.0权限控制,调用接口需要进行token获取认证、
CakePHP 的 Oauth 库插件 蛋糕 2.x 版本 1.1 Oauth 库是。 Oauth 消费者实现 初始化消费者: $Consumer = new Consumer($options... $RequestToken = $Consumer->getRequestToken(array('oauth_callback' => $optio
这两天终于把获取access_token+自定义菜单+授权登录+获取用户信息部分完成了,nodejs其实不是很熟悉,所以估计有很多特性没用起来的,还有很多冗余代码以及各种问题,只能说功能实现了,大家多多担待吧。 获取access...
ASP.NET_QQ登录OAuth2.0_access_token 申请appid和appkey 源码
通过OAuth2.0受权的网页将会获取到打开者的微信信息,甚至包括微信昵称、头像等有用的数据,开发者们可以凭此设计出更多更丰富的页面应用,比如最近一直很火爆的红包类活动。除此之外还有个额外的好处,就是可以控制...