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();
}
}
相关推荐
1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
铅酸电池失效仿真comsol
Java小程序项目源码,该项目包含完整的前后端代码、数据库脚本和相关工具,简单部署即可运行。功能完善、界面美观、操作简单,具有很高的实际应用价值,非常适合作为Java毕业设计或Java课程设计使用。 所有项目均经过严格调试,确保可运行!下载后即可快速部署和使用。 1 适用场景: 毕业设计 期末大作业 课程设计 2 项目特点: 代码完整:详细代码注释,适合新手学习和使用 功能强大:涵盖常见的核心功能,满足大部分课程设计需求 部署简单:有基础的人,只需按照教程操作,轻松完成本地或服务器部署 高质量代码:经过严格测试,确保无错误,稳定运行 3 技术栈和工具 前端:小程序 后端框架:SSM/SpringBoot 开发环境:IntelliJ IDEA 数据库:MySQL(建议使用 5.7 版本,更稳定) 数据库可视化工具:Navicat 部署环境:Tomcat(推荐 7.x 或 8.x 版本),Maven
Java小程序项目源码,该项目包含完整的前后端代码、数据库脚本和相关工具,简单部署即可运行。功能完善、界面美观、操作简单,具有很高的实际应用价值,非常适合作为Java毕业设计或Java课程设计使用。 所有项目均经过严格调试,确保可运行!下载后即可快速部署和使用。 1 适用场景: 毕业设计 期末大作业 课程设计 2 项目特点: 代码完整:详细代码注释,适合新手学习和使用 功能强大:涵盖常见的核心功能,满足大部分课程设计需求 部署简单:有基础的人,只需按照教程操作,轻松完成本地或服务器部署 高质量代码:经过严格测试,确保无错误,稳定运行 3 技术栈和工具 前端:小程序 后端框架:SSM/SpringBoot 开发环境:IntelliJ IDEA 数据库:MySQL(建议使用 5.7 版本,更稳定) 数据库可视化工具:Navicat 部署环境:Tomcat(推荐 7.x 或 8.x 版本),Maven
springboot124中药实验管理系统设计与实现,含有完整的源码和报告文档
解除劳动合同协议书
快速过滤图像融合Matlab代码.rar
强调图像中内核形状(例如直线)的过滤器Matlab代码.rar
在内网linux服务器安装redis 在Linux环境中离线安装Redis是常见的需求,尤其是在内网服务器上,由于无法直接访问公网,我们需要提前下载Redis的源码包并手动安装。下面将详细解释如何进行这一过程。
1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
微信小程序StartKitw_xapp-startkit
座位选择微信小程序版本
机械臂代码_Mechanical_arm
图像分割测试视频river-light.mp4
前端分析-2023071100789
labview源码参考示例,可供参考学习使用
MPC跟踪轨迹圆形(以后轴为基准)
MATLAB代码:基于主从博弈的智能小区代理商定价策略及电动汽车充电管理 关键词:电动汽车 主从博弈 动态定价 智能小区 充放电优化 参考文档:《基于主从博弈的智能小区代理商定价策略及电动汽车充电管理》基本复现 仿真平台:MATLAB+CPLEX gurobi平台 优势:代码具有一定的深度和创新性,注释清晰,非烂大街的代码,非常精品 主要内容:代码主要做的是一个电动汽车充电管理和智能小区代理商动态定价的问题,将代理商和车主各自追求利益最大化建模为主从博弈,上层以代理商的充电电价作为优化变量,下层以电动汽车的充电策略作为优化变量,通过优化得出最优电价策略以及动态充电策略,代码出图效果非常好,店主已经对代码进行了深入的加工和处理,出图效果非常好,代码质量非常高,保姆级的注释以及人性化的模块子程序,所有数据均有可靠来源,联系后会直接发您资料,保证您学得会,用的起来,简直是萌新福利
springboot154基于Spring Boot智能无人仓库管理,含有完整的源码和报告文档
Matlab领域上传的视频是由对应的完整代码运行得来的,完整代码皆可运行,亲测可用,适合小白; 1、从视频里可见完整代码的内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,私信博主; 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可私信博主; 4.1 博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作